*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:#666}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:24px;color:#333;margin-bottom:8px}.login-header p{color:#666;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-block{width:100%}.error{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:0;margin-bottom:24px;box-shadow:0 10px 30px #0003;overflow:hidden}.header-container{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;gap:24px;flex-wrap:wrap}.header-left{flex:1;min-width:300px}.logo-section{display:flex;align-items:center;gap:16px}.logo-icon{height:60px;width:auto;background:#fff;border-radius:12px;padding:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026;object-fit:contain}.title-section h1{margin:0;color:#fff;font-size:28px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}.title-section .subtitle{margin:4px 0 0;color:#ffffffe6;font-size:14px;font-weight:400}.header-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.period-selector{display:flex;align-items:center;gap:8px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:12px}.period-selector label{color:#fff;font-size:14px;font-weight:500;white-space:nowrap}.period-selector select{background:#fffffff2;border:none;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500;color:#1f2937;cursor:pointer;transition:all .2s}.period-selector select:hover{background:#fff;box-shadow:0 2px 8px #0000001a}.period-selector select:focus{outline:none;box-shadow:0 0 0 3px #ffffff4d}.last-sync{color:#ffffffe6;font-size:12px;background:#ffffff1a;padding:6px 12px;border-radius:8px;white-space:nowrap}.btn-export,.btn-logout{background:#fffffff2;border:none;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#667eea;white-space:nowrap}.btn-export:hover,.btn-logout:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-export:active,.btn-logout:active{transform:translateY(0)}.btn-logout{color:#dc2626}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000001a;transition:transform .2s}.stat-card:hover{transform:translateY(-4px)}.stat-card h3{margin:0 0 8px;color:#6b7280;font-size:14px;font-weight:500}.stat-card .value{font-size:32px;font-weight:700;color:#1f2937}.table-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px #0000001a;overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #e5e7eb}.data-table th{background:#f9fafb;font-weight:600;color:#374151}.data-table tbody tr:hover{background:#f9fafb;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.modal-content{background:#fff;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{margin:0;color:#1f2937;font-size:24px}.modal-close{background:#f3f4f6;border:none;border-radius:8px;width:36px;height:36px;font-size:20px;cursor:pointer;transition:background .2s}.modal-close:hover{background:#e5e7eb}.modal-body{padding:24px}.modal-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.modal-stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 6px #0000001a}.modal-stat-icon{font-size:32px}.modal-stat-content{display:flex;flex-direction:column;gap:4px}.modal-stat-label{color:#ffffffe6;font-size:13px;font-weight:500}.modal-stat-value{color:#fff;font-size:28px;font-weight:700}.modal-section{margin-bottom:32px;padding:20px;background:#f9fafb;border-radius:12px;border-left:4px solid #667eea}.modal-section-title{margin:0 0 16px;color:#1f2937;font-size:18px;font-weight:600}.modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.modal-info-card{background:#fff;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 4px #0000000d;transition:transform .2s}.modal-info-card:hover{transform:translateY(-2px)}.modal-info-card.highlight{border:2px solid #10b981;background:#f0fdf4}.modal-info-card.alert{border:2px solid #ef4444;background:#fef2f2}.modal-info-card.success{border:2px solid #06b6d4;background:#f0f9ff}.info-label{color:#6b7280;font-size:13px;font-weight:500}.info-value{color:#1f2937;font-size:24px;font-weight:700}.modal-chart{margin-bottom:32px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d}.modal-chart h3{margin:0 0 20px;color:#1f2937;font-size:18px;font-weight:600}.modal-analysis{padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d}.modal-analysis h3{margin:0 0 20px;color:#1f2937;font-size:18px;font-weight:600}.analysis-content{display:flex;flex-direction:column;gap:16px}.analysis-badge{padding:12px 20px;border-radius:8px;font-size:16px;font-weight:600;text-align:center}.analysis-badge.analysis-success{background:#d1fae5;color:#065f46}.analysis-badge.analysis-warning{background:#fed7aa;color:#92400e}.analysis-progress{width:100%;height:24px;background:#e5e7eb;border-radius:12px;overflow:hidden}.analysis-progress-bar{height:100%;transition:width .3s ease;border-radius:12px}.analysis-details{display:flex;flex-direction:column;gap:8px}.analysis-details p{margin:0;color:#374151;font-size:14px}.text-success{color:#059669!important;font-weight:600}.text-warning{color:#d97706!important;font-weight:600}.modal-footer{padding:20px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:center;position:sticky;bottom:0;background:#fff}.btn-modal-close{background:#667eea;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-modal-close:hover{background:#5568d3}.btn-sync{background:#10b981;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-sync:hover{background:#059669}.btn-sync:disabled{background:#9ca3af;cursor:not-allowed}@media(max-width:768px){.stats-grid,.modal-stats,.modal-grid{grid-template-columns:1fr}.modal-content{max-height:95vh}.dashboard-header h1{font-size:22px}}.loading{text-align:center;padding:40px;color:#fff;font-size:18px}.progress-bar-compact{width:100%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-top:4px}.progress-fill-compact{height:100%;transition:width .3s ease;border-radius:3px}.table-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000001a;margin-bottom:24px}.section-title{margin:0 0 20px;color:#1f2937;font-size:20px;font-weight:700}.table-container{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb}.specialty-table{width:100%;border-collapse:collapse;font-size:14px;min-width:800px}.specialty-table thead{background:linear-gradient(135deg,#667eea,#764ba2);position:sticky;top:0;z-index:10}.specialty-table thead th{color:#fff;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:16px 12px;text-align:left;border-bottom:3px solid rgba(255,255,255,.3)}.th-specialty{min-width:200px;text-align:left!important}.th-number{min-width:90px;text-align:center!important}.th-percent{min-width:80px;text-align:center!important}.specialty-table tbody tr{border-bottom:1px solid #e5e7eb;transition:all .2s ease}.specialty-table tbody tr:hover{background:#f9fafb;cursor:pointer;transform:scale(1.01);box-shadow:0 2px 8px #00000014}.specialty-table tbody tr:last-child{border-bottom:none}.td-specialty{padding:16px 12px;font-weight:600;color:#1f2937;text-align:left}.td-number{padding:16px 12px;text-align:center;font-weight:500;color:#4b5563}.td-blue{color:#3b82f6!important;font-weight:600}.td-green{color:#10b981!important;font-weight:600}.td-bold{font-weight:700!important;font-size:15px}.td-percent{padding:16px 12px;text-align:center;font-weight:700;font-size:14px}@media(max-width:768px){.table-section{padding:16px;border-radius:12px}.section-title{font-size:18px;margin-bottom:16px}.table-container{border-radius:8px}.specialty-table{font-size:12px;min-width:700px}.specialty-table thead th{padding:12px 8px;font-size:10px}.td-specialty,.td-number,.td-percent{padding:12px 8px}.th-specialty{min-width:150px}.th-number{min-width:70px}.th-percent{min-width:60px}}@media(max-width:480px){.specialty-table{font-size:11px;min-width:650px}.specialty-table thead th{padding:10px 6px;font-size:9px}.td-specialty,.td-number,.td-percent{padding:10px 6px}.td-bold{font-size:13px}}@media(max-width:768px){.header-container{padding:20px;gap:16px}.header-left{min-width:100%}.logo-icon{height:50px;padding:6px}.title-section h1{font-size:22px}.title-section .subtitle{font-size:12px}.header-right{width:100%;justify-content:flex-start}.period-selector{flex:1;min-width:100%}.btn-export,.btn-logout{flex:1;padding:10px 16px;font-size:13px}}@media(max-width:480px){.header-container{padding:16px}.logo-icon{height:45px;padding:6px}.title-section h1{font-size:18px}.title-section .subtitle{font-size:11px}.btn-export,.btn-logout{font-size:12px;padding:8px 12px}}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:24px;margin-bottom:32px}.chart-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 6px #00000012;transition:all .3s ease;border:1px solid #e5e7eb}.chart-card:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-2px)}.chart-header{margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f3f4f6}.chart-header h3{margin:0 0 8px;color:#1f2937;font-size:18px;font-weight:700;letter-spacing:-.02em}.chart-subtitle{margin:0;color:#6b7280;font-size:13px;font-weight:400;line-height:1.4}@media(max-width:1024px){.charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.chart-card{padding:20px}.chart-header h3{font-size:16px}.chart-subtitle{font-size:12px}}@media(max-width:480px){.charts-grid{gap:16px}.chart-card{padding:16px}.chart-header{margin-bottom:16px;padding-bottom:12px}.chart-header h3{font-size:15px}.chart-subtitle{font-size:11px}}
