@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.data-uploader{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--border-radius);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all .3s ease;width:100%}.data-uploader:hover{border-color:var(--accent-teal);box-shadow:0 0 15px #25d0c226}.file-label{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--font-family);color:var(--text-secondary);font-size:.85rem;font-weight:500;width:100%}.file-label span{min-width:90px;color:var(--text-secondary)}.file-label input[type=file]{color:var(--text-secondary);font-size:.8rem;background:var(--bg-input);border:1px dashed var(--border-color);border-radius:6px;padding:4px 8px;cursor:pointer;transition:all .2s ease;width:100%;max-width:260px}.file-label input[type=file]:hover{border-color:var(--accent-teal);background:#1f2b47b3}.file-label input[type=file]::file-selector-button{background:linear-gradient(135deg,var(--accent-teal),var(--accent-indigo));color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:.75rem;font-weight:600;margin-right:8px;cursor:pointer;transition:all .2s ease;font-family:var(--font-family)}.file-label input[type=file]::file-selector-button:hover{filter:brightness(1.1);transform:translateY(-.5px)}.button-group{display:flex;gap:10px;margin-top:4px}.reset-button{flex:1;padding:9px 14px;background:#f655701f;color:var(--accent-rose);border:1px solid hsla(350,90%,65%,.25);border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:var(--font-family)}.reset-button:hover{background:#f6557038;border-color:var(--accent-rose);box-shadow:0 4px 12px #f6557026;transform:translateY(-1px)}.export-button{flex:1;padding:9px 14px;background:linear-gradient(135deg,var(--accent-teal),var(--accent-indigo));color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:var(--font-family);box-shadow:0 2px 10px #25d0c233}.export-button:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 16px #25d0c259}.export-button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.upload-status{font-size:.78rem;color:var(--accent-emerald);font-weight:500;text-align:center;min-height:18px;margin-top:2px}:root{--bg-primary: hsl(222, 47%, 8%);--bg-secondary: hsl(222, 40%, 11%);--bg-glass: hsla(222, 40%, 18%, .55);--bg-glass-hover: hsla(222, 40%, 24%, .7);--bg-input: hsla(222, 40%, 14%, .8);--accent-teal: hsl(175, 70%, 48%);--accent-teal-dim: hsla(175, 70%, 48%, .18);--accent-indigo: hsl(234, 89%, 74%);--accent-violet: hsl(265, 83%, 72%);--accent-amber: hsl(38, 95%, 60%);--accent-emerald: hsl(152, 76%, 55%);--accent-rose: hsl(350, 90%, 65%);--sector-dev: hsl(175, 70%, 48%);--sector-qa: hsl(350, 90%, 65%);--sector-data: hsl(152, 76%, 55%);--sector-security: hsl(234, 89%, 74%);--sector-pm: hsl(38, 95%, 60%);--sector-robotics: hsl(265, 83%, 72%);--sector-ops: hsl(175, 40%, 40%);--text-primary: hsl(210, 40%, 96%);--text-secondary: hsl(215, 20%, 65%);--text-muted: hsl(215, 15%, 42%);--border-color: hsla(215, 30%, 40%, .35);--border-glow: hsla(175, 70%, 48%, .4);--shadow-sm: 0 2px 8px hsla(222, 47%, 2%, .5);--shadow-md: 0 8px 32px hsla(222, 47%, 2%, .6), 0 2px 8px hsla(222, 47%, 2%, .3);--shadow-glow: 0 0 20px hsla(175, 70%, 48%, .15), 0 8px 32px hsla(222, 47%, 2%, .5);--bg-color: hsl(222, 47%, 8%);--card-bg: hsla(222, 40%, 14%, .8);--primary-color: hsl(175, 70%, 48%);--primary-hover: hsl(175, 70%, 40%);--secondary-color: hsl(215, 20%, 40%);--secondary-hover: hsl(215, 20%, 32%);--success-color: hsl(152, 76%, 55%);--warning-color: hsl(38, 95%, 60%);--danger-color: hsl(350, 90%, 65%);--border-radius: 12px;--shadow: var(--shadow-md);--font-family: "Inter", system-ui, -apple-system, sans-serif}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 12px #25d0c233}50%{box-shadow:0 0 24px #25d0c273}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;background:linear-gradient(135deg,#0b111e,#0e1325,#0e0e20,#0b111e);background-size:400% 400%;animation:gradientShift 18s ease infinite;color:var(--text-primary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}.dashboard-container{max-width:1440px;margin:0 auto;padding:28px 24px;display:flex;flex-direction:column;gap:24px;animation:fadeInUp .5s ease both}.dashboard-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;border-bottom:1px solid var(--border-color);padding-bottom:20px}.header-title h1{margin:0;font-size:2.1rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent-teal),var(--accent-indigo),var(--accent-violet));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% auto;animation:shimmer 4s linear infinite}.header-title .subtitle{margin:6px 0 0;color:var(--text-secondary);font-size:.92rem;font-weight:400}.card{background:var(--bg-glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:22px;box-shadow:var(--shadow-md);transition:box-shadow .25s ease,border-color .25s ease;animation:fadeInUp .4s ease both}.card:hover{border-color:#5979a680;box-shadow:var(--shadow-glow)}.card h3{margin-top:0;margin-bottom:16px;font-size:1rem;font-weight:700;letter-spacing:.01em;border-bottom:1px solid var(--border-color);padding-bottom:10px;color:var(--text-primary)}.btn-primary,.btn-secondary{padding:9px 18px;border-radius:8px;font-size:.83rem;font-weight:600;cursor:pointer;border:none;transition:all .2s ease;letter-spacing:.01em}.btn-primary{background:linear-gradient(135deg,var(--accent-teal),var(--accent-indigo));color:#fff;box-shadow:0 2px 12px #25d0c24d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px #25d0c280;filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#3e557480;color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{transform:translateY(-2px);background:#4b668ba6;border-color:var(--accent-teal);box-shadow:0 4px 16px #25d0c233}.data-uploader{flex-grow:1;max-width:520px}.upload-controls{display:flex;flex-direction:column;gap:12px}.file-input-group{display:flex;align-items:center;justify-content:space-between;gap:10px}.file-input-group label{font-size:.82rem;font-weight:600;color:var(--text-secondary);min-width:130px}.file-input-group input[type=file]{font-size:.82rem;color:var(--text-secondary)}.button-group{display:flex;gap:8px;margin-top:6px}.filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}.filter-control{display:flex;flex-direction:column;gap:5px}.filter-control label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.filter-control select,.filter-control input[type=number]{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.84rem;color:var(--text-primary);background:var(--bg-input);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease;font-family:var(--font-family)}.filter-control select:focus,.filter-control input[type=number]:focus{outline:none;border-color:var(--accent-teal);box-shadow:0 0 0 3px #25d0c233;background:#1c2740e6}.filter-control select option{background:#151e32;color:var(--text-primary)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width: 960px){.dashboard-grid{grid-template-columns:1fr}}.left-panel{display:flex;flex-direction:column;gap:24px}.right-panel{display:flex;flex-direction:column}.competency-map-container{flex-grow:1;display:flex;flex-direction:column}.placeholder-d3-chart{background:var(--accent-teal-dim);border:2px dashed hsla(175,70%,48%,.3);border-radius:10px;padding:32px;text-align:center;flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:280px}.placeholder-note{color:var(--text-muted);font-style:italic;margin:0;font-size:.9rem}.interactive-role-selector{width:100%;text-align:left}.interactive-role-selector label{font-size:.8rem;font-weight:600;color:var(--text-secondary);display:block;margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}.role-chip-list{display:flex;flex-wrap:wrap;gap:8px}.role-chip{padding:6px 14px;background:#222f4fb3;border:1px solid var(--border-color);border-radius:20px;font-size:.79rem;font-weight:500;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.role-chip:hover{background:#25d0c226;border-color:var(--accent-teal);color:var(--accent-teal);transform:translateY(-1px);box-shadow:0 2px 8px #25d0c233}.role-chip.active{background:linear-gradient(135deg,#25d0c24d,#828df84d);border-color:var(--accent-teal);color:var(--accent-teal);box-shadow:0 2px 12px #25d0c24d}.role-detail-card{height:100%;display:flex;flex-direction:column;box-sizing:border-box}.role-detail-card.empty{justify-content:center;align-items:center;text-align:center;color:var(--text-muted);min-height:400px}.role-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.role-header h4{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary)}.badge{padding:4px 10px;border-radius:6px;font-size:.73rem;font-weight:700;letter-spacing:.04em}.grade-badge{background:#828df82e;color:var(--accent-indigo);border:1px solid hsla(234,89%,74%,.3)}.role-meta{display:flex;gap:16px;font-size:.83rem;color:var(--text-secondary);margin-bottom:18px;border-bottom:1px solid var(--border-color);padding-bottom:14px;flex-wrap:wrap}.role-description{line-height:1.6;margin-bottom:20px;font-size:.92rem;color:var(--text-secondary)}.competencies-section h5{margin:18px 0 10px;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}.competencies-section ul{margin:0;padding-left:20px;line-height:1.6;font-size:.88rem;color:var(--text-secondary)}.tag-group{display:flex;flex-wrap:wrap;gap:6px}.tag{padding:4px 10px;border-radius:10px;font-size:.77rem;font-weight:600}.tag-hard{background:#f6557026;color:var(--accent-rose);border:1px solid hsla(350,90%,65%,.25)}.tag-soft{background:#fab33826;color:var(--accent-amber);border:1px solid hsla(38,95%,60%,.25)}.tag-tool{background:#35e39224;color:var(--accent-emerald);border:1px solid hsla(152,76%,55%,.25)}.market-stats-section{margin-top:24px;border-top:1px solid var(--border-color);padding-top:18px}.market-stats-section h5{margin:0 0 14px;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}.market-cards{display:flex;flex-direction:column;gap:10px}.market-card{border:1px solid var(--border-color);border-radius:8px;padding:12px 14px;background:#151e32b3;transition:all .2s ease}.market-card:hover{border-color:#25d0c266;background:#1c2740b3}.market-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.83rem;font-weight:600;color:var(--text-primary)}.market-card-body{font-size:.83rem;display:grid;grid-template-columns:1fr 1fr;gap:6px;color:var(--text-secondary)}.market-card-body .updated-at{grid-column:span 2;color:var(--text-muted);font-size:.73rem;margin-top:6px}.demand-badge{text-transform:uppercase;font-size:.68rem;letter-spacing:.06em;font-weight:700}.demand-badge[data-demand=high]{background:#f6557026;color:var(--accent-rose);padding:3px 8px;border-radius:5px;border:1px solid hsla(350,90%,65%,.25)}.demand-badge[data-demand=medium]{background:#fab33826;color:var(--accent-amber);padding:3px 8px;border-radius:5px;border:1px solid hsla(38,95%,60%,.25)}.demand-badge[data-demand=low]{background:#52637a4d;color:var(--text-secondary);padding:3px 8px;border-radius:5px;border:1px solid hsla(215,30%,40%,.3)}.heatmap-container{display:flex;flex-direction:column}.heatmap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;border-bottom:1px solid var(--border-color);padding-bottom:12px}.heatmap-header h3{margin:0;border:none;padding:0}.mode-selector{display:flex;align-items:center;gap:6px}.mode-label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.mode-btn{padding:5px 14px;border:1px solid var(--border-color);background:#1c274099;font-size:.78rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .2s ease;color:var(--text-secondary);font-family:var(--font-family)}.mode-btn:hover{background:var(--bg-glass-hover);border-color:var(--accent-teal);color:var(--accent-teal);transform:translateY(-1px)}.mode-btn.active{background:linear-gradient(135deg,#25d0c24d,#828df840);color:var(--accent-teal);border-color:var(--accent-teal);box-shadow:0 2px 10px #25d0c240}.table-responsive{overflow-x:auto;width:100%;border-radius:8px}.heatmap-table{width:100%;border-collapse:collapse;text-align:left;font-size:.83rem}.heatmap-table th,.heatmap-table td{padding:10px 14px;border:1px solid var(--border-color)}.heatmap-table th{background:#151e32e6;font-weight:700;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.heatmap-table tbody tr{transition:all .18s ease;color:var(--text-secondary)}.heatmap-table tbody tr:hover{background:#25d0c212;color:var(--text-primary)}.heatmap-table tbody tr:hover td{border-color:#25d0c233}.heatmap-table tr.selected-row{outline:2px solid var(--accent-teal);outline-offset:-2px;background:#25d0c21a}.role-cell-title{cursor:pointer;display:flex;flex-direction:column}.role-cell-title:hover{color:var(--accent-teal)}.role-cell-title .grade-sub{font-size:.72rem;color:var(--text-muted)}.empty-table,.empty-message{text-align:center;color:var(--text-muted);font-style:italic;padding:24px}.controls-row{display:flex;flex-wrap:wrap;gap:20px}.controls-row>*{flex:1;min-width:280px}.app-header{display:flex;flex-direction:column;gap:2px}.app-footer{text-align:center;padding:16px 0 8px;color:var(--text-muted);font-size:.78rem;border-top:1px solid var(--border-color)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#121a2b80;border-radius:3px}::-webkit-scrollbar-thumb{background:#47618599;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-teal)}@media (max-width: 600px){.dashboard-container{padding:16px 14px;gap:16px}.header-title h1{font-size:1.6rem}.filter-grid{grid-template-columns:1fr 1fr}.controls-row{flex-direction:column}}.search-bar-container{margin-bottom:20px;width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.search-icon{position:absolute;left:14px;width:18px;height:18px;color:var(--text-muted);pointer-events:none;transition:color .2s ease}.search-input{width:100%;padding:12px 40px 12px 42px;border:1px solid var(--border-color);border-radius:10px;font-size:.9rem;color:var(--text-primary);background:var(--bg-input);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .25s ease;font-family:var(--font-family)}.search-input:focus{outline:none;border-color:var(--accent-teal);box-shadow:0 0 15px #25d0c240,0 0 0 3px #25d0c226;background:#1c2740f2}.search-input:focus~.search-icon{color:var(--accent-teal)}.search-clear-btn{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s ease}.search-clear-btn:hover{color:var(--accent-rose)}.map-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;border-bottom:1px solid var(--border-color);padding-bottom:10px}.map-header-row h3{margin:0!important;border-bottom:none!important;padding-bottom:0!important}.map-controls-group{display:flex;gap:6px;align-items:center}.map-ctrl-btn{background:#1c274099;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;padding:6px 12px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;height:32px;font-family:var(--font-family)}.map-ctrl-btn:hover{background:var(--bg-glass-hover);border-color:var(--accent-teal);color:var(--accent-teal);transform:translateY(-1px)}.map-ctrl-btn:active{transform:translateY(0)}.maximize-btn.active{background:#f6557026;color:var(--accent-rose);border-color:#f655704d}.maximize-btn.active:hover{background:#f6557040;color:var(--accent-rose);border-color:var(--accent-rose)}.competency-map-container.maximized{position:fixed!important;top:20px;left:20px;right:20px;bottom:20px;width:calc(100vw - 40px)!important;height:calc(100vh - 40px)!important;z-index:99999;background:#0a0f1ef7!important;backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px);border:1px solid rgba(255,255,255,.15)!important;box-shadow:0 25px 60px #000000f2;padding:30px!important;display:flex;flex-direction:column;animation:fadeIn .25s ease both}.competency-map-container.maximized .competency-map-svg-container{flex-grow:1;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:20px;width:100%;height:100%}.competency-map-svg-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%;min-height:400px;position:relative}@keyframes fadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
