.mobile-only{display:none!important}.desktop-only{display:block!important}.tablet-only{display:none!important}.table-scroll-mobile{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.stack-mobile{display:flex;flex-direction:row}.hide-mobile{display:block}.show-mobile{display:none!important}@media(max-width:768px){.mobile-only{display:block!important}.desktop-only,.hide-mobile{display:none!important}.show-mobile{display:block!important}.stack-mobile{flex-direction:column!important}button,.btn,.icon-button,.nav-link,input,select{min-height:44px;min-width:44px}.table-container,.scroll-x-mobile,.table-scroll-mobile{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.modal-content.mobile-full{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important}.page-container{padding:var(--mobile-padding, 16px)!important}.full-width-mobile{width:100%!important}}@media(min-width:769px)and (max-width:1024px){.tablet-only{display:block!important}.desktop-only{display:none!important}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--color-text-primary);background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media(max-width:768px){:root{font-size:16px}.modal-overlay,.modal-backdrop{padding:0!important}.modal,.modal-content{width:100%!important;height:100%!important;max-width:100%!important;max-height:100%!important;border-radius:0!important;margin:0!important;overflow-y:auto!important}}.login-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);padding:20px;overflow:auto}.login-card{background:#fff;border-radius:var(--spacing-md);box-shadow:0 20px 60px #0000004d;padding:48px 40px;width:100%;max-width:440px;margin:auto;animation:slideUp .5s ease-out}.login-header{text-align:center;margin-bottom:36px}.login-logo{width:360px;height:120px;max-width:100%;margin:0 auto 8px;display:block;object-fit:cover;object-position:center;filter:drop-shadow(0 4px 12px rgba(102,126,234,.2));animation:fadeInScale .6s ease-out;transition:transform .3s ease}.login-logo:hover{transform:scale(1.05)}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.login-header h1{font-size:var(--spacing-xl);font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.login-header p{font-size:15px;color:var(--color-text-secondary);margin:0;font-weight:500;animation:fadeIn .8s ease-out .2s both}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-size:15px;font-weight:600;color:var(--color-gray-700);margin-bottom:2px}.form-group input{padding:14px 18px;border:2px solid var(--color-gray-200);border-radius:10px;font-size:var(--spacing-md);transition:all .2s;background:var(--color-gray-50)}.form-group input:focus{outline:none;border-color:var(--color-primary-start);background:#fff;box-shadow:0 0 0 4px #667eea1a}.form-group input:disabled{background-color:var(--color-gray-50);cursor:not-allowed;opacity:.6}.error-message{background-color:#fed7d7;color:var(--color-danger);padding:14px 18px;border-radius:10px;font-size:14px;border:1px solid #fc8181;font-weight:500}.login-button{background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);color:#fff;border:none;padding:var(--spacing-md) 24px;border-radius:10px;font-size:17px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:var(--spacing-sm);letter-spacing:.3px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:28px;padding-top:20px;border-top:1px solid var(--color-gray-200);text-align:center}.credits{font-size:13px;color:var(--color-text-secondary);margin:0;line-height:1.5}.credits strong{color:var(--color-primary-start);font-weight:600}.demo-credentials{font-size:13px;color:var(--color-text-secondary);margin:0}.demo-credentials strong{color:var(--color-gray-700)}.logo-skeleton{width:360px;height:120px;max-width:100%;margin:0 auto 8px;display:block;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:var(--spacing-sm)}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.parent-access-section{margin-top:25px;padding:20px;border:2px solid #e0e7ff;border-radius:12px;background:linear-gradient(135deg,#f8faff,#eff3ff)}.parent-access-section h3{margin:0 0 15px;color:#4f46e5;font-size:18px;font-weight:600}.info-message{padding:12px 15px;background:#dbeafe;border-left:4px solid #3b82f6;border-radius:6px;color:#1e40af;font-size:14px;margin-bottom:15px}.info-message small{display:block;margin-top:5px}.message-alert{padding:10px 15px;background:#10b981;color:#fff;border-radius:6px;margin-bottom:15px;font-size:14px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.no-access{text-align:center;padding:20px}.info-text{color:#64748b;margin-bottom:10px}.helper-text{color:#94a3b8;font-size:13px;margin:8px 0}.warning-text{display:block;color:#dc2626;font-size:13px;margin-top:6px;font-weight:500}.form-group label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}.email-input-readonly{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb;color:#6b7280;font-size:14px;cursor:not-allowed}.email-info-box{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:15px;margin-bottom:20px}.info-label{font-size:14px;color:#666;margin:0 0 8px;font-weight:500}.email-display{font-size:16px;color:#333;font-weight:600;padding:10px;background:#fff;border-radius:6px;border:1px solid #ddd;margin-bottom:8px}.info-hint{display:block;font-size:13px;color:#667eea;margin-top:5px}.warning-box{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:15px;text-align:center}.warning-icon{font-size:32px;margin:0 0 10px}.warning-text{font-size:16px;color:#856404;margin:0 0 5px}.warning-hint{font-size:14px;color:#666;margin:10px 0 0}.password-info-disabled{padding:12px 15px;background:#f3f4f6;border:1px dashed #d1d5db;border-radius:6px;color:#6b7280;font-size:13px;font-style:italic}.password-info-disabled p{margin:0}.create-access-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:15px}.create-access-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #667eea4d}.create-access-button:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#9ca3af,#6b7280)}.access-active{padding:10px 0}.access-info{background:#fff;padding:15px;border-radius:8px;margin-bottom:15px;border:1px solid #e5e7eb}.access-info p{margin:8px 0;color:#374151;font-size:14px}.access-info strong{color:#1f2937;font-weight:600}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fef3c7;color:#92400e}.status-badge.blocked{background:#fee2e2;color:#991b1b}.status-badge.ok{background:#d1fae5;color:#065f46}.blocked-reason{color:#dc2626;font-weight:500;font-style:italic}.password-display{background:#fff7ed;padding:20px;border-radius:8px;border:2px solid #fb923c;margin-bottom:15px}.security-alert{display:flex;gap:15px;background:#fef2f2;border:2px solid #ef4444;border-radius:8px;padding:15px;margin-bottom:20px;animation:pulse-border 2s infinite}@keyframes pulse-border{0%,to{border-color:#ef4444}50%{border-color:#dc2626}}.alert-icon{font-size:32px;line-height:1}.alert-content{flex:1}.alert-content strong{display:block;color:#991b1b;font-size:15px;margin-bottom:8px}.alert-content p{color:#7f1d1d;font-size:14px;margin:0;line-height:1.5}.password-instructions{margin-top:15px;padding:15px;background:#fffbeb;border-radius:8px;border-left:4px solid #f59e0b}.password-instructions p{margin:0 0 10px;color:#78350f;font-size:14px}.password-instructions ul{margin:10px 0;padding-left:20px;list-style:none}.password-instructions li{margin:8px 0;color:#92400e;font-size:14px;line-height:1.6}.credentials-example{margin-top:15px!important;padding:12px;background:#fff;border-radius:6px;border:1px solid #fed7aa}.credentials-example code{background:#fef3c7;padding:3px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:13px;font-weight:600;color:#92400e}.password-display label{display:block;font-weight:600;color:#c2410c;margin-bottom:8px;font-size:14px}.password-field{display:flex;gap:8px;align-items:center}.password-field input{flex:1;padding:10px 12px;border:1px solid #fed7aa;border-radius:6px;font-family:Courier New,monospace;font-size:15px;font-weight:600;background:#fff}.icon-btn{padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s}.icon-btn:hover{background:#f3f4f6;border-color:#d1d5db;transform:scale(1.05)}.access-actions{display:flex;gap:10px;margin:15px 0;flex-wrap:wrap}.toggle-button,.regenerate-button,.delete-button{flex:1;min-width:150px;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.toggle-button{background:#10b981;color:#fff}.toggle-button:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.regenerate-button{background:#3b82f6;color:#fff}.regenerate-button:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.delete-button{background:#ef4444;color:#fff}.delete-button:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.toggle-button:disabled,.regenerate-button:disabled,.delete-button:disabled,.block-button:disabled,.unblock-button:disabled{opacity:.5;cursor:not-allowed}.block-button,.unblock-button{flex:1;min-width:150px;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.block-button{background:#f59e0b;color:#fff}.block-button:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.unblock-button{background:#10b981;color:#fff}.unblock-button:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.patients-page{min-height:100vh;background-color:var(--color-gray-50)}.page-header{background:#fff;padding:var(--spacing-lg) 32px;border-bottom:1px solid var(--color-gray-200);display:flex;justify-content:space-between;align-items:center}.page-header h1{margin:0 0 4px;font-size:var(--spacing-lg);color:var(--color-text-primary)}.page-header p{margin:0;color:var(--color-text-secondary);font-size:14px}.logout-button{background:var(--color-danger);color:#fff;border:none;padding:10px 20px;border-radius:var(--spacing-sm);cursor:pointer;font-weight:600;transition:background .2s}.logout-button:hover{background:var(--color-danger)}.page-content{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.actions-bar{margin-bottom:var(--spacing-lg)}.primary-button{background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);color:#fff;border:none;padding:12px 24px;border-radius:var(--spacing-sm);font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.primary-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.secondary-button{background:#fff;color:var(--color-gray-600);border:2px solid var(--color-gray-200);padding:12px 24px;border-radius:var(--spacing-sm);font-weight:600;cursor:pointer;transition:all .2s}.secondary-button:hover{border-color:var(--color-gray-300);background:var(--color-gray-50)}.patients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg)}.patient-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.patient-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.patient-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-gray-200)}.patient-header h3{margin:0;font-size:20px;color:var(--color-text-primary)}.patient-actions{display:flex;gap:var(--spacing-sm)}.icon-button{background:none;border:none;font-size:18px;cursor:pointer;padding:var(--spacing-xs) 8px;border-radius:var(--spacing-xs);transition:background .2s}.icon-button:hover{background:var(--color-gray-50)}.patient-info p{margin:var(--spacing-sm) 0;font-size:14px;color:var(--color-gray-600)}.patient-info strong{color:var(--color-gray-700)}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:var(--radius-lg)}.empty-state p{color:var(--color-text-secondary);font-size:var(--spacing-md);margin-bottom:20px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:var(--spacing-md);padding:var(--spacing-xl);width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 24px;font-size:var(--spacing-lg);color:var(--color-text-primary)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--color-gray-700);font-size:14px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--color-gray-200);border-radius:var(--spacing-sm);font-size:var(--spacing-md);font-family:inherit;transition:border-color .2s}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:var(--spacing-lg)}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:var(--color-text-secondary)}@media(max-width:768px){.page-header{padding:var(--spacing-md);flex-direction:column;align-items:flex-start;gap:12px}.page-content{padding:var(--spacing-md)}.patients-grid,.form-row{grid-template-columns:1fr}.modal-content{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important;padding:var(--spacing-lg) 16px}}@media(max-width:480px){.page-header h1{font-size:20px}.patient-card{padding:var(--spacing-md)}}.slot-selector{width:100%}.slot-select{width:100%;padding:12px;font-size:14px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;color:#1f2937;cursor:pointer;transition:all .2s}.slot-select:hover:not(:disabled){border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.slot-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.slot-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.slot-select option{padding:8px}.delete-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;padding:20px}.delete-modal-content{background:#fff;border-radius:12px;padding:0;max-width:500px;width:100%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.delete-modal-header{padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.delete-modal-header h2{margin:0;font-size:20px;font-weight:600;color:#dc2626}.delete-modal-body{padding:24px}.delete-warning{font-size:16px;font-weight:500;color:#1f2937;margin:0 0 20px}.appointment-details{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:16px}.detail-row{display:flex;justify-content:space-between;padding:6px 0}.detail-row:not(:last-child){border-bottom:1px solid #e5e7eb}.detail-label{font-weight:500;color:#6b7280;font-size:14px}.detail-value{font-weight:600;color:#1f2937;font-size:14px}.series-warning{background-color:#fef3c7;border:1px solid #fbbf24;border-radius:6px;padding:12px;margin-bottom:16px}.series-warning p{margin:0;font-size:14px;color:#92400e}.series-warning p:not(:last-child){margin-bottom:8px}.delete-note{font-size:13px;color:#6b7280;font-style:italic;margin:0}.delete-modal-actions{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb;border-radius:0 0 12px 12px}.btn-cancel,.btn-delete,.btn-delete-series{padding:10px 20px;border-radius:6px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;border:none}.btn-cancel:hover:not(:disabled){background-color:#e5e7eb}.btn-delete{background-color:#dc2626;color:#fff}.btn-delete:hover:not(:disabled){background-color:#b91c1c}.btn-delete-series{background-color:#ea580c;color:#fff}.btn-delete-series:hover:not(:disabled){background-color:#c2410c}.btn-cancel:disabled,.btn-delete:disabled,.btn-delete-series:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.delete-modal-actions{flex-direction:column-reverse}.btn-cancel,.btn-delete,.btn-delete-series{width:100%}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:32px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h2{margin:0 0 24px;font-size:24px;font-weight:600;color:#1f2937}.error-message{padding:12px;background-color:#fee2e2;border:1px solid #fca5a5;border-radius:6px;color:#991b1b;margin-bottom:20px;font-size:14px}.warning-message{padding:12px;background-color:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;margin-bottom:20px;font-size:14px;line-height:1.5}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:14px;color:#374151}.form-group input[type=text],.form-group input[type=date],.form-group input[type=time],.form-group select,.form-group textarea{width:100%;padding:12px;font-size:14px;border:1px solid #d1d5db;border-radius:6px;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.form-group textarea{resize:vertical;font-family:inherit}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-size:14px;color:#374151}.modal-actions{display:flex;gap:12px;justify-content:space-between;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.actions-right{display:flex;gap:12px}.btn-cancel,.btn-submit,.btn-delete-left{padding:10px 20px;border-radius:6px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background-color:#f3f4f6;color:#374151}.btn-cancel:hover{background-color:#e5e7eb}.btn-submit{background-color:#6366f1;color:#fff}.btn-submit:hover:not(:disabled){background-color:#4f46e5}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-delete-left{background-color:#dc2626;color:#fff}.btn-delete-left:hover:not(:disabled){background-color:#b91c1c}.btn-delete-left:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.modal-content{padding:24px}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}.appointments-page-v2{padding:20px;background:#f8f9fa;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h1{font-size:28px;font-weight:600;color:#1f2937;margin:0}.header-actions{display:flex;gap:12px}.btn-new-appointment{padding:10px 20px;background:#6366f1;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.btn-new-appointment:hover{background:#4f46e5}.professional-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid #e5e7eb;overflow-x:auto;padding-bottom:2px}.professional-tabs .tab{padding:12px 20px;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-weight:500;color:#6b7280;transition:all .2s;white-space:nowrap;font-size:14px}.professional-tabs .tab:hover{color:#1f2937;background:#f9fafb;border-radius:8px 8px 0 0}.professional-tabs .tab.active{color:#6366f1;border-bottom-color:#6366f1;background:#f0f9ff;border-radius:8px 8px 0 0}.week-navigator{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.week-range{font-size:18px;font-weight:600;color:#1f2937}.nav-button{padding:8px 16px;background:#f3f4f6;border:none;border-radius:6px;cursor:pointer;font-weight:500;color:#374151;transition:background .2s}.nav-button:hover{background:#e5e7eb}.status-legend{display:flex;align-items:center;gap:24px;margin-bottom:20px;padding:12px 16px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;flex-wrap:wrap}.legend-title{font-size:14px;font-weight:600;color:#374151}.legend-items{display:flex;gap:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.legend-item .badge{margin:0}.table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.loading{padding:40px;text-align:center;color:#6b7280;font-size:16px}.appointments-table{width:100%;border-collapse:collapse;min-width:800px}.appointments-table thead{background:#f8f9fa;position:sticky;top:0;z-index:10}.appointments-table th{padding:16px 12px;text-align:center;font-weight:600;font-size:13px;color:#374151;border-bottom:2px solid #e5e7eb;text-transform:uppercase;letter-spacing:.5px}.time-column{width:150px;text-align:left!important;padding-left:20px!important}.day-column{min-width:180px}.time-label{padding:16px 20px;font-weight:600;font-size:14px;background:#f8f9fa;border-right:2px solid #e5e7eb;color:#1f2937;white-space:nowrap}.time-slot-cell{border:1px solid #e5e7eb;padding:8px;min-height:80px;vertical-align:top;position:relative;background:#fff;transition:background-color .2s}.time-slot-cell.empty{cursor:pointer}.time-slot-cell.empty:hover{background-color:#f0f9ff;border-color:#93c5fd}.time-slot-cell.empty:hover .empty-indicator{opacity:1;transform:translate(-50%,-50%) scale(1.1)}.empty-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px;color:#9ca3af;opacity:0;transition:all .2s;pointer-events:none}.appointment-card.status-not-sent{background-color:#fee2e2!important;border-left-color:#dc2626!important}.appointment-card.status-pending{background-color:#fef3c7!important;border-left-color:#f59e0b!important}.appointment-card.status-confirmed{background-color:#d1fae5!important;border-left-color:#10b981!important}.appointment-card.status-cancelled{background-color:#f3f4f6!important;border-left-color:#6b7280!important}.appointment-card{background:#fff;border-radius:6px;padding:0;margin:4px 0;transition:all .2s;box-shadow:0 1px 3px #0000001a;border-left:4px solid;display:flex;flex-direction:column;overflow:hidden}.appointment-card:hover{box-shadow:0 4px 6px #00000026;transform:translateY(-1px)}.card-content{padding:8px 10px;flex:1;cursor:pointer}.card-actions{display:flex;gap:4px;padding:4px;background-color:#00000005;border-top:1px solid rgba(0,0,0,.05)}.btn-whatsapp{flex:1;padding:6px;background-color:#6366f1;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:16px;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-whatsapp:hover:not(:disabled){background-color:#4f46e5;transform:scale(1.05)}.btn-whatsapp:disabled{opacity:.5;cursor:not-allowed}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}.status-badges{display:flex;gap:4px;flex-shrink:0}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:11px;font-weight:600;line-height:1}.badge-not-sent{background-color:#ef4444;color:#fff}.badge-confirmed{background-color:#10b981;color:#fff}.badge-pending{background-color:#f59e0b;color:#fff}.badge-cancelled{background-color:#6b7280;color:#fff}.badge-present{background-color:#3b82f6;color:#fff}.badge-absent{background-color:#dc2626;color:#fff}.badge-justified_absence{background-color:#8b5cf6;color:#fff}.patient-name{font-weight:600;font-size:13px;color:#1f2937;margin-bottom:0;flex:1}.service-name{font-size:11px;color:#6b7280;margin-bottom:2px}.professional-name{font-size:10px;color:#9ca3af;font-style:italic}.service-psychology{border-left-color:#3b82f6}.service-therapy{border-left-color:#10b981}.service-general{border-left-color:#8b5cf6}.service-other{border-left-color:#6b7280}@media(max-width:1024px){.appointments-page-v2{padding:12px}.page-header h1{font-size:24px}.professional-tabs{gap:4px}.professional-tabs .tab{padding:10px 16px;font-size:13px}.day-column{min-width:140px}.time-label{font-size:13px}}@media(max-width:768px){.week-navigator{flex-direction:column;gap:12px}.week-range{font-size:16px}.appointments-table th,.appointments-table td{padding:8px}.time-slot-cell{min-height:60px}.appointment-card{padding:8px}.appointment-card .patient-name{font-size:13px}.appointment-card .service-name{font-size:11px}}.reports-page{padding:20px}.filters{margin-bottom:20px}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.report-card{background:#fff;padding:20px;border-radius:var(--spacing-sm);box-shadow:0 1px 3px #0000001a;border-left:var(--spacing-xs) solid #3498db}.report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.report-header h3{margin:0;font-size:18px;color:#2c3e50}.report-date{font-size:14px;color:#7f8c8d}.report-patient{font-size:14px;font-weight:600;color:#34495e;margin-bottom:var(--spacing-xs)}.report-author{font-size:13px;color:#95a5a6;margin-bottom:12px}.report-content{font-size:14px;color:#555;line-height:1.5}.modal{background:#fff;padding:var(--spacing-lg);border-radius:var(--spacing-sm);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm);border:1px solid #ddd;border-radius:var(--spacing-xs);font-family:inherit}.form-group textarea{resize:vertical}.report-badges{margin-bottom:var(--spacing-sm)}.status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-lg);font-size:11px;font-weight:600;text-transform:uppercase}.status-badge.draft{background:#f1f3f5;color:#495057}.status-badge.confirmed{background:#e8f5e9;color:#2e7d32}.report-service{font-size:13px;color:var(--color-primary-start);margin-bottom:var(--spacing-sm);font-weight:500}.btn-edit,.btn-confirm,.btn-whatsapp,.btn-reopen{border:none;padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn-edit{background:#fff3e0;color:#f57c00}.btn-edit:hover{background:#ffe0b2}.btn-confirm{background:#e8f5e9;color:#2e7d32}.btn-confirm:hover{background:#c8e6c9}.btn-whatsapp{background:#e0f7fa;color:#00838f}.btn-whatsapp:hover{background:#b2ebf2}.btn-reopen{background:#fff9c4;color:#f9a825}.btn-reopen:hover{background:#fff59d}.modal-view{max-width:800px}.modal-header-with-print{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid #f1f3f5}.modal-header-with-print h2{margin:0;color:#2c3e50;font-size:var(--spacing-lg)}.modal-header-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center}.btn-print{background:#e3f2fd;border:none;padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:#1976d2;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn-print:hover{background:#bbdefb}.btn-close{background:#e9ecef;border:none;width:32px;height:32px;border-radius:50%;font-size:16px;font-weight:600;color:#495057;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-close:hover{background:#dee2e6;color:#2c3e50}.report-view-content{padding:0 8px}.clinic-header{display:flex;align-items:center;gap:20px;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid #f1f3f5}.clinic-logo svg{display:block}.clinic-info h1{margin:0 0 8px;font-size:var(--spacing-lg);color:#2c3e50;font-weight:700}.clinic-info p{margin:0 0 4px;color:#7f8c8d;font-size:14px}.report-meta{background:var(--color-gray-50);padding:var(--spacing-md);border-radius:var(--spacing-sm);margin-bottom:var(--spacing-lg);display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.report-meta p{margin:0;color:#495057;font-size:14px}.report-meta strong{color:#2c3e50;margin-right:var(--spacing-xs)}.report-full-content{font-size:var(--spacing-md);line-height:1.8;color:#2c3e50;white-space:pre-wrap}.report-full-content p{margin-bottom:var(--spacing-md)}@media(max-width:768px){.reports-page{padding:var(--spacing-md)}.header{flex-direction:column;align-items:stretch;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.filters,.filter-select{width:100%}.reports-grid{grid-template-columns:1fr}.report-card{padding:var(--spacing-md)}.modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important;padding:var(--spacing-lg) 16px!important}.modal-header-with-print{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.modal-header-actions{width:100%;justify-content:space-between}.report-meta{grid-template-columns:1fr}.clinic-header{flex-direction:column;text-align:center;gap:12px}}@media print{body *{visibility:hidden}.modal-overlay,.modal-view,.modal-view *{visibility:visible}.modal-overlay{position:absolute;left:0;top:0;background:#fff;padding:0}.modal-view{box-shadow:none;width:100%;max-width:100%;padding:0;margin:0}.modal-header-actions{display:none}.report-meta{border:1px solid #ddd;background:#fff}}.workflow-badge{display:inline-block;padding:var(--spacing-xs) 10px;border-radius:var(--radius-lg);font-size:11px;font-weight:600;text-transform:uppercase;margin-left:6px}.workflow-badge.draft{background:#f1f3f5;color:#495057}.workflow-badge.pending{background:#fff3cd;color:#856404}.workflow-badge.in-review{background:#cfe2ff;color:#084298}.workflow-badge.changes-requested{background:#f8d7da;color:#842029}.workflow-badge.approved{background:#d1e7dd;color:#0f5132}.priority-badge{display:inline-block;padding:var(--spacing-xs) 10px;border-radius:var(--radius-lg);font-size:11px;font-weight:700;margin-left:6px}.priority-badge.urgent{background:#ffe5e5;color:#c92a2a;border:1px solid #ffc9c9}.priority-badge.high{background:#fff4e6;color:#e67700;border:1px solid #ffe8cc}.priority-badge.normal{background:#e7f5ff;color:#1971c2;border:1px solid #d0ebff}.priority-badge.low{background:#f3f0ff;color:#5f3dc4;border:1px solid #e5dbff}.btn-submit,.btn-start-review,.btn-approve,.btn-request-changes{border:none;padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn-submit{background:#e3f2fd;color:#1976d2}.btn-submit:hover{background:#bbdefb}.btn-start-review{background:#fff3e0;color:#f57c00}.btn-start-review:hover{background:#ffe0b2}.btn-approve{background:#e8f5e9;color:#2e7d32}.btn-approve:hover{background:#c8e6c9}.btn-request-changes{background:#fff9c4;color:#f9a825}.btn-request-changes:hover{background:#fff59d}.info-message{display:inline-block;padding:var(--spacing-sm) 12px;background:#e7f5ff;color:#1971c2;border-radius:var(--radius-sm);font-size:13px;font-weight:500}.modal h2{margin-top:0;margin-bottom:var(--spacing-md);color:#2c3e50}.modal p{margin-bottom:12px;color:#495057}.modal .form-group label{color:#2c3e50}.modal button:disabled{opacity:.5;cursor:not-allowed}.finance-page{padding:20px}.filters{margin-bottom:20px;display:flex;gap:12px}.filter-select{padding:var(--spacing-sm) 12px;border:1px solid #ddd;border-radius:var(--spacing-xs);font-size:14px}.invoices-list table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--spacing-sm);overflow:hidden;box-shadow:0 1px 3px #0000001a}.invoices-list th,.invoices-list td{padding:12px 16px;text-align:left;border-bottom:1px solid #eee}.invoices-list th{background-color:var(--color-gray-50);font-weight:600}.status-badge{padding:var(--spacing-xs) 12px;border-radius:var(--radius-lg);font-size:.85em;font-weight:500;color:#fff}.btn-small{padding:6px 12px;background-color:#3498db;color:#fff;border:none;border-radius:var(--spacing-xs);cursor:pointer;font-size:14px}.btn-small:hover{background-color:#2980b9}.modal{background:#fff;padding:var(--spacing-lg);border-radius:var(--spacing-sm);width:100%;max-width:500px;box-shadow:0 4px 6px #0000001a}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:500}.form-group input,.form-group select{width:100%;padding:var(--spacing-sm);border:1px solid #ddd;border-radius:var(--spacing-xs)}.btn-primary{background-color:#007bff;color:#fff;border:none;padding:var(--spacing-sm) 16px;border-radius:var(--spacing-xs);cursor:pointer}.btn-primary:hover{background-color:#0056b3}.expenses-list table,.payments-list table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--spacing-sm);overflow:hidden;box-shadow:0 1px 3px #0000001a}.expenses-list th,.expenses-list td,.payments-list th,.payments-list td{padding:12px 16px;text-align:left;border-bottom:1px solid #eee}.expenses-list th,.payments-list th{background-color:var(--color-gray-50);font-weight:600}.btn-delete-icon{background:none;border:none;cursor:pointer;font-size:1.2em;padding:var(--spacing-xs);border-radius:var(--spacing-xs);transition:background-color .2s;position:relative;display:inline-flex;align-items:center;justify-content:center}.btn-delete-icon:hover{background-color:#ffebee}.actions-cell{display:flex;gap:var(--spacing-sm);align-items:stretch;flex-wrap:wrap;justify-content:flex-start}.btn-edit{background:none;border:none;cursor:pointer;font-size:1.2em;padding:var(--spacing-xs);border-radius:var(--spacing-xs);transition:background-color .2s;position:relative;display:inline-flex;align-items:center;justify-content:center}.btn-edit:hover{background-color:#e3f2fd}.btn-action{padding:var(--spacing-sm) 12px;border:1px solid #ddd;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;background:#fff;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;min-height:36px;justify-content:center}.btn-action:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-action:active{transform:translateY(0)}.btn-edit-text{color:var(--color-info);border-color:var(--color-info)}.btn-edit-text:hover{background-color:var(--color-info);color:#fff}.btn-delete-text{color:#f44336;border-color:#f44336}.btn-delete-text:hover{background-color:#f44336;color:#fff}.btn-small{padding:var(--spacing-sm) 12px;background-color:#3498db;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;min-height:36px;transition:all .2s ease;white-space:nowrap}.btn-small:hover{background-color:#2980b9;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-small:active{transform:translateY(0)}.btn-icon-only{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center}.invoices-list tr.row-paid{background-color:#f0fdf4;box-shadow:inset 3px 0 #22c55e}.invoices-list tr.row-overdue{background-color:#fef2f2;box-shadow:inset 3px 0 #ef4444}.invoices-list tr.row-partial{background-color:#fffbeb;box-shadow:inset 3px 0 #f59e0b}.status-dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex-shrink:0}.status-legend{display:flex;gap:var(--spacing-md);align-items:center;margin-left:auto;padding:var(--spacing-sm) 12px;background:var(--color-gray-50);border-radius:var(--radius-sm)}.legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#666}@media(max-width:768px){.finance-page{padding:var(--spacing-md)}.header{flex-direction:column;align-items:stretch;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.tabs{overflow-x:auto;padding-bottom:5px;white-space:nowrap;display:flex;-webkit-overflow-scrolling:touch}.modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important}}.photos-page{padding:20px}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-top:20px}.photo-card{background:#fff;border-radius:var(--spacing-sm);overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:transform .2s}.photo-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.photo-wrapper{height:200px;overflow:hidden;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center}.photo-wrapper img{width:100%;height:100%;object-fit:cover}.photo-wrapper .filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.filter-select,.filter-date{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;min-width:200px}.btn-clear-filters{padding:.5rem 1rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-clear-filters:hover{background-color:#5a6268}.photo-info{padding:12px;position:relative}.photo-date{font-size:.85em;color:#888;margin-bottom:var(--spacing-xs)}.photo-desc{font-size:.95em;color:#333;margin:0;line-height:1.4}.btn-delete-icon{position:absolute;top:10px;right:10px;background:none;border:none;cursor:pointer;opacity:.6;transition:opacity .2s}.btn-delete-icon:hover{opacity:1}@media(max-width:768px){.photos-page{padding:var(--spacing-md)}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.photo-wrapper{height:160px}}.document-upload{margin-bottom:1.5rem}.document-label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.upload-zone{border:2px dashed #cbd5e0;border-radius:8px;padding:2rem;text-align:center;transition:all .3s ease;background-color:#f7fafc}.upload-zone:hover{border-color:#4299e1;background-color:#ebf8ff}.upload-zone.drag-active{border-color:#3182ce;background-color:#bee3f8}.file-input{display:none}.upload-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{font-size:2.5rem}.upload-text{font-size:1rem;color:#2d3748;font-weight:500}.upload-hint{font-size:.875rem;color:#718096}.uploading{display:flex;flex-direction:column;align-items:center;gap:.75rem}.spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#4299e1;border-radius:50%;animation:spin .8s linear infinite}.document-preview{display:flex;align-items:center;justify-content:space-between;padding:1rem;background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px}.document-info{display:flex;align-items:center;gap:.75rem}.document-icon{font-size:1.5rem}.document-link{color:#4299e1;text-decoration:none;font-weight:500;transition:color .2s}.document-link:hover{color:#2b6cb0;text-decoration:underline}.btn-delete-doc{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;transition:transform .2s}.btn-delete-doc:hover{transform:scale(1.1)}.professionals-page{padding:var(--spacing-lg);background:var(--color-gray-50);min-height:100vh}.professionals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.professional-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);display:flex;gap:var(--spacing-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.professional-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.professional-card.inactive{opacity:.6;background:var(--color-gray-100)}.professional-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0}.professional-info{flex:1;min-width:0;padding-right:var(--spacing-sm)}.professional-info h3{margin:0 0 var(--spacing-xs) 0;font-size:18px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.professional-email{margin:0 0 var(--spacing-xs) 0;font-size:14px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.professional-phone{margin:0;font-size:13px;color:var(--color-text-muted)}.inactive-badge{display:inline-block;margin-top:var(--spacing-xs);padding:4px 8px;background:var(--color-danger);color:#fff;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.professional-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);flex-shrink:0}.btn-edit,.btn-delete{padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none}.btn-edit{background:var(--color-info);color:#fff}.btn-edit:hover{background:#1976d2}.btn-delete{background:var(--color-gray-200);color:var(--color-text-primary)}.btn-delete:hover{background:var(--color-danger);color:#fff}.modal{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative}.modal{scroll-behavior:smooth}.modal::-webkit-scrollbar{width:8px}.modal::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:4px}.modal::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}.modal::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);gap:var(--spacing-md)}.modal-header h2{margin:0;color:var(--color-text-primary);font-size:24px;flex:1}.btn-close{background:transparent;border:none;font-size:28px;color:var(--color-text-muted);cursor:pointer;padding:4px 8px;line-height:1;transition:all var(--transition-fast);border-radius:var(--radius-md);flex-shrink:0}.btn-close:hover{background:var(--color-gray-100);color:var(--color-text-primary);transform:rotate(90deg)}.form-group input{width:100%;padding:12px;border:2px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:15px;transition:border-color var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--color-primary)}.form-group input:disabled{background:var(--color-gray-100);cursor:not-allowed}.documents-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:2px solid var(--color-gray-200)}.section-title{margin:0 0 var(--spacing-lg) 0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.form-group textarea{width:100%;padding:12px;border:2px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:15px;font-family:inherit;transition:border-color var(--transition-fast);resize:vertical}.form-group textarea:focus{outline:none;border-color:var(--color-primary)}@media(max-width:768px){.professionals-page{padding:16px}.page-header{flex-direction:column;align-items:stretch;margin-top:32px}.professionals-grid{grid-template-columns:1fr}.professional-card{flex-direction:column;align-items:center;text-align:center}.professional-actions{flex-direction:row;width:100%;justify-content:center}.modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important}.form-row{grid-template-columns:1fr}}.services-page{padding:var(--spacing-lg);background:var(--color-gray-50);min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.page-header h1{margin:0 0 var(--spacing-xs) 0;font-size:32px;font-weight:700;color:var(--color-text-primary)}.btn-create{background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-lg);font-size:15px;font-weight:600;cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal);white-space:nowrap}.btn-create:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl)}.service-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:space-between;transition:transform var(--transition-normal),box-shadow var(--transition-normal);position:relative;overflow:hidden;border-top-width:4px;border-top-style:solid;height:100%}.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.service-card.inactive{opacity:.75;background:var(--color-gray-50)}.service-header{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-sm);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.service-title{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary);line-height:1.3}.service-body{padding:0 var(--spacing-lg) var(--spacing-lg);flex:1;display:flex;flex-direction:column}.service-description{margin:var(--spacing-sm) 0 var(--spacing-lg);font-size:14px;color:var(--color-text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.service-details{display:flex;gap:var(--spacing-lg);margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--color-gray-100)}.detail-item{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--color-text-secondary);font-weight:500}.detail-item .icon{font-size:16px}.detail-item.price{color:var(--color-success);font-weight:700}.service-footer{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-gray-50);display:flex;gap:var(--spacing-md);border-top:1px solid var(--color-gray-200)}.inactive-badge{padding:4px 8px;background:var(--color-danger);color:#fff;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.btn-action{flex:1;padding:8px 12px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;display:flex;align-items:center;justify-content:center}.btn-action.edit{background:#fff;border-color:var(--color-gray-300);color:var(--color-text-primary)}.btn-action.edit:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.btn-action.delete{background:transparent;color:var(--color-text-muted)}.btn-action.delete:hover{color:var(--color-danger);background:#f443361a}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 var(--spacing-lg) 0;color:var(--color-text-primary);font-size:24px}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--color-text-primary);font-size:14px}.form-group input,.form-group textarea{width:100%;padding:12px;border:2px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:15px;transition:border-color var(--transition-fast);font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.color-picker{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.color-option{width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all var(--transition-fast);border:3px solid transparent}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--color-text-primary);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--color-text-primary)}.modal-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.modal-actions button{flex:1;padding:12px;border-radius:var(--radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.modal-actions button[type=button]{background:var(--color-gray-200);border:none;color:var(--color-text-primary)}.modal-actions button[type=button]:hover{background:var(--color-gray-300)}.btn-primary{background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);color:#fff;border:none}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.loading,.empty-state{text-align:center;color:var(--color-text-muted);padding:var(--spacing-2xl);font-size:14px}@media(max-width:768px){.services-page{padding:16px}.page-header{flex-direction:column;align-items:stretch;margin-top:32px}.services-grid{grid-template-columns:1fr}.modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important}.form-row{grid-template-columns:1fr}}.language-selector{position:relative}.language-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;transition:all .2s ease;width:100%;justify-content:center}.language-btn:hover{background:#fff3}.current-lang{font-size:18px}.language-dropdown{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;opacity:0;visibility:hidden;transform:translateY(10px);transition:all .2s ease;z-index:2000}.language-selector:hover .language-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.language-option{width:100%;padding:12px 16px;border:none;background:transparent;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background .2s ease;color:#2c3e50;font-size:14px}.language-option:first-child{border-radius:8px 8px 0 0}.language-option:last-child{border-radius:0 0 8px 8px}.language-option:hover{background:#f8f9fa}.language-option.active{background:#e3f2fd;color:#1976d2;font-weight:600}.flag{font-size:20px}.lang-name{flex:1;text-align:left}.demo-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;text-align:center;box-shadow:0 2px 10px #667eea4d;position:sticky;top:0;z-index:1000;animation:slideDown .3s ease}.demo-banner-content{display:flex;align-items:center;justify-content:center;gap:15px;max-width:1200px;margin:0 auto}.demo-icon{font-size:24px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.demo-text{display:flex;flex-direction:column;gap:4px;text-align:left}.demo-text strong{font-size:16px;font-weight:700;letter-spacing:1px}.demo-subtitle{font-size:13px;opacity:.9;font-weight:400}@media(max-width:768px){.demo-banner{padding:10px 15px}.demo-text{gap:2px}.demo-text strong{font-size:14px}.demo-subtitle{font-size:11px}.demo-icon{font-size:20px}}.version-display{padding:12px 16px;border-top:1px solid rgba(255,255,255,.1);background:#0000001a;text-align:center;font-family:Courier New,monospace;font-size:11px;color:#ffffffb3;margin-top:auto}.version-display__version{font-weight:600;color:#ffffffe6;margin-bottom:2px;letter-spacing:.5px}.version-display__date{font-size:10px;opacity:.8}.version-display:hover{background:#00000026;cursor:help}@media(prefers-color-scheme:dark){.version-display{border-top-color:#ffffff0d;background:#ffffff08}}@media(max-width:768px){.version-display{font-size:10px;padding:10px 12px}.version-display__date{font-size:9px}}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;transition:width .3s ease;position:fixed;height:100vh;z-index:1000;will-change:transform}.sidebar.collapsed{width:80px}.sidebar-header{padding:12px 8px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;min-height:180px;gap:8px}.sidebar-logo{display:flex;align-items:center;justify-content:center;height:160px;flex:1;overflow:hidden;padding:0 4px}.sidebar-logo-img{max-height:160px;max-width:248px;width:auto;object-fit:contain;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar-logo:hover .sidebar-logo-img{transform:scale(1.02);filter:brightness(1.1)}.sidebar.collapsed .sidebar-logo-img{width:72px;height:72px;border-radius:8px}.toggle-btn{background:#ffffff1a;border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease;flex-shrink:0}.toggle-btn:hover{background:#fff3}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:16px;padding:14px 20px;color:#fffc;text-decoration:none;transition:all .2s ease;font-size:15px;font-weight:500;white-space:nowrap}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#ffffff26;color:#fff;border-left:4px solid white;padding-left:16px}.nav-icon{width:20px;height:20px;flex-shrink:0}.sidebar.collapsed .nav-link{justify-content:center;padding:14px}.sidebar.collapsed .nav-link.active{border-left:none;border-bottom:3px solid white;padding:14px}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:12px}.btn-logout{width:100%;padding:12px 20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;cursor:pointer;font-size:15px;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:12px}.btn-logout:hover{background:#fff3}.sidebar.collapsed .btn-logout{padding:12px}.main-content{flex:1;margin-left:260px;background:#f8f9fa;transition:margin-left .3s ease}.main-content.expanded{margin-left:80px}.mobile-menu-toggle{position:fixed;top:20px;left:20px;z-index:1001;background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);color:#fff;border:none;width:48px;height:48px;border-radius:12px;display:none;align-items:center;justify-content:center;box-shadow:var(--shadow-md);cursor:pointer;font-size:20px}.mobile-overlay{position:fixed;inset:0;background:#00000080;z-index:999;display:block;animation:fadeIn .3s ease;will-change:opacity}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.mobile-menu-toggle{display:flex}.sidebar{width:280px;transform:translate(-100%);transition:transform .3s ease;z-index:1000}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%);width:280px}.main-content{margin-left:0;padding-top:60px}.main-content.expanded{margin-left:0}.toggle-btn{display:none}.nav-link{min-height:44px}.mobile-menu-toggle{min-width:48px;min-height:48px}}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#ffffff0d}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.parent-layout{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.parent-header{background:#fffffff2;box-shadow:0 2px 10px #0000001a;padding:1rem 0}.parent-header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.parent-logo h1{font-size:1.5rem;color:#667eea;margin:0}.parent-nav{display:flex;gap:1rem;flex:1;justify-content:center}.parent-nav-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;color:#4a5568;font-weight:500;transition:all .3s ease}.parent-nav-link:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.parent-nav-link.active{background:#667eea;color:#fff}.parent-user-menu{display:flex;align-items:center;gap:1rem}.parent-user-name{color:#2d3748;font-weight:500}.parent-logout-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#f56565;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.parent-logout-btn:hover{background:#e53e3e;transform:translateY(-2px)}.parent-main{max-width:1200px;margin:2rem auto;padding:0 2rem;min-height:calc(100vh - 120px)}@media(max-width:768px){.parent-header-content{flex-direction:column;gap:1rem}.parent-nav{width:100%;justify-content:center}.parent-user-menu{width:100%;justify-content:space-between}}.last-activities-container{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);height:100%;display:flex;flex-direction:column}.last-activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.last-activities-header h2{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.view-all-link{font-size:14px;color:var(--color-primary);text-decoration:none;font-weight:500}.view-all-link:hover{text-decoration:underline}.activities-list{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;overflow-y:auto;min-height:300px;max-height:500px}.activity-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-gray-100);border-radius:var(--radius-md);transition:all var(--transition-fast);background-color:#fff}.activity-item:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-200);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.activity-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.activity-avatar.system{background-color:var(--color-gray-100);color:var(--color-text-secondary)}.activity-content{flex:1;min-width:0}.activity-title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.activity-description{font-size:13px;color:var(--color-text-secondary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-muted)}.activity-time{font-weight:500}.activity-avatar.create{background-color:#e6fffa;color:#047481}.activity-avatar.update{background-color:#ebf8ff;color:#2b6cb0}.activity-avatar.delete{background-color:#fff5f5;color:#c53030}.activity-avatar.view{background-color:#f7fafc;color:#4a5568}.activity-avatar.login{background-color:#f0fff4;color:#2f855a}.activity-avatar.alert{background-color:#fffaf0;color:#c05621}.empty-state{text-align:center;color:var(--color-text-muted);padding:var(--spacing-xl);font-size:14px}.dashboard{padding:var(--spacing-lg);background:var(--color-gray-50);min-height:100vh}.dashboard-header{margin-bottom:var(--spacing-xl)}.dashboard-header h1{margin:0 0 var(--spacing-sm) 0;font-size:32px;font-weight:700;color:var(--color-text-primary)}.subtitle{margin:0;color:var(--color-text-secondary);font-size:14px}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--color-text-secondary)}.spinner{width:40px;height:40px;border:4px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.dashboard{padding:16px}.dashboard-header h1{font-size:24px;margin-top:32px}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:16px}.stat-value{font-size:24px}.actions-grid{grid-template-columns:repeat(2,1fr);gap:12px}.action-btn{padding:16px}.dashboard-content{grid-template-columns:1fr;gap:16px}}@media(max-width:480px){.dashboard,.stat-card{padding:12px}.action-label{font-size:12px}.schedule-item{padding:12px}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--spacing-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.stat-icon{font-size:48px;line-height:1}.stat-content{flex:1}.stat-value{font-size:36px;font-weight:700;color:var(--color-text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:14px;color:var(--color-text-secondary);font-weight:500}.stat-meta{font-size:12px;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.quick-actions{margin-bottom:var(--spacing-xl)}.quick-actions h2{margin:0 0 var(--spacing-md) 0;font-size:20px;font-weight:600;color:var(--color-text-primary)}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.action-btn{background:#fff;border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);cursor:pointer;transition:all var(--transition-normal)}.action-btn:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-icon{font-size:32px}.action-label{font-size:14px;font-weight:600;color:var(--color-text-primary)}.dashboard-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.schedule-section,.activity-section{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md)}.schedule-section h2,.activity-section h2{margin:0 0 var(--spacing-md) 0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.empty-state{text-align:center;color:var(--color-text-muted);padding:var(--spacing-xl) var(--spacing-md);font-size:14px}.schedule-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.schedule-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-gray-50);border-radius:var(--radius-md);transition:background var(--transition-fast)}.schedule-item:hover{background:var(--color-gray-100)}.schedule-time{font-size:14px;font-weight:600;color:var(--color-primary);min-width:60px}.schedule-details{flex:1}.schedule-patient{font-size:14px;font-weight:600;color:var(--color-text-primary)}.schedule-service{font-size:12px;color:var(--color-text-secondary)}.schedule-status{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.schedule-status.status-scheduled{background:#e3f2fd;color:#1976d2}.schedule-status.status-confirmed{background:#e8f5e9;color:#388e3c}.activity-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.activity-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);transition:background var(--transition-fast)}.activity-item:hover{background:var(--color-gray-50)}.activity-icon{font-size:24px}.activity-details{flex:1}.activity-title{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.activity-meta{font-size:12px;color:var(--color-text-secondary)}@media(max-width:1024px){.dashboard-content{grid-template-columns:1fr}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.actions-grid{grid-template-columns:repeat(2,1fr)}}.access-control-page{padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-actions{display:flex;gap:10px}.tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:1px solid #ddd;padding-bottom:10px}.tab{padding:var(--spacing-sm) 16px;border:none;background:none;cursor:pointer;font-size:var(--spacing-md);font-weight:500;color:#666;border-radius:var(--spacing-xs);transition:all .2s}.tab:hover{background-color:#f0f0f0;color:#333}.tab.active{background-color:#e3f2fd;color:#007bff;font-weight:600}.filters{margin-bottom:20px;display:flex;gap:12px;align-items:center}.search-input{flex:1;max-width:400px;padding:var(--spacing-sm) 12px;border:1px solid #ddd;border-radius:var(--spacing-xs);font-size:14px}.filter-select{padding:var(--spacing-sm) 12px;border:1px solid #ddd;border-radius:var(--spacing-xs);font-size:14px;min-width:150px}.users-list table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--spacing-sm);overflow:hidden;box-shadow:0 1px 3px #0000001a}.users-list th,.users-list td{padding:12px 16px;text-align:left;border-bottom:1px solid #eee}.users-list th{background-color:var(--color-gray-50);font-weight:600}.users-list tbody tr:hover{background-color:var(--color-gray-50)}.role-badge{padding:var(--spacing-xs) 12px;border-radius:var(--radius-lg);font-size:.85em;font-weight:500;color:#fff;display:inline-block}.role-badge.SUPER_ADMIN{background-color:#9333ea}.role-badge.CLINIC_ADMIN{background-color:#3b82f6}.role-badge.PROFESSIONAL{background-color:#10b981}.role-badge.RECEPTIONIST{background-color:#f59e0b}.role-badge.PARENT{background-color:#ec4899}.status-badge{padding:var(--spacing-xs) 12px;border-radius:var(--radius-lg);font-size:.85em;font-weight:500;display:inline-block}.status-badge.active{background-color:#22c55e;color:#fff}.status-badge.inactive{background-color:#ef4444;color:#fff}.actions-cell{display:flex;gap:var(--spacing-sm);align-items:center}.btn-icon{background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--spacing-xs);transition:background-color .2s;display:inline-flex;align-items:center;justify-content:center;font-size:1.1em}.btn-icon:hover{background-color:#e3f2fd}.btn-icon.delete:hover{background-color:#ffebee;color:#ef4444}.btn-primary{background-color:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:var(--spacing-sm);transition:all .2s ease}.btn-primary:hover{background-color:#0056b3;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-primary:active{transform:translateY(0)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;padding:var(--spacing-lg);border-radius:var(--spacing-sm);width:100%;max-width:600px;box-shadow:0 4px 6px #0000001a;max-height:90vh;overflow-y:auto}.modal h2{margin-top:0;margin-bottom:20px;color:#333}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:var(--spacing-sm) 12px;border:1px solid #ddd;border-radius:var(--spacing-xs);font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group small{color:#666;font-size:.85em}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:var(--spacing-lg)}.modal-actions button{padding:var(--spacing-sm) 16px;border:none;border-radius:var(--spacing-xs);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.modal-actions button[type=button]{background-color:#f0f0f0;color:#333}.modal-actions button[type=button]:hover{background-color:#e0e0e0}.empty-state{text-align:center;padding:40px 20px;color:#666;font-size:var(--spacing-md)}.loading{text-align:center;padding:40px;font-size:var(--spacing-md);color:#666}@media(max-width:768px){.access-control-page{padding:var(--spacing-md)}.header{flex-direction:column;align-items:stretch;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.header-actions{flex-direction:column;width:100%}.header-actions .btn-primary{width:100%;justify-content:center}.tabs{overflow-x:auto;padding-bottom:5px;white-space:nowrap;-webkit-overflow-scrolling:touch}.filters{flex-direction:column;align-items:stretch;gap:12px}.search-input{max-width:100%}.filter-select{width:100%}.users-list{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-list table{min-width:600px}.users-list th,.users-list td{padding:10px 12px;font-size:13px}.btn-icon{min-width:44px;min-height:44px;padding:var(--spacing-sm)}.btn-primary{min-height:44px;padding:12px 20px}.modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;margin:0!important;padding:var(--spacing-lg) 16px}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%;min-height:44px}}.cropper-overlay{position:fixed;inset:0;background-color:#000000b3;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.cropper-container{background-color:#fff;border-radius:12px;width:100%;max-width:600px;height:80vh;max-height:700px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 30px #0003}.cropper-header{padding:16px 20px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.cropper-header h4{margin:0;font-size:18px;color:#1a202c;font-weight:600}.btn-close-cropper{background:none;border:none;color:#a0aec0;font-size:20px;cursor:pointer;padding:4px;transition:color .2s;display:flex;align-items:center;justify-content:center}.btn-close-cropper:hover{color:#e53e3e}.cropper-area{position:relative;flex:1;background-color:#333}.cropper-controls{padding:20px;background-color:#fff;border-top:1px solid #e5e7eb}.zoom-slider-container{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:#718096}.zoom-slider{flex:1;cursor:pointer;height:6px;background:#e2e8f0;border-radius:3px;-webkit-appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:#667eea;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000001a}.cropper-actions{display:flex;justify-content:flex-end;gap:12px}.btn-secondary{padding:10px 20px;background-color:#edf2f7;color:#4a5568;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-secondary:hover{background-color:#e2e8f0}.btn-primary{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:opacity .2s;display:flex;align-items:center;gap:8px}.btn-primary:hover{opacity:.9}.logo-uploader-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:16px;transition:all .2s ease}.logo-uploader-card:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.logo-uploader-header h3{margin:0 0 4px;font-size:16px;font-weight:600;color:#111827}.logo-uploader-desc{margin:0 0 8px;font-size:13px;color:#6b7280}.logo-uploader-size{display:inline-block;background:#f3f4f6;color:#4b5563;font-size:11px;padding:2px 8px;border-radius:4px;font-family:monospace}.logo-preview-area{background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;padding:20px;display:flex;align-items:center;justify-content:center;min-height:120px}.logo-img{max-width:100%;max-height:100px;object-fit:contain}.logo-img.icon{width:64px;height:64px;border-radius:8px}.logo-img.report{max-width:100%}.no-logo-placeholder{color:#9ca3af;font-size:13px;font-style:italic}.logo-error{color:#ef4444;font-size:12px;margin-bottom:8px;display:flex;align-items:center;gap:6px}.logo-uploader-actions{margin-top:auto}.btn-select-file,.btn-upload-file{width:100%;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-select-file{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-select-file:hover{background:#f3f4f6;border-color:#9ca3af}.btn-upload-file{background:#4f46e5;border:1px solid #4f46e5;color:#fff}.btn-upload-file:hover{background:#4338ca}.upload-confirm-actions{display:flex;gap:8px}.btn-cancel-upload{flex:1;padding:8px 16px;border-radius:6px;font-size:14px;border:1px solid #d1d5db;background:#fff;color:#6b7280;cursor:pointer}.btn-cancel-upload:hover{background:#f9fafb;color:#374151}.settings-card{background:#fff;border-radius:var(--spacing-sm);padding:2rem;box-shadow:0 1px 3px #0000001a;max-width:800px}.settings-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#374151;font-size:.875rem}.form-group input,.form-group textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:var(--radius-sm);font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary-start);box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group textarea:disabled{background-color:#f3f4f6;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;justify-content:flex-start;gap:1rem;padding-top:1rem}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:1rem}.alert-success{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background-color:var(--color-primary-start);color:#fff}.btn-primary:hover:not(:disabled){background-color:#5568d3}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.logo-current{margin-top:1rem;padding:1rem;background-color:#f9fafb;border-radius:var(--radius-sm);border:1px solid #e5e7eb}.logo-label{font-size:.875rem;color:#6b7280;margin-bottom:.5rem}.logo-preview{max-width:300px;max-height:200px;object-fit:contain;background-color:#fff;padding:1rem;border:1px solid #e5e7eb;border-radius:var(--spacing-xs)}.help-text{font-size:.75rem;color:#6b7280;margin-top:.5rem}@media(max-width:768px){.settings-card{padding:1.5rem 1rem;margin:var(--spacing-md);max-width:100%}.settings-form{gap:1.25rem}.form-group label{font-size:.8125rem}.form-group input,.form-group textarea{padding:.625rem;font-size:.8125rem}.form-actions{flex-direction:column;gap:.75rem}.btn{width:100%;justify-content:center;min-height:44px;padding:.875rem 1.5rem}.logo-preview{max-width:100%;max-height:150px}.alert{padding:.625rem .875rem;font-size:.8125rem}}.logos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:24px}.section-title{font-size:1.1rem;font-weight:600;color:#1f2937;margin-bottom:16px;display:block}.section-divider{height:1px;background-color:#e5e7eb;margin:32px 0 24px}@media(max-width:640px){.logos-grid{grid-template-columns:1fr}}.confirm-page{min-height:100vh;background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%);display:flex;align-items:center;justify-content:center;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.confirm-container{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;padding:40px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.clinic-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:3px solid var(--color-primary-start)}.clinic-header h1{color:var(--color-primary-start);font-size:28px;margin:0 0 10px}.clinic-header .subtitle{color:#666;font-size:var(--spacing-md);margin:0}.appointment-details{background:var(--color-gray-50);border-radius:var(--radius-lg);padding:25px;margin-bottom:25px}.appointment-details h2{color:#333;font-size:20px;margin:0 0 20px;text-align:center}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e0e0e0}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:600;color:#555;font-size:15px}.detail-row .value{color:#333;font-size:15px;text-align:right}.status-badge{padding:6px 12px;border-radius:20px;font-size:14px;font-weight:600}.status-pending{background:#fff3cd;color:#856404}.status-confirmed{background:#d4edda;color:#155724}.status-cancelled{background:#f8d7da;color:#721c24}.warning-box{background:#fff3cd;border-left:var(--spacing-xs) solid #ffc107;padding:15px;margin-bottom:25px;border-radius:var(--spacing-sm)}.warning-box p{margin:0;color:#856404;font-size:14px;line-height:1.6}.action-buttons{display:flex;gap:15px;margin-bottom:25px}.action-buttons button{flex:1;padding:var(--spacing-md);border:none;border-radius:var(--radius-lg);font-size:var(--spacing-md);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-confirm{background:#28a745;color:#fff}.btn-confirm:hover:not(:disabled){background:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a74566}.btn-cancel{background:#dc3545;color:#fff}.btn-cancel:hover:not(:disabled){background:#c82333;transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.action-buttons button:disabled{opacity:.6;cursor:not-allowed}.success-message{background:#d4edda;border:1px solid #c3e6cb;color:#155724;padding:15px;border-radius:var(--spacing-sm);margin-bottom:20px;text-align:center;font-weight:600}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:15px;border-radius:var(--spacing-sm);margin-bottom:20px;text-align:center;font-weight:600}.already-actioned{background:#e7f3ff;border:2px solid var(--color-primary-start);padding:20px;border-radius:var(--radius-lg);text-align:center;margin-bottom:25px}.already-actioned p{margin:0 0 10px;font-size:var(--spacing-md);font-weight:600;color:#333}.already-actioned .action-date{font-size:14px;color:#666;font-weight:400}.footer{text-align:center;padding-top:20px;border-top:1px solid #e0e0e0;color:#666;font-size:14px}.footer p{margin:5px 0}.loading,.error-state{text-align:center;padding:40px 20px}.error-state h2{color:#dc3545;margin-bottom:10px}.error-state p{color:#666}@media(max-width:600px){.confirm-container{padding:25px}.clinic-header h1{font-size:var(--spacing-lg)}.action-buttons{flex-direction:column}.detail-row{flex-direction:column;align-items:flex-start;gap:5px}.detail-row .value{text-align:left}}.parent-reports-page{min-height:100vh;padding-bottom:2rem}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.report-card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.report-card-hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.report-card-header{border-bottom:2px solid var(--color-gray-50);padding-bottom:1rem;margin-bottom:1rem}.report-card-header h3{margin:0 0 .5rem;color:var(--color-gray-700)}.report-date{color:var(--color-text-secondary);font-size:.875rem}.report-card-body{margin-bottom:1rem}.report-info p{margin:.5rem 0;color:var(--color-gray-600);display:flex;align-items:center;gap:.5rem}.report-info i{color:var(--color-primary-start);width:20px}.report-card-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-view,.btn-download{flex:1;padding:.75rem;border:none;border-radius:var(--spacing-sm);font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-view{background:var(--color-primary-start);color:#fff}.btn-view:hover{background:#5568d3;transform:translateY(-2px)}.btn-download{background:var(--color-success);color:#fff}.btn-download:hover{background:#38a169;transform:translateY(-2px)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid var(--color-gray-50)}.modal-header h2{margin:0;color:var(--color-gray-700)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-gray-400);cursor:pointer;padding:.5rem;transition:color .3s ease}.modal-close:hover{color:var(--color-gray-700)}.modal-body{padding:1.5rem}.report-metadata{background:var(--color-gray-50);padding:1rem;border-radius:var(--spacing-sm);margin-bottom:1.5rem}.report-metadata p{margin:.5rem 0;color:var(--color-gray-600)}.report-content{line-height:1.8;color:var(--color-gray-700)}.modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:2px solid var(--color-gray-50);justify-content:flex-end}.btn-download-modal,.btn-close-modal{padding:.75rem 1.5rem;border:none;border-radius:var(--spacing-sm);font-weight:500;cursor:pointer;transition:all .3s ease}.btn-download-modal{background:var(--color-success);color:#fff}.btn-download-modal:hover{background:#38a169}.btn-close-modal{background:var(--color-gray-50);color:var(--color-gray-600)}.btn-close-modal:hover{background:var(--color-gray-100)}@media(max-width:768px){.reports-grid{grid-template-columns:1fr}.filters-section{flex-direction:column}.filter-btn,.clear-filter-btn{align-self:stretch}}.parent-photos-page{min-height:100vh;padding-bottom:2rem}.page-header{background:#fff;padding:2rem;border-radius:var(--radius-lg);margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.page-header h1{display:flex;align-items:center;gap:.75rem;margin:0;color:var(--color-gray-700);font-size:2rem}.page-subtitle{margin:.5rem 0 0;color:var(--color-text-secondary)}.filters-section{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;background:#fff;padding:1.5rem;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000001a}.filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:200px}.filter-group label{font-weight:500;color:var(--color-gray-600);display:flex;align-items:center;gap:.5rem}.date-input{padding:.75rem;border:2px solid var(--color-gray-200);border-radius:var(--spacing-sm);font-size:1rem;transition:border-color .3s ease}.date-input:focus{outline:none;border-color:var(--color-primary-start)}.filter-btn,.clear-filter-btn{padding:.75rem 1.5rem;border:none;border-radius:var(--spacing-sm);font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;align-self:flex-end}.filter-btn{background:var(--color-primary-start);color:#fff}.filter-btn:hover{background:#5568d3;transform:translateY(-2px)}.clear-filter-btn{background:var(--color-gray-50);color:var(--color-gray-600);border:2px solid var(--color-gray-200)}.clear-filter-btn:hover{background:var(--color-gray-100)}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#fff;font-size:1.2rem}.loading-spinner i{font-size:3rem;margin-bottom:1rem}.empty-state{background:#fff;padding:3rem;border-radius:var(--radius-lg);text-align:center;color:var(--color-text-secondary)}.empty-state i{font-size:4rem;color:var(--color-gray-300);margin-bottom:1rem}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.photo-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s ease}.photo-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.photo-image{width:100%;height:250px;overflow:hidden;background:var(--color-gray-50)}.photo-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-card:hover .photo-image img{transform:scale(1.05)}.photo-info{padding:1rem}.photo-info p{margin:.5rem 0;display:flex;align-items:center;gap:.5rem;color:var(--color-gray-600)}.photo-info i{color:var(--color-primary-start);width:20px}.photo-patient{font-weight:600;color:var(--color-gray-700)!important}.photo-date{font-size:.875rem;color:var(--color-text-secondary)!important}.photo-description{margin-top:.75rem!important;font-size:.9rem;line-height:1.5;color:var(--color-gray-600)!important}.lightbox-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:2000;padding:2rem}.lightbox-close{position:absolute;top:2rem;right:2rem;background:#ffffff1a;color:#fff;border:none;font-size:2rem;width:50px;height:50px;border-radius:50%;cursor:pointer;transition:all .3s ease;z-index:2002}.lightbox-close:hover{background:#fff3;transform:rotate(90deg)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;color:#fff;border:none;font-size:2rem;width:60px;height:60px;border-radius:50%;cursor:pointer;transition:all .3s ease;z-index:2002}.lightbox-nav:hover{background:#fff3}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}.lightbox-content{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.lightbox-content img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:var(--spacing-sm);box-shadow:0 10px 40px #00000080}.lightbox-info{background:#fffffff2;padding:1.5rem;border-radius:var(--spacing-sm);max-width:600px;width:100%}.lightbox-info p{margin:.5rem 0;display:flex;align-items:center;gap:.5rem;color:var(--color-gray-600)}.lightbox-info i{color:var(--color-primary-start);width:20px}.lightbox-patient{font-weight:600;color:var(--color-gray-700)!important;font-size:1.1rem}.lightbox-date{color:var(--color-text-secondary)!important}.lightbox-description{margin-top:1rem!important;line-height:1.6;color:var(--color-gray-600)!important}.lightbox-counter{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);background:#ffffffe6;color:var(--color-gray-700);padding:.5rem 1.5rem;border-radius:20px;font-weight:600;z-index:2002}@media(max-width:768px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.photo-image{height:200px}.filters-section{flex-direction:column}.filter-btn,.clear-filter-btn{align-self:stretch}.lightbox-nav{width:40px;height:40px;font-size:1.5rem}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.lightbox-close{top:1rem;right:1rem;width:40px;height:40px;font-size:1.5rem}}.audit-log-page{padding:20px;max-width:1400px;margin:0 auto}.page-header{margin-bottom:30px}.page-header h1{margin:0;color:#1f2937;font-size:28px;font-weight:700}.subtitle{margin:var(--spacing-sm) 0 0 0;color:#6b7280;font-size:15px}.page-content{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 1px 3px #0000001a}.filters-section{margin-bottom:var(--spacing-lg)}.search-box{position:relative;margin-bottom:var(--spacing-md)}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:#9ca3af;font-size:var(--spacing-md)}.search-box input{width:100%;padding:12px 16px 12px 48px;border:2px solid #e5e7eb;border-radius:var(--spacing-sm);font-size:15px;transition:border-color .2s}.search-box input:focus{outline:none;border-color:var(--color-primary-start)}.filters-row{display:flex;gap:12px;flex-wrap:wrap}.filter-select,.filter-date{padding:10px 14px;border:1px solid #d1d5db;border-radius:var(--spacing-sm);font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.filter-select:focus,.filter-date:focus{outline:none;border-color:var(--color-primary-start)}.filter-select{min-width:180px}.filter-date{min-width:150px}.results-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding:12px 16px;background:#f9fafb;border-radius:var(--spacing-sm);font-size:14px;color:#6b7280}.page-info{font-weight:600;color:#374151}.logs-table{overflow-x:auto;border-radius:var(--spacing-sm);border:1px solid #e5e7eb}table{width:100%;border-collapse:collapse}thead{background:#f9fafb}th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#374151;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}tbody tr{border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background-color .2s}tbody tr:hover{background-color:#f9fafb}tbody tr.expanded{background-color:#eff6ff}td{padding:14px 16px;font-size:14px;color:#374151}.date-cell{font-family:Courier New,monospace;font-size:13px;color:#6b7280;white-space:nowrap}.user-cell{min-width:150px}.user-name{font-weight:600;color:#1f2937}.user-role{font-size:12px;color:#6b7280;margin-top:2px}.system-user{color:#9ca3af;font-style:italic}.action-badge{display:inline-block;padding:var(--spacing-xs) 12px;border-radius:var(--radius-lg);font-size:12px;font-weight:600;white-space:nowrap}.badge-create{background:#d1fae5;color:#065f46}.badge-update{background:#dbeafe;color:#1e40af}.badge-delete{background:#fee2e2;color:#991b1b}.badge-view{background:#e0e7ff;color:#3730a3}.badge-login{background:#d1fae5;color:#065f46}.badge-logout{background:#fef3c7;color:#92400e}.badge-default{background:#f3f4f6;color:#4b5563}.resource-cell{font-weight:500;color:#4b5563}.resource-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ip-cell{font-family:Courier New,monospace;font-size:13px;color:#6b7280}.details-cell{text-align:center}.details-btn{background:none;border:none;color:var(--color-primary-start);cursor:pointer;font-size:14px;padding:var(--spacing-xs) 8px;transition:color .2s}.details-btn:hover{color:#4f46e5}.details-row{background:#f9fafb}.details-content{padding:var(--spacing-md);border-top:1px solid #e5e7eb}.detail-item{margin-bottom:12px}.detail-item:last-child{margin-bottom:0}.detail-item strong{display:inline-block;min-width:120px;color:#374151;font-weight:600}.detail-item pre{margin:var(--spacing-sm) 0 0 0;padding:12px;background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius-sm);font-size:12px;overflow-x:auto;max-height:300px}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid #e5e7eb}.pagination-btn{padding:var(--spacing-sm) 16px;background:#fff;border:1px solid #d1d5db;border-radius:var(--spacing-sm);color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:var(--color-primary-start);color:var(--color-primary-start)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:14px;color:#6b7280;font-weight:500}.loading,.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.loading{font-size:var(--spacing-md)}.empty-state p{font-size:var(--spacing-md);margin:0}@media(max-width:768px){.filters-row{flex-direction:column}.filter-select,.filter-date{width:100%}.logs-table{font-size:12px}th,td{padding:var(--spacing-sm)}.resource-name{max-width:100px}}.update-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #00000026;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.update-banner-content{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;gap:16px}.update-banner-icon{font-size:24px;flex-shrink:0}.update-banner-text{flex:1}.update-banner-text strong{display:block;font-size:16px;margin-bottom:4px}.update-banner-text p{margin:0;font-size:14px;opacity:.95}.update-banner-actions{display:flex;gap:12px;flex-shrink:0}.update-banner-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.update-banner-btn-primary{background:#fff;color:#667eea}.update-banner-btn-primary:hover{background:#f8f9fa;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.update-banner-btn-secondary{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}.update-banner-btn-secondary:hover{background:#ffffff1a;border-color:#fff}@media(max-width:768px){.update-banner-content{flex-direction:column;align-items:flex-start;gap:12px}.update-banner-actions{width:100%;flex-direction:column}.update-banner-btn{width:100%}}.ticket-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px -5px #0000000d;border:1px solid rgba(0,0,0,.03);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;display:flex;flex-direction:column;height:100%}.ticket-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000001a;border-color:#667eea4d}.ticket-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ticket-id{font-family:Monaco,Consolas,monospace;font-size:12px;color:#a0aec0;font-weight:600;letter-spacing:.5px}.ticket-status{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.status-nuevo{background:#ebf8ff;color:#3182ce}.status-en-analisis{background:#e6fffa;color:#319795}.status-en-progreso{background:#ebf4ff;color:#5a67d8}.status-en-espera{background:#fffaf0;color:#dd6b20}.status-resuelto{background:#f0fff4;color:#38a169}.status-cerrado{background:#f7fafc;color:#718096}.status-critica{background:#fff5f5;color:#e53e3e}.ticket-card-title{font-size:16px;font-weight:700;color:#2d3748;margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ticket-card-desc{font-size:13px;color:#718096;margin:0 0 16px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.ticket-card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #edf2f7}.meta-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#718096}.meta-icon{color:#a0aec0}.priority-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase;border:1px solid transparent}.priority-critical{color:#c53030;background:#fff5f5;border-color:#feb2b2}.priority-high{color:#c05621;background:#fffaf0;border-color:#fbd38d}.priority-medium{color:#b7791f;background:ivory;border-color:#f6e05e}.priority-low{color:#2f855a;background:#f0fff4;border-color:#9ae6b4}.ticket-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:12px}.assignee-info{display:flex;align-items:center;gap:8px}.assignee-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.assignee-name{color:#4a5568;font-weight:500}.time-info{color:#a0aec0;font-size:11px;display:flex;align-items:center;gap:4px}.ticket-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:30px}.glass-card{background:#fff;border-radius:20px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 10px 30px -10px #0000000d;border:1px solid rgba(255,255,255,.8);transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden}.glass-card:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;border-radius:4px 0 0 4px}.glass-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px -10px #0000001a}.glass-card.open:before{background:#667eea}.glass-card.open .stat-icon-wrapper{background:#667eea1a;color:#667eea}.glass-card.critical:before{background:#f56565}.glass-card.critical .stat-icon-wrapper{background:#f565651a;color:#f56565}.glass-card.progress:before{background:#4299e1}.glass-card.progress .stat-icon-wrapper{background:#4299e11a;color:#4299e1}.glass-card.resolved:before{background:#48bb78}.glass-card.resolved .stat-icon-wrapper{background:#48bb781a;color:#48bb78}.stat-icon-wrapper{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px}.stat-info{display:flex;flex-direction:column}.stat-label{font-size:14px;color:#a0aec0;font-weight:500;margin-bottom:4px}.stat-value{font-size:32px;font-weight:700;color:#2d3748;line-height:1.1}.stat-trend{font-size:12px;margin-top:4px;font-weight:600}.stat-trend.positive{color:#48bb78}.stat-trend.negative{color:#f56565}.stat-trend.neutral{color:#a0aec0}.glass-panel{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 15px -5px #0000000d;border:1px solid rgba(0,0,0,.03);margin-bottom:24px}.filters-row-top{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:16px;flex-wrap:wrap}.search-wrapper{position:relative;flex:1;min-width:250px}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#a0aec0}.search-input-premium{width:100%;padding:12px 16px 12px 42px;border-radius:12px;border:1px solid #e2e8f0;background:#f7fafc;color:#2d3748;font-size:14px;transition:all .2s}.search-input-premium:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.status-pills{display:flex;gap:8px;flex-wrap:wrap}.filter-pill{padding:8px 16px;border-radius:20px;border:1px solid #e2e8f0;background:#fff;color:#4a5568;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.filter-pill:hover{background:#f7fafc;border-color:#cbd5e0}.filter-pill.active{background:#667eea;color:#fff;border-color:#667eea;box-shadow:0 2px 5px #667eea4d}.filters-row-bottom{display:flex;gap:12px;align-items:center}.select-wrapper{position:relative;min-width:180px}.select-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#a0aec0;font-size:12px;pointer-events:none}.filter-select{width:100%;padding:10px 12px 10px 32px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-size:13px;color:#4a5568;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a0aec0' 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-repeat:no-repeat;background-position:right 12px center;background-size:14px}.filter-select:focus{border-color:#667eea;outline:none}@media(max-width:768px){.filters-row-top{flex-direction:column;align-items:stretch}.status-pills{overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.filter-pill{white-space:nowrap}.filters-row-bottom{flex-wrap:wrap}.select-wrapper{flex:1}}:root{--color-primary-start: #667eea;--color-primary-end: #764ba2;--color-primary: #667eea;--color-success: #4CAF50;--color-warning: #FF9800;--color-danger: #F44336;--color-info: #2196F3;--color-gray-50: #f8f9fa;--color-gray-100: #f1f3f5;--color-gray-200: #e9ecef;--color-gray-300: #dee2e6;--color-gray-400: #ced4da;--color-gray-500: #adb5bd;--color-gray-600: #6c757d;--color-gray-700: #495057;--color-gray-800: #343a40;--color-gray-900: #212529;--color-text-primary: #2c3e50;--color-text-secondary: #7f8c8d;--color-text-muted: #95a5a6;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .06);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .12);--shadow-xl: 0 8px 20px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--breakpoint-mobile: 768px;--breakpoint-tablet: 1024px;--breakpoint-desktop: 1440px;--touch-target-min: 44px;--mobile-padding: 16px;--mobile-font-base: 16px;--mobile-spacing-xs: 4px;--mobile-spacing-sm: 8px;--mobile-spacing-md: 12px;--mobile-spacing-lg: 16px;--mobile-spacing-xl: 24px}*{box-sizing:border-box}body{margin:0;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;color:var(--color-text-primary)}.gradient-primary{background:linear-gradient(135deg,var(--color-primary-start) 0%,var(--color-primary-end) 100%)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.modules-settings{padding:2rem;max-width:1200px;margin:0 auto}.modules-header{margin-bottom:2rem}.modules-header h2{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.modules-description{color:#6b7280;font-size:.875rem}.module-category{margin-bottom:3rem}.category-header{margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.category-header h3{font-size:1.25rem;font-weight:600;color:#374151;margin-bottom:.25rem}.category-description{color:#6b7280;font-size:.875rem;margin:0}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.module-card{background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;transition:all .2s}.module-card.enabled{border-color:#10b981;background:#f0fdf4}.module-card.disabled{opacity:.7}.module-card.core{border-color:#3b82f6;background:#eff6ff}.module-card:hover{box-shadow:0 4px 6px -1px #0000001a}.module-info{margin-bottom:1rem}.module-title{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.module-title h4{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0}.module-description{color:#6b7280;font-size:.875rem;margin:.5rem 0;line-height:1.5}.module-route{display:inline-block;font-size:.75rem;color:#9ca3af;font-family:monospace;background:#f3f4f6;padding:.25rem .5rem;border-radius:.25rem}.module-toggle{display:flex;align-items:center;gap:.75rem}.toggle-label{font-size:.875rem;font-weight:500;color:#374151}.switch{position:relative;display:inline-block;width:48px;height:var(--spacing-lg)}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.3s;border-radius:var(--spacing-lg)}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider{background-color:#10b981}input:checked+.slider:before{transform:translate(24px)}input:disabled+.slider{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:.25rem}.badge-core{background-color:#dbeafe;color:#1e40af}@media(max-width:768px){.modules-settings{padding:1rem}.modules-grid{grid-template-columns:1fr}.modules-header h2{font-size:1.5rem}}
