.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:40px;width:100%;max-width:400px;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#333;font-size:28px;font-weight:600;margin-bottom:8px}.login-header p{color:#666;font-size:14px;margin:0}.login-form,.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;color:#333;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;transition:all .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#e74c3c}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed}.error-text{color:#e74c3c;font-size:12px;margin-top:4px;display:block}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;text-align:center}.login-button{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{text-align:center;margin-top:20px}.login-footer p{margin:8px 0;font-size:14px;color:#666}.login-footer a{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s ease}.login-footer a:hover{color:#764ba2}@media (max-width: 480px){.login-card{padding:30px 20px;margin:10px}.login-header h1{font-size:24px}.form-group input{padding:10px 14px}.login-button{padding:12px;font-size:15px}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.login-button:disabled{animation:pulse 1.5s infinite}.onboarding-card{max-width:600px}.step-indicator{display:flex;justify-content:space-between;margin-bottom:30px;position:relative}.step-indicator:before{content:"";position:absolute;top:20px;left:0;right:0;height:2px;background:#e1e5e9;z-index:1}.step{display:flex;flex-direction:column;align-items:center;position:relative;z-index:2;flex:1}.step-number{width:40px;height:40px;border-radius:50%;background:#e1e5e9;color:#666;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;margin-bottom:8px;transition:all .3s ease}.step.active .step-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.step-label{font-size:12px;color:#666;text-align:center;font-weight:500}.step.active .step-label{color:#667eea;font-weight:600}.step-content{animation:fadeInUp .4s ease-out}.step-content h3{color:#333;font-size:20px;font-weight:600;margin-bottom:8px;text-align:center}.step-content p{color:#666;font-size:14px;text-align:center;margin-bottom:25px}.step-buttons{display:flex;gap:15px;margin-top:30px}.login-container .btn-primary{flex:1;background:transparent;color:#667eea;border:2px solid #667eea;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.login-container .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.login-container .btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-container .btn-secondary{flex:1;background:transparent;color:#667eea;border:2px solid #667eea;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.plans-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-bottom:20px}.plan-card{position:relative;border:2px solid #e1e5e9;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff}.plan-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 8px 25px #667eea1a}.plan-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d);box-shadow:0 8px 25px #667eea26}.plan-card input[type=radio]{position:absolute;opacity:0;cursor:pointer}.plan-card label{cursor:pointer;display:block}.plan-card h4{color:#333;font-size:16px;font-weight:600;margin-bottom:8px;text-align:center}.plan-card p{color:#666;font-size:12px;text-align:center;margin-bottom:15px}.plan-card ul{list-style:none;padding:0;margin:0}.plan-card li{color:#666;font-size:12px;margin-bottom:5px;padding-left:15px;position:relative}.plan-card li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700}@media (max-width: 600px){.onboarding-card{max-width:100%;margin:10px}.step-indicator{margin-bottom:20px}.step-number{width:35px;height:35px;font-size:14px}.step-label{font-size:11px}.plans-container{grid-template-columns:1fr}.step-buttons{flex-direction:column}}.password-strength{margin-top:10px}.strength-bar{width:100%;height:4px;background:#e1e5e9;border-radius:2px;overflow:hidden;margin-bottom:8px}.strength-fill{height:100%;transition:all .3s ease;border-radius:2px}.strength-0{width:0%;background:#e74c3c}.strength-1{width:20%;background:#e74c3c}.strength-2{width:40%;background:#f39c12}.strength-3{width:60%;background:#f1c40f}.strength-4{width:80%;background:#27ae60}.strength-5{width:100%;background:#2ecc71}.strength-text{font-size:12px;font-weight:500;margin-bottom:10px;text-align:center}.strength-0+.strength-text,.strength-1+.strength-text{color:#e74c3c}.strength-2+.strength-text{color:#f39c12}.strength-3+.strength-text{color:#f1c40f}.strength-4+.strength-text,.strength-5+.strength-text{color:#27ae60}.password-criteria{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:11px;color:#666}.criterion{display:flex;align-items:center;gap:4px;opacity:.6;transition:all .3s ease}.criterion.met{opacity:1;color:#27ae60;font-weight:500}.criterion:before{content:"○";color:#ccc;font-weight:700}.criterion.met:before{content:"✓";color:#27ae60}@media (max-width: 480px){.password-criteria{grid-template-columns:1fr;gap:6px}}.success-container{text-align:center;padding:20px 0}.success-container .success-message{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#166534;padding:16px;border-radius:8px;margin-bottom:20px;font-size:14px;line-height:1.5}.redirect-info{margin-top:15px}.redirect-info p{color:#666;font-size:13px;margin:0;font-style:italic}.loading-container{text-align:center;padding:30px 0}.loading-text{color:#667eea;font-size:16px;font-weight:500;margin:0}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{padding-right:45px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:all .3s ease;opacity:.7;display:flex;align-items:center;justify-content:center}.password-toggle svg{width:20px;height:20px;color:#666;transition:color .3s ease}.password-toggle:hover{opacity:1;background:#667eea1a}.password-toggle:hover svg{color:#667eea}.password-toggle:disabled{opacity:.4;cursor:not-allowed}.password-toggle:focus{outline:none;box-shadow:0 0 0 2px #667eea33}.dashboard-layout{display:flex;min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.sidebar{width:280px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:fixed;height:100vh;overflow-y:auto;z-index:1000;box-shadow:2px 0 10px #0000001a;transition:width .3s ease}.sidebar.retracted{width:70px}.sidebar.retracted .sidebar-header{padding:16px 10px}.sidebar.retracted .sidebar-user-info{padding:12px 10px}.sidebar.retracted .sidebar-logout-button{padding:10px;display:flex;justify-content:center;align-items:center}.sidebar.retracted .sidebar-item{padding:16px 0;justify-content:center}.sidebar.retracted .sidebar-icon{margin-right:0}.sidebar.retracted .sidebar-nav{padding:10px 0}.sidebar-toggle{position:fixed;top:20px;left:261px;width:40px;height:40px;border-radius:50%;background:#fff;border:2px solid #667eea;color:#667eea;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;transition:all .3s ease;box-shadow:0 2px 8px #00000026}.sidebar.retracted .sidebar-toggle{left:51px}.sidebar-toggle:hover{background:#667eea;color:#fff;transform:scale(1.1)}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}.sidebar-header h3{margin:0;font-size:20px;font-weight:600;color:#fff}.sidebar-logo-container{width:100%;display:flex;align-items:center;justify-content:center;padding:0 10px}.sidebar-logo{width:100%;max-width:100px;height:auto;object-fit:contain;transition:max-width .3s ease}.sidebar.retracted .sidebar-logo{max-width:45px;padding:0}.sidebar-user-info{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff0d}.user-welcome{margin-bottom:12px}.user-welcome span{color:#fff;font-size:14px;font-weight:500;display:block;word-wrap:break-word}.sidebar-logout-button{width:100%;background:#e74c3c;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.sidebar-logout-button:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 4px 15px #e74c3c4d}.sidebar-nav{padding:20px 0}.sidebar-item{width:100%;display:flex;align-items:center;padding:16px 20px;background:none;border:none;color:#fffc;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:left}.sidebar-item.locked{opacity:.45}.sidebar-item:hover{background:#ffffff1a;color:#fff}.sidebar-item.active{background:#fff3;color:#fff;border-left:4px solid white}.sidebar-icon{margin-right:12px;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar-label{flex:1}.main-content{flex:1;margin-left:280px;min-height:100vh;display:flex;flex-direction:column;min-width:0;transition:margin-left .3s ease}.main-content.sidebar-retracted{margin-left:70px}.content-wrapper{flex:1;padding:20px;min-width:0}.dashboard-header{display:flex;justify-content:center;align-items:center;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a;margin:20px}.dashboard-header h2{color:#333;font-size:28px;font-weight:600;margin:0}.content-section{margin-bottom:30px}.content-section h2{color:#333;font-size:24px;font-weight:600;margin-bottom:20px;margin-left:20px}.dashboard-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-left:20px;margin-right:20px}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease;border:1px solid #e1e5e9}.card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.card h3{color:#333;font-size:20px;font-weight:600;margin-bottom:12px}.card p{color:#666;font-size:14px;line-height:1.6;margin:0}@media (max-width: 1024px){.sidebar{width:240px}.sidebar.retracted{width:60px}.main-content{margin-left:240px}.main-content.sidebar-retracted{margin-left:60px}.sidebar-toggle{left:221px}.sidebar.retracted .sidebar-toggle{left:41px}}@media (max-width: 768px){.dashboard-layout{flex-direction:column}.sidebar-toggle{display:none}.sidebar,.sidebar.retracted{width:100%;height:auto;position:relative;max-height:400px}.main-content,.main-content.sidebar-retracted{margin-left:0}.sidebar.retracted .sidebar-item{justify-content:flex-start;padding:12px 16px}.sidebar.retracted .sidebar-icon{margin-right:8px}.dashboard-header{flex-direction:column;gap:16px;text-align:center;margin:10px}.dashboard-header h2{font-size:24px}.sidebar-user-info{padding:15px}.user-welcome span{font-size:13px}.sidebar-logout-button{padding:8px 12px;font-size:13px}.dashboard-content{grid-template-columns:1fr;margin-left:10px;margin-right:10px}.content-section h2{margin-left:10px}.card{padding:20px}.sidebar-nav{display:flex;flex-wrap:wrap;gap:8px;padding:10px}.sidebar-item{flex:1;min-width:120px;padding:12px 16px;font-size:14px}.sidebar-icon{margin-right:8px;font-size:16px}}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (min-width: 768px){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.flex{display:flex}.flex-1{flex:1 1 0%}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.w-4{width:1rem}.h-4{height:1rem}.w-5{width:1.25rem}.h-5{height:1.25rem}.w-6{width:1.5rem}.h-6{height:1.5rem}.w-8{width:2rem}.h-8{height:2rem}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-red-600{color:#dc2626}.text-green-600{color:#16a34a}.text-blue-600{color:#2563eb}.text-purple-600{color:#9333ea}.text-yellow-600{color:#ca8a04}.text-indigo-600{color:#4f46e5}.text-indigo-800{color:#3730a3}.text-orange-600{color:#ea580c}.text-orange-800{color:#9a3412}.bg-orange-100{background-color:#ffedd5}.rounded-full{border-radius:9999px}.col-span-2{grid-column:span 2 / span 2}.module-container{padding:0 20px 20px;max-width:100%;min-width:0}.module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.module-header h1{margin:0}.module-header p{margin:4px 0 0}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:1px solid #667eea;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;line-height:1.2;min-height:38px;cursor:pointer;transition:all .3s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.btn-primary:disabled,.btn-secondary:disabled,.btn-success:disabled,.btn-danger:disabled,.btn-warning:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:1px solid #667eea;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;line-height:1.2;min-height:38px;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#fff;color:#667eea;border:1px solid #667eea;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;line-height:1.2;min-height:38px;cursor:pointer;transition:all .3s ease}.btn-outline:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 15px #667eea26}.btn-sm{padding:8px 16px;font-size:13px}.btn-inline{width:auto;align-self:flex-start}.btn-sm.btn-primary,.btn-sm.btn-secondary{padding:8px 16px}.btn-sm.btn-success,.btn-sm.btn-danger,.btn-sm.btn-warning{padding:8px 16px;display:inline-flex;align-items:center;gap:4px}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid #e1e5e9;background:#fff;color:#666;cursor:pointer;transition:all .3s ease;position:relative}.btn-icon:hover{background:#f8f9fa;border-color:#667eea;color:#667eea}.btn-icon.text-red-600:hover{border-color:#dc2626;color:#dc2626;background:#fef2f2}.btn-icon.text-green-600:hover{border-color:#16a34a;color:#16a34a;background:#f0fdf4}.btn-icon.text-yellow-600:hover{border-color:#ca8a04;color:#ca8a04;background:#fefce8}.btn-icon[data-tooltip]:after,.btn-icon[data-tooltip]:before{opacity:0;pointer-events:none;transition:opacity .2s ease}.btn-icon[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:#111827;color:#fff;font-size:12px;padding:6px 10px;border-radius:6px;white-space:nowrap;z-index:20}.btn-icon[data-tooltip]:before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border-width:6px 6px 0 6px;border-style:solid;border-color:#111827 transparent transparent transparent;z-index:19}.btn-icon[data-tooltip]:hover:after,.btn-icon[data-tooltip]:hover:before,.btn-icon[data-tooltip]:focus-visible:after,.btn-icon[data-tooltip]:focus-visible:before{opacity:1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-content{flex:1}.stat-label{font-size:13px;color:#666;margin:0 0 4px}.stat-value{font-size:24px;font-weight:700;color:#333;margin:0}.module-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #e1e5e9;padding-bottom:0;overflow-x:auto}.tab-item{display:flex;align-items:center;gap:8px;padding:12px 20px;background:none;border:none;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}.tab-item:hover{color:#667eea}.tab-item.active{color:#667eea;border-bottom-color:#667eea}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;overflow-x:auto;overflow-y:hidden;max-width:100%;-webkit-overflow-scrolling:touch}.table-container.tooltip-container{overflow-x:auto;overflow-y:visible;position:relative}.table-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e1e5e9;flex-wrap:wrap;gap:16px}.table-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.search-box{display:flex;align-items:center;gap:8px;background:#f8f9fa;border:1px solid #e1e5e9;border-radius:8px;padding:8px 16px;min-width:250px}.search-box input{border:none;background:none;outline:none;font-size:14px;flex:1}.search-box input::placeholder{color:#999}.data-table{width:100%;border-collapse:collapse;min-width:720px}.data-table thead{background:#f8f9fa}.data-table th{padding:14px;text-align:left;font-size:13px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:14px;border-bottom:1px solid #f0f0f0;font-size:14px;color:#333;word-break:break-word}.data-table tbody tr:hover{background:#f8f9ff}.data-table tbody tr:last-child td{border-bottom:none}.data-table tfoot{background:#f8f9fa;font-weight:600}.data-table tfoot td{padding:14px 20px;border-top:2px solid #e1e5e9}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9}.empty-state h3{margin:16px 0 8px;font-size:20px;font-weight:600;color:#333}.empty-state p{margin:0 0 24px;color:#666;max-width:400px}.bg-red-100{background-color:#fee2e2}.text-red-800{color:#991b1b}.bg-yellow-100{background-color:#fef3c7}.text-yellow-800{color:#92400e}.bg-green-100{background-color:#dcfce7}.text-green-800{color:#166534}.bg-blue-100{background-color:#dbeafe}.text-blue-800{color:#1e40af}.bg-purple-100{background-color:#f3e8ff}.text-purple-800{color:#6b21a8}.bg-gray-100{background-color:#f3f4f6}.text-gray-800{color:#1f2937}.bg-indigo-100{background-color:#e0e7ff}.bg-teal-100{background-color:#ccfbf1}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.calendar-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:#f8f9fa;border-bottom:1px solid #e1e5e9}.calendar-weekday{padding:12px;text-align:center;font-size:13px;font-weight:600;color:#666;text-transform:uppercase}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-width:0;min-height:100px;overflow:hidden;padding:8px;border-right:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0;background:#fff;cursor:pointer;transition:background .2s ease}.calendar-day:hover{background:#f8f9ff}.calendar-day.selected{outline:2px solid #667eea;outline-offset:-2px;background:#eef2ff}.calendar-day.available{background:#ecfdf5;border-color:#d1fae5}.calendar-day.available .day-number{color:#065f46;font-weight:600}.calendar-day:nth-child(7n){border-right:none}.calendar-day.other-month{background:#fafafa}.calendar-day.other-month .day-number{color:#ccc}.calendar-day.past{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.calendar-day.past:hover{background:#f3f4f6}.calendar-day.today{background:#f0f4ff}.calendar-day.today .day-number{background:#667eea;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.day-number{font-size:14px;font-weight:500;color:#333;margin-bottom:4px}.day-events{display:flex;flex-direction:column;gap:2px;max-height:52px;overflow:hidden}.event-dot{padding:2px 6px;border-radius:4px;font-size:11px;color:#fff;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-title{font-size:11px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.more-events{font-size:11px;color:#666;padding:2px 6px}.events-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;padding:20px}.event-card{display:flex;align-items:flex-start;gap:16px;padding:16px;border-bottom:1px solid #f0f0f0}.event-card:last-child{border-bottom:none}.event-indicator{width:4px;height:100%;min-height:60px;border-radius:2px}.event-content{flex:1}.event-content h4{margin:0 0 8px;font-size:16px}.event-details{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:#666;margin-bottom:8px}.event-participants{display:flex;align-items:center;gap:8px;font-size:13px;color:#666}.event-type-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.agenda-layout{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}.agenda-tasks{display:flex;flex-direction:column;gap:20px}.calendar-toggle{display:flex;gap:8px}.calendar-toggle .btn-sm{border:1px solid #e1e5e9;background:#f8fafc;color:#475569}.calendar-toggle .btn-sm.active{background:#667eea;border-color:#667eea;color:#fff;box-shadow:0 6px 12px #667eea2e}.reports-container .module-header{align-items:flex-start}.reports-header-actions{display:flex;flex-direction:column;gap:12px;align-items:flex-end}.reports-filter{display:flex;gap:12px;flex-wrap:wrap}.reports-filter select,.reports-filter input{padding:8px 12px;border-radius:8px;border:1px solid #e1e5e9;font-size:13px}.reports-actions{display:flex;justify-content:flex-end}.reports-actions .btn-secondary{padding:8px 14px;border-radius:10px;border:1px solid #e1e5e9;background:#111827;color:#fff;font-size:13px}.reports-content{display:flex;flex-direction:column;gap:24px}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.report-summary-card{display:flex;gap:12px;padding:16px;border-radius:12px;background:#fff;border:1px solid #e1e5e9;box-shadow:0 2px 8px #0000000f;align-items:center}.summary-icon{width:36px;height:36px;border-radius:10px;background:#eef2ff;display:flex;align-items:center;justify-content:center;color:#4338ca}.summary-label{font-size:12px;color:#6b7280}.summary-value{font-size:18px;color:#111827;display:block}.report-card{background:#fff;border-radius:12px;border:1px solid #e1e5e9;box-shadow:0 2px 8px #0000000f;padding:16px}.report-card-header h3{margin:0;font-size:15px;color:#1f2937}.report-card-header span{font-size:12px;color:#6b7280}.chart-wrapper{position:relative;margin-top:12px;height:220px}.chart-bar{fill:#6366f1;cursor:pointer}.chart-label{font-size:10px;fill:#6b7280}.chart-line{fill:none;stroke:#6366f1;stroke-width:3}.chart-point{fill:#6366f1;cursor:pointer}.chart-tooltip{position:fixed;background:#111827;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;pointer-events:none;transform:translate(-50%,-12px);z-index:999;display:flex;flex-direction:column;gap:2px}.donut-wrapper{display:flex;gap:16px;align-items:center}.donut{width:120px;height:120px}.donut-legend{display:flex;flex-direction:column;gap:6px}.donut-legend .legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280}.donut-legend .legend-item strong{color:#111827}@media print{body *{visibility:hidden}#reports-print-area,#reports-print-area *{visibility:visible}#reports-print-area{position:absolute;left:0;top:0;width:100%}.reports-actions,.reports-filter,.tabs{display:none!important}.report-card,.report-summary-card{box-shadow:none}}.module-loading-overlay{position:relative;min-height:60vh}.module-loading-overlay .loading-container{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffd1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;z-index:10}.agenda-panel{display:flex;flex-direction:column;gap:20px}.agenda-appointments-grid{display:grid;gap:20px}.appointment-link{display:flex;flex-direction:column;gap:12px}.appointment-link input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e1e5e9;font-size:13px}.appointment-link-actions{display:flex;gap:10px;flex-wrap:wrap}.appointment-resource-list,.appointment-booking-list,.appointment-availability-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.appointments-services{display:flex;flex-direction:column;gap:20px}.services-grid{display:grid;gap:20px}.services-panel{background:#fff;border-radius:14px;border:1px solid #e1e5e9;box-shadow:0 2px 8px #0000000f;padding:18px;display:flex;flex-direction:column;gap:16px}.services-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.services-header h3{margin:0;font-size:16px;font-weight:600;color:#1f2937}.services-header p{margin:6px 0 0;font-size:12px;color:#6b7280}.services-count{background:#eef2ff;color:#4338ca;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;height:fit-content}.services-list{display:flex;flex-direction:column;gap:12px}.service-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid #f0f0f0;background:#fbfbfb}.service-card-main{display:flex;flex-direction:column;gap:4px}.service-card-main strong{font-size:14px;color:#111827}.service-card-main span{font-size:12px;color:#6b7280}.service-card-main small{font-size:12px;color:#9ca3af}.services-form{display:flex;flex-direction:column;gap:12px}.services-form input,.services-form select{padding:10px 12px;border-radius:10px;border:1px solid #e1e5e9;font-size:13px}.services-form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.resource-service-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.resource-service-title label{display:flex;align-items:center;gap:8px;font-weight:600;color:#111827}.resource-service-title span{font-size:12px;color:#6b7280}.resource-service-fields input{flex:1;padding:10px 12px;border-radius:10px;border:1px solid #e1e5e9;font-size:13px}.appointment-resource-item,.appointment-booking-item,.appointment-availability-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid #f0f0f0;background:#fbfbfb}.appointment-resource-item span,.appointment-booking-item span,.appointment-availability-item span,.appointment-resource-item small,.appointment-booking-item small,.appointment-availability-item small{display:block;font-size:12px;color:#6b7280;margin-top:4px}.appointment-booking-item.approved{border-color:#dbeafe;background:#eff6ff}.appointment-actions{display:flex;align-items:center;gap:8px}.agenda-panel-card{background:#fff;border-radius:14px;border:1px solid #e1e5e9;box-shadow:0 2px 8px #0000000f;padding:16px}.agenda-panel-title{margin:0 0 12px;font-size:16px;font-weight:600;color:#1f2937}.agenda-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.agenda-count{background:#eef2ff;color:#4338ca;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.agenda-form{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.agenda-form label{display:flex;flex-direction:column;gap:6px}.agenda-form label span{font-size:12px;font-weight:600;color:#4b5563;letter-spacing:.02em}.agenda-form input,.agenda-form textarea,.agenda-form select{padding:10px 12px;border-radius:10px;border:1px solid #e1e5e9;font-size:13px}.agenda-form textarea{min-height:70px;resize:vertical}.agenda-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tasks-list{display:flex;flex-direction:column;gap:12px}.task-item{padding:12px;border-radius:12px;border:1px solid #f0f0f0;background:#fbfbfb}.task-item.completed{opacity:.7;text-decoration:line-through}.task-main{display:flex;align-items:flex-start;gap:10px}.task-main input[type=checkbox]{margin-top:4px}.task-date{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#6b7280;margin-top:4px}.task-notes{margin:6px 0 0;font-size:12px;color:#6b7280}.task-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:8px}.task-edit{margin-top:10px;display:flex;flex-direction:column;gap:10px}.task-edit input,.task-edit textarea,.task-edit select{padding:8px 10px;border-radius:8px;border:1px solid #e1e5e9;font-size:12px}.priority-low{border-left:4px solid #10b981}.priority-medium{border-left:4px solid #f59e0b}.priority-high{border-left:4px solid #ef4444}.agenda-main{display:flex;flex-direction:column;gap:16px}.agenda-legend{display:flex;flex-wrap:wrap;gap:12px;padding:12px 4px 0}.agenda-day-panel{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000f}.agenda-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.agenda-day-header h3{margin:0;font-size:16px;font-weight:600;color:#1f2937}.agenda-day-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid #f0f0f0}.agenda-day-item:last-child{border-bottom:none}.agenda-day-meta{margin-top:4px;display:flex;gap:12px;font-size:12px;color:#6b7280}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.legend-dot{width:10px;height:10px;border-radius:50%}.event-type-default{background:#94a3b8}.event-type-payable{background:#ef4444}.event-type-receivable{background:#22c55e}.event-type-delivery{background:#3b82f6}.event-type-service{background:#f59e0b}.event-type-purchase{background:#0ea5e9}.event-type-production{background:#8b5cf6}.event-type-payroll{background:#14b8a6}.event-type-stock{background:#64748b}.event-type-vacation{background:#ec4899}.event-type-task{background:#111827}.event-type-appointment{background:#0ea5e9}.events-list .event-type-badge{background:#f3f4f6;color:#374151}.agenda-container .event-indicator.event-type-default,.agenda-container .event-indicator.event-type-payable,.agenda-container .event-indicator.event-type-receivable,.agenda-container .event-indicator.event-type-delivery,.agenda-container .event-indicator.event-type-service,.agenda-container .event-indicator.event-type-purchase,.agenda-container .event-indicator.event-type-production,.agenda-container .event-indicator.event-type-payroll,.agenda-container .event-indicator.event-type-stock,.agenda-container .event-indicator.event-type-vacation,.agenda-container .event-indicator.event-type-task,.agenda-container .event-indicator.event-type-appointment{border-radius:4px}@media (max-width: 1100px){.agenda-appointments-grid,.services-grid{grid-template-columns:1fr}}@media (max-width: 1100px){.agenda-layout{grid-template-columns:1fr}}.bg-blue-500{background-color:#3b82f6}.bg-green-500{background-color:#22c55e}.bg-yellow-500{background-color:#eab308}.bg-purple-500{background-color:#a855f7}.bg-gray-500{background-color:#6b7280}.module-content{margin-top:0;max-width:100%;min-width:0;overflow-x:hidden}.public-appointment{min-height:100vh;background:#f8fafc;padding:40px 16px;display:flex;align-items:flex-start;justify-content:center}.public-appointment-card{width:100%;max-width:90%;background:#fff;border-radius:16px;border:1px solid #e1e5e9;box-shadow:0 8px 24px #0f172a14;padding:24px}.public-appointment-card h1{margin:0 0 8px;font-size:22px;color:#1f2937}.public-appointment-card p{margin:0 0 16px;color:#6b7280}.public-appointment-form{display:flex;flex-direction:column;gap:14px}.public-appointment-section{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#f9fafb}.public-appointment-section h4{margin:0 0 12px;font-size:13px;font-weight:700;color:#1f2937;text-transform:uppercase;letter-spacing:.04em}.public-appointment-grid{display:grid;gap:12px;margin-bottom:12px}.public-appointment-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.public-appointment-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.public-appointment-grid.one{grid-template-columns:1fr}.public-appointment-customer-card{display:flex;flex-direction:column;gap:4px;padding:12px 16px;border-radius:12px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}.public-appointment-customer-card strong{font-size:15px;color:#7c2d12}.public-appointment-customer-card span{font-size:12px}.public-appointment-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#374151}.public-appointment-form input,.public-appointment-form textarea,.public-appointment-form select{padding:10px 12px;border-radius:10px;border:1px solid #e1e5e9;font-size:13px}.public-appointment-form textarea{min-height:80px;resize:vertical}.public-appointment-slots{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.public-slot{border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;padding:10px;border-radius:10px;font-size:13px;display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:all .2s ease}.public-slot span{font-size:11px;color:#2563eb}.public-slot:hover{transform:translateY(-1px);box-shadow:0 6px 14px #1e40af26}.public-slot.pending{background:#fef9c3;border-color:#facc15;color:#92400e;cursor:not-allowed}.public-slot.pending span{color:#b45309}.public-slot.selected{background:#dcfce7;border-color:#22c55e;color:#166534}.public-slot.selected span{color:#166534}.public-slot:disabled{opacity:.85;cursor:not-allowed;transform:none;box-shadow:none}.public-appointment-info{display:grid;gap:10px}.public-appointment .error-text{color:#dc2626;font-size:13px;margin:0}.public-appointment .success-text{color:#16a34a;font-size:13px;margin:0}.public-appointment-success{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:12px;background:#ecfdf3;border:1px solid #86efac;color:#166534}.public-appointment-success h4{margin:0;font-size:16px}.public-appointment-success p{margin:0;font-size:13px}@media (max-width: 768px){.public-appointment-grid.two,.public-appointment-grid.three{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal,.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-lg{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e1e5e9}.modal-header h3{margin:0;font-size:20px;font-weight:600;color:#333}.modal-header>button:last-child{background:none;border:none;color:#999;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-header>button:last-child:hover{background:#f0f0f0;color:#666}.modal-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close:hover{background:#f0f0f0;color:#666}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e1e5e9}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;margin-bottom:16px}.form-group label{font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1px solid #e1e5e9;border-radius:8px;font-size:14px;color:#333;transition:all .2s ease;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px;margin-bottom:16px}.form-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.form-section-title{margin:0;font-size:16px;font-weight:600;color:#1f2937}.rich-editor{border:1px solid #e1e5e9;border-radius:8px;overflow:visible}.rich-editor-toolbar{display:flex;flex-wrap:wrap;column-gap:6px;row-gap:2px;padding:6px 8px;border-bottom:1px solid #e1e5e9;background:#f8f9fa;align-items:center;align-content:center}.rich-editor-group{display:inline-flex;align-items:center;gap:6px;padding-right:6px;border-right:1px solid #e1e5e9;min-height:36px}.rich-editor-group:last-child{border-right:none;padding-right:0}.rich-editor-btn{width:34px;height:34px;border:1px solid #d1d5db;background:#fff;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:#374151;transition:all .15s ease}.rich-editor-btn:hover{border-color:#c7d2fe;background:#eef2ff}.rich-editor-btn.is-active{border-color:#6366f1;background:#e0e7ff;color:#1f2937}.rich-editor-btn-text{font-size:12px;font-weight:600}.rich-editor-icon{width:16px;height:16px}.rich-editor-select,.rich-editor-color{padding:0 8px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:12px;color:#333;height:38px;line-height:normal;box-sizing:border-box}.rich-editor-color{width:38px;height:38px;padding:0}.rich-editor-select--format{min-width:120px}.rich-editor-select--font{min-width:200px}.rich-editor-select--size{min-width:140px}.rich-editor-color-label{display:flex;align-items:center;gap:6px;font-size:12px;color:#333}.rich-editor-color-icon{font-weight:600;font-size:12px;color:#111827}.rich-editor-details{position:relative}.rich-editor-details summary{list-style:none}.rich-editor-details summary::-webkit-details-marker{display:none}.rich-editor-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px;min-width:320px;max-width:90vw;max-height:min(60vh,420px);overflow:auto;box-shadow:0 12px 25px #0f172a1f;z-index:20}.rich-editor-dropdown--insert{width:min(90vw,320px);max-width:min(90vw,320px)}.rich-editor-table-size{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:end}.rich-editor-table-field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#4b5563}.rich-editor-table-field input{border:1px solid #d1d5db;border-radius:6px;height:34px;padding:0 8px;font-size:12px}.rich-editor-table-size .rich-editor-dropdown-btn{grid-column:1 / -1;justify-content:center}.rich-editor-table-toolbar{display:flex;flex-wrap:wrap;gap:8px;padding:8px;border-bottom:1px solid #e1e5e9;background:#fff}.rich-editor-table-group{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px;padding-right:6px;border-right:1px solid #e1e5e9}.rich-editor-table-group:last-child{border-right:none;padding-right:0}.rich-editor-dropdown-title{font-size:12px;font-weight:600;color:#4b5563;margin-bottom:8px}.rich-editor-dropdown-section{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.rich-editor-dropdown-section:last-child{margin-bottom:0}.rich-editor-dropdown-btn{border:1px solid #d1d5db;background:#f9fafb;border-radius:6px;padding:6px 8px;font-size:12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:#374151}.rich-editor-dropdown-btn:hover{background:#eef2ff;border-color:#c7d2fe}.rich-editor-content{width:min(210mm,100%);min-height:297mm;margin:0 auto;padding:18px 20px;font-size:14px;color:#333;background:#fff;box-shadow:0 0 0 1px #e5e7eb}.rich-editor-table{width:100%;border-collapse:collapse;margin:10px 0}.rich-editor-table th,.rich-editor-table td{border:1px solid #d1d5db;padding:6px 8px;text-align:left;vertical-align:top}.rich-editor-table td.rich-editor-cell-selected,.rich-editor-table th.rich-editor-cell-selected{outline:2px solid #6366f1;outline-offset:-2px;background:#6366f114}.rich-editor-table th{background:#f3f4f6;font-weight:600}.rich-editor-content:focus{outline:none}.rich-editor-content:empty:before{content:attr(data-placeholder);color:#9ca3af}.form-group.checkbox{flex-direction:row;align-items:center;gap:8px}.form-group.checkbox input{width:auto;margin:0}.form-group.checkbox label{margin:0;cursor:pointer}.flex-2{grid-column:span 2}.signature-anchor-layout{display:grid;grid-template-columns:280px 1fr;gap:20px}.signature-anchor-controls{display:flex;flex-direction:column;gap:12px}.signature-anchor-list{display:flex;flex-direction:column;gap:10px}.signature-anchor-item{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;border:1px solid #e1e5e9;border-radius:8px;padding:10px;background:#fff}.signature-anchor-item.active{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51f}.signature-anchor-actions{display:flex;gap:6px;flex-wrap:wrap}.signature-anchor-status{font-size:12px;color:#6b7280;margin-top:4px}.signature-anchor-preview{border:1px solid #e1e5e9;border-radius:10px;background:#fafafa;padding:12px}.signature-anchor-canvas{position:relative;background:#fff;border-radius:8px;border:1px solid #e1e5e9;min-height:520px;overflow:auto}.signature-anchor-canvas.placing{cursor:crosshair}.signature-anchor-document{padding:16px}.signature-anchor-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.signature-anchor{position:absolute;border:2px dashed #4f46e5;background:#4f46e514;border-radius:6px;box-sizing:border-box;padding:6px;display:flex;flex-direction:column;gap:4px;color:#1f2937;pointer-events:auto}.signature-anchor-active{border-color:#0ea5e9;background:#0ea5e914}.signature-anchor-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:#334155}.signature-anchor-content{flex:1;display:flex;align-items:center;justify-content:center;font-size:12px;color:#111827;text-align:center}.signature-anchor-content img{max-width:100%;max-height:100%;object-fit:contain}.signature-anchor-placeholder{color:#9ca3af;font-size:12px}.signature-anchor-handle{position:absolute;width:12px;height:12px;right:-6px;bottom:-6px;background:#4f46e5;border:2px solid #fff;border-radius:50%;cursor:se-resize}.signature-anchor-hint{font-size:12px;color:#6b7280;margin-top:8px}.form-input,.form-select,.form-textarea{padding:10px 14px;border:1px solid #e1e5e9;border-radius:8px;font-size:14px;color:#333;transition:all .2s ease;font-family:inherit;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;min-height:80px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #e1e5e9;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-message{background:#fee2e2;color:#991b1b;padding:16px 20px;border-radius:8px;border:1px solid #fecaca;margin-bottom:16px}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.panel-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000f}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:16px}.panel-title{margin:0;font-size:16px;font-weight:600;color:#1f2937}.panel-subtitle{margin:4px 0 0;font-size:12px;color:#6b7280}.schedule-grid{display:flex;flex-direction:column;gap:12px}.schedule-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.schedule-day{display:flex;align-items:center;gap:8px;min-width:140px;font-weight:600;color:#374151}.schedule-period{display:flex;align-items:center;gap:8px}.schedule-row .btn-secondary{padding:6px 10px;font-size:12px;border-radius:8px}.signature-box{margin-top:20px;display:flex;flex-direction:column;gap:12px}.header-actions{display:flex;gap:12px;align-items:center}.tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #e1e5e9;padding-bottom:0;overflow-x:auto}.tab{display:flex;align-items:center;gap:8px;padding:12px 20px;background:none;border:none;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}.tab:hover{color:#667eea}.tab.active{color:#667eea;border-bottom-color:#667eea}.tab-content{margin-top:0}.stat-icon.blue{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-icon.green{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.stat-icon.red{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.stat-icon.yellow{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-icon.purple{background:linear-gradient(135deg,#a855f7,#9333ea);color:#fff}.stat-icon.teal{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff}.stat-info{flex:1;display:flex;flex-direction:column}.stat-info .stat-value{font-size:24px;font-weight:700;color:#333;margin:0 0 4px}.stat-info .stat-label{font-size:13px;color:#666;margin:0}.financial-summary{display:flex;flex-direction:column;gap:24px}.summary-section h3{font-size:18px;font-weight:600;margin:0 0 16px;color:#333}.upcoming-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.upcoming-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9}.upcoming-card h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#333;padding-bottom:12px;border-bottom:2px solid #e1e5e9}.upcoming-card.receivable h4{border-bottom-color:#22c55e;color:#22c55e}.upcoming-card.payable h4{border-bottom-color:#ef4444;color:#ef4444}.upcoming-list{list-style:none;padding:0;margin:0}.upcoming-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s ease}.upcoming-list li:hover{background-color:#f8f9fa}.upcoming-list li:last-child{border-bottom:none}.upcoming-list .description{font-size:14px;color:#333;font-weight:500}.upcoming-list .amount{font-size:14px;font-weight:600}.upcoming-list .date{font-size:12px;color:#666;margin-top:4px}.empty-message{text-align:center;padding:20px;color:#999;font-size:14px}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.paid,.status-badge.received{background:#dcfce7;color:#166534}.status-badge.overdue{background:#fee2e2;color:#991b1b}.status-badge.partial{background:#dbeafe;color:#1e40af}.status-badge.canceled{background:#f3f4f6;color:#1f2937}.btn-success{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;line-height:1.2;min-height:32px;cursor:pointer;transition:all .3s ease}.btn-success:hover{transform:translateY(-2px);box-shadow:0 4px 15px #22c55e66}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;line-height:1.2;min-height:32px;cursor:pointer;transition:all .3s ease}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ef444466}.btn-warning{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;line-height:1.2;min-height:32px;cursor:pointer;transition:all .3s ease}.btn-warning:hover{transform:translateY(-2px);box-shadow:0 4px 15px #f59e0b66}.payment-method-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;border:1px solid #e1e5e9;background:#fff}.bank-accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.bank-account-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;transition:all .3s ease}.bank-account-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.account-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.account-info{flex:1}.account-info h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#333}.bank-name{font-size:14px;color:#666;margin:0}.account-type{font-size:12px;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.account-balance{text-align:right}.account-balance .label{font-size:12px;color:#666;margin-bottom:4px}.account-balance .value{font-size:24px;font-weight:700;color:#333}.color-dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:8px}.default-badge{display:inline-flex;align-items:center;padding:4px 10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.default-label{display:inline-flex;align-items:center;padding:4px 10px;background:#f0f0f0;color:#666;border-radius:12px;font-size:11px;font-weight:500}.data-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;overflow-x:auto;overflow-y:hidden;max-width:100%;-webkit-overflow-scrolling:touch;margin-top:20px}.data-table-container.tooltip-container{overflow-x:auto;overflow-y:visible;position:relative}.data-table-container .table-header{padding:20px;border-bottom:1px solid #e1e5e9}.data-table-container .table-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.amount{font-weight:600;font-size:14px}.amount.positive{color:#22c55e}.amount.negative{color:#ef4444}.due-date{font-size:13px;color:#666}.due-date.overdue{color:#ef4444;font-weight:600}.due-date.today{color:#f59e0b;font-weight:600}.due-date.soon{color:#3b82f6;font-weight:500}.table-actions{display:flex;gap:8px;align-items:center}.text-right{text-align:right}.text-left{text-align:left}.reports-container{display:flex;flex-direction:column;gap:24px}.report-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;margin-bottom:24px}.report-section h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#333;padding-bottom:12px;border-bottom:2px solid #e1e5e9}.report-filters{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9;display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.report-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border:1px solid #e1e5e9}.report-card h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#333}.report-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:20px}.report-item{text-align:center;padding:16px;background:#f8f9fa;border-radius:8px}.report-item-label{font-size:12px;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.report-item-value{font-size:20px;font-weight:700;color:#333}.report-item-value.positive{color:#22c55e}.report-item-value.negative{color:#ef4444}.dashboard-link-item{width:100%;border:1px solid transparent;cursor:pointer;text-align:left;font-family:inherit;font-size:inherit;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.dashboard-link-item:hover{transform:translateY(-1px);box-shadow:0 4px 10px #00000014;border-color:#c7d2fe}.dashboard-link-item:focus-visible{outline:2px solid #667eea;outline-offset:2px}.alert-highlight{box-shadow:0 0 0 2px #6366f199}.boleto-barcode-panel{border:1px solid #e2e8f0;border-radius:10px;padding:12px;margin:12px 0;background:#f8fafc}.barcode-header{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.barcode-title{font-weight:600;color:#1f2937}.barcode-digits{font-family:Courier New,Courier,monospace;font-size:12px;color:#475569;word-break:break-all}.barcode-render{display:flex;flex-direction:column;gap:8px}.boleto-barcode-svg{width:100%;max-width:520px;height:auto}.barcode-hint{font-size:12px;color:#64748b;margin:0}.barcode-warning{font-size:12px;color:#b91c1c;margin:0}.public-quote-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#eef2f7);padding:32px 16px;display:flex;justify-content:center;align-items:flex-start}.public-quote-card{width:100%;max-width:980px;background:#fff;border-radius:16px;padding:24px;box-shadow:0 18px 40px #0f172a1a}.public-quote-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.public-quote-header h2{margin:0 0 4px}.public-quote-subtitle{margin:0;color:#64748b}.public-quote-meta{display:flex;flex-direction:column;gap:4px;color:#475569;font-size:13px}.public-quote-content{border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:16px 0}.public-quote-total{display:flex;gap:24px;margin-top:16px;flex-wrap:wrap}.public-quote-total div{display:flex;flex-direction:column;gap:4px}.public-quote-notes{margin-top:16px;background:#f8fafc;padding:12px 16px;border-radius:12px}.public-quote-notes h4{margin-top:0}.public-quote-decision{margin-top:24px}.public-quote-actions{display:flex;gap:12px;flex-wrap:wrap}.public-quote-status{padding:12px 16px;border-radius:10px;font-weight:600}.public-quote-status.approved{background:#22c55e26;color:#16a34a}.public-quote-status.rejected{background:#ef444426;color:#dc2626}.public-quote-error{color:#b91c1c}.public-invite-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#eef2f7);padding:32px 16px;display:flex;justify-content:center;align-items:flex-start}.public-invite-card{width:100%;max-width:980px;background:#fff;border-radius:16px;padding:24px;box-shadow:0 18px 40px #0f172a1a}.public-invite-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.public-invite-subtitle{margin:4px 0 0;color:#64748b}.public-invite-meta{color:#475569;font-size:13px}.public-invite-form{display:flex;flex-direction:column;gap:20px}.public-invite-section{border-top:1px solid #e2e8f0;padding-top:16px}.public-invite-section h4{margin:0 0 12px}.public-invite-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.public-invite-actions{display:flex;justify-content:flex-end;margin-top:8px}.public-invite-error{color:#b91c1c;font-weight:500}@media (max-width: 768px){.module-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions button{flex:1}.stats-grid{grid-template-columns:repeat(2,1fr)}.table-header{flex-direction:column;align-items:flex-start}.search-box{width:100%;min-width:unset}.services-form-row{grid-template-columns:1fr}.module-tabs,.tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-day{min-height:60px;padding:4px}.event-dot{padding:2px 4px;font-size:9px}.modal{max-width:100%;margin:10px}.form-row,.upcoming-grid,.public-invite-grid{grid-template-columns:1fr}.report-filters{flex-direction:column;align-items:stretch}.signature-anchor-layout{grid-template-columns:1fr}.signature-anchor-canvas{min-height:420px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.data-table{font-size:12px}.data-table th,.data-table td{padding:10px 12px}.stat-info .stat-value{font-size:20px}.report-summary{grid-template-columns:1fr}}.booking-count{font-size:12px;color:#2563eb;background:#e0f2fe;border-radius:999px;padding:2px 8px;display:inline-block}.booking-status{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;text-transform:capitalize}.booking-status.pending{background:#fef3c7;color:#b45309}.booking-status.approved{background:#dcfce7;color:#166534}.resource-service-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.resource-service-item{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff}.resource-service-fields{display:flex;align-items:center;gap:12px}.toggle-field{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}button{cursor:pointer;border:none;outline:none}button:disabled{cursor:not-allowed}input{font-family:inherit}a{text-decoration:none;color:inherit}.text-center{text-align:center}.mt-20{margin-top:20px}.mb-20{margin-bottom:20px}.app{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;box-shadow:0 2px 10px #0000001a;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.app-header h1{color:#333;font-size:24px;font-weight:600;margin:0}.user-info{display:flex;align-items:center;gap:16px}.user-info span{color:#666;font-size:14px}.logout-button{background:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.logout-button:hover{background:#c0392b;transform:translateY(-1px)}.app-main{flex:1;padding:24px;background:#f8f9fa}@media (max-width: 768px){.app-header{padding:12px 16px;flex-direction:column;gap:12px;text-align:center}.app-header h1{font-size:20px}.user-info{flex-direction:column;gap:8px}.app-main{padding:16px}}
