:root{--primary:#6366f1;--primary-hover:#4f46e5;--bg-dark:#0f172a;--bg-card:#1e293bb3;--text-main:#f8fafc;--text-muted:#94a3b8;--border:#ffffff1a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-dark);color:var(--text-main);font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}.app-container{background:radial-gradient(circle at 100% 0,#6366f126,#0000);width:100vw;height:100vh;display:flex}.sidebar{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid var(--border);flex-direction:column;gap:2rem;width:300px;padding:2rem;display:flex;overflow-y:auto}.main-content{flex-direction:column;flex:1;gap:2rem;padding:2rem;display:flex;overflow-y:auto}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:1rem;padding:1.5rem}h1,h2,h3{letter-spacing:-.025em}.btn{cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px)}.data-table{border-collapse:collapse;width:100%;margin-top:1rem}.data-table th{text-align:left;border-bottom:2px solid var(--border);color:var(--text-muted);padding:1rem;font-size:.875rem}.data-table td{border-bottom:1px solid var(--border);padding:1rem;font-size:.875rem}.data-table tr:hover{background:#ffffff08}.filter-group{flex-direction:column;gap:.5rem;display:flex}select,input{border:1px solid var(--border);color:#fff;background:#0003;border-radius:.5rem;width:100%;padding:.75rem}.column-list{flex-direction:column;gap:.25rem;max-height:300px;padding-right:.5rem;display:flex;overflow-y:auto}.column-item{cursor:pointer;align-items:center;gap:.5rem;padding:.25rem;font-size:.875rem;display:flex}.column-item:hover{background:#ffffff0d}.sidebar-nav{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.nav-item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{color:var(--text-main);background:#ffffff0d}.nav-item.active{background:var(--primary);color:#fff}.sidebar-divider{background:var(--border);height:1px;margin-bottom:2rem}.search-input{border:1px solid var(--border);color:#fff;background:#0003;border-radius:.5rem;outline:none;width:100%;padding:.75rem}.dict-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.dict-card{flex-direction:column;gap:1rem;display:flex;border-left:4px solid var(--primary)!important}.dict-label{color:var(--primary);margin:0;font-size:.9rem;line-height:1.4}.dict-timeline{flex-direction:column;gap:.75rem;display:flex}.timeline-item{background:#ffffff08;border-radius:.4rem;align-items:center;gap:1rem;padding:.5rem;display:flex}.year-pill{background:var(--primary);color:#fff;text-align:center;border-radius:1rem;min-width:45px;padding:.2rem .5rem;font-size:.75rem;font-weight:700}.var-info{flex-direction:column;display:flex}.var-code{color:var(--text-main);font-family:monospace;font-weight:700}.var-meta{color:var(--text-muted);font-size:.7rem}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{flex-direction:column;width:90%;max-width:800px;max-height:80vh;padding:0;display:flex}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;padding:1.5rem;display:flex}.btn-icon{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.4rem;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.btn-icon:hover{color:var(--text-main);background:#ffffff1a}.small-input{background:#0000004d;padding:.5rem;font-size:.8rem}.loader{height:200px;color:var(--primary);justify-content:center;align-items:center;font-weight:500;display:flex}.btn-secondary{color:#fff;background:#ffffff1a}.th-tooltip{cursor:help;position:relative}.th-tooltip .th-label{color:#e2e8f0;border:1px solid var(--primary);white-space:nowrap;white-space:normal;z-index:100;pointer-events:none;background:#1e293b;border-radius:.5rem;max-width:350px;padding:.5rem .75rem;font-size:.75rem;font-weight:400;line-height:1.4;display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0006}.th-tooltip:hover .th-label{display:block}.th-tooltip:after{content:"";background:var(--primary);vertical-align:super;opacity:.6;border-radius:50%;width:4px;height:4px;margin-left:4px;display:inline-block}.tooltip-popup{color:#e2e8f0;border:1px solid var(--primary);white-space:normal;z-index:9999;pointer-events:none;background:#1e293b;border-radius:.5rem;max-width:300px;padding:.5rem .75rem;font-size:.75rem;position:fixed;transform:translate(-50%);box-shadow:0 8px 24px #0006}.comparison-table{margin-top:0}.comparison-table th{text-align:center;background:#6366f114;padding:.75rem;font-size:.8rem}.comparison-table th:first-child{text-align:left}.comparison-table td{vertical-align:top;padding:.5rem .75rem;font-size:.8rem}.cell-content{flex-direction:column;gap:.15rem;display:flex}.cell-label{color:var(--text-main);font-size:.8rem;line-height:1.3}.cell-table{color:var(--text-muted);font-family:monospace;font-size:.65rem}.cell-empty{background:#00000026}.cell-empty-clickable{cursor:pointer}.cell-empty-clickable:hover{border-left-color:#6366f14d;background:#6366f114!important}.cell-empty-inner{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.75rem;font-style:italic;display:flex}.cell-empty-plus{opacity:0;color:var(--primary);transition:opacity .15s}.cell-empty-clickable:hover .cell-empty-plus{opacity:1}.cell-pending{background:#22c55e26!important;border-left:2px solid #22c55e99!important}.conflict-row td{border-left-color:#eab308}.conflict-row td:first-child{color:#eab308}.global-search-bar{margin-top:1rem;position:relative}.global-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.global-search-input{color:#fff;border-radius:.5rem;outline:none;width:100%;font-size:.85rem;transition:border-color .2s;border:1px solid var(--border)!important;background:#00000040!important;padding:.65rem 2.5rem .65rem 2.25rem!important}.global-search-input:focus{box-shadow:0 0 0 2px #6366f126;border-color:var(--primary)!important}.global-search-input:disabled{opacity:.5;cursor:not-allowed}.search-result-summary{color:var(--primary);background:#6366f11a;border:1px solid #6366f133;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.8rem;display:flex}.mapping-page{flex-direction:column;gap:1.5rem;display:flex}.mapping-list{flex-direction:column;gap:1rem;display:flex}.mapping-card{border:1px solid var(--border);background:#0003;border-radius:.75rem;padding:1rem;transition:border-color .2s}.mapping-card:hover{border-color:#6366f14d}.mapping-header{align-items:flex-start;gap:.75rem;margin-bottom:.75rem;display:flex}.mapping-name-input{font-weight:600;background:#6366f11a!important;border:1px solid #6366f14d!important;padding:.5rem .75rem!important;font-size:.9rem!important}.mapping-entries{flex-direction:column;gap:.4rem;display:flex}.mapping-entry{align-items:center;gap:.5rem;padding:.25rem 0;display:flex}.mapping-entry input{background:#0000004d;padding:.4rem .6rem;font-size:.8rem}.mapping-entry .year-pill{flex-shrink:0;min-width:50px}.cell-clickable{cursor:pointer;border-left:3px solid #0000;transition:all .15s}.cell-clickable:hover{border-left-color:var(--primary);background:#6366f11a!important}.cell-conflict{border-left-color:#eab30866}.cell-conflict:hover{border-left-color:#eab308!important}.cell-remapped{background:#22c55e14!important;border-left-color:#22c55e!important}.cell-remapped:hover{background:#22c55e26!important}.cell-remap-badge{background:#22c55e26;border-radius:.3rem;align-items:center;gap:.3rem;width:fit-content;margin-bottom:.2rem;padding:.15rem .4rem;font-size:.7rem;display:flex}.remap-from{color:var(--text-muted);font-family:monospace;text-decoration:line-through}.remap-to{color:#22c55e;font-family:monospace;font-weight:700}.btn-undo{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.2rem;align-items:center;margin-left:.2rem;padding:.1rem;display:flex}.btn-undo:hover{color:#ef4444;background:#ef444426}.legend-conflict{color:#eab308;font-weight:600}.legend-remapped{color:#22c55e;font-weight:600}.save-success{color:#22c55e;text-align:center;background:#22c55e26;border:1px solid #22c55e4d;border-radius:.75rem;padding:.75rem 1.5rem;font-size:.875rem}.picker-modal{border:1px solid var(--border);background:#1e293b;border-radius:1rem;flex-direction:column;width:90%;max-width:700px;max-height:85vh;display:flex;box-shadow:0 24px 64px #00000080}.picker-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem;display:flex}.picker-header h3{margin-bottom:.35rem}.picker-subtitle{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.8rem;display:flex}.picker-subtitle code{color:var(--primary);background:#6366f133;border-radius:.25rem;padding:.1rem .4rem;font-weight:700}.picker-current-label{text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:.7rem;overflow:hidden}.picker-search{border-bottom:1px solid var(--border);padding:.75rem 1.5rem;position:relative}.picker-search-icon{color:var(--text-muted);position:absolute;top:50%;left:2rem;transform:translateY(-50%)}.picker-search-input{color:#fff;border-radius:.5rem;outline:none;width:100%;font-size:.85rem;border:1px solid var(--border)!important;background:#0000004d!important;padding:.75rem .75rem .75rem 2.25rem!important}.picker-search-input:focus{box-shadow:0 0 0 2px #6366f133;border-color:var(--primary)!important}.picker-count{color:var(--text-muted);border-bottom:1px solid var(--border);padding:.5rem 1.5rem;font-size:.75rem}.picker-results{flex:1;padding:.5rem 0;overflow-y:auto}.picker-group{margin-bottom:.5rem}.picker-group-header{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;z-index:1;background:#6366f10d;align-items:center;gap:.5rem;padding:.5rem 1.5rem;font-size:.7rem;font-weight:700;display:flex;position:sticky;top:0}.picker-group-count{color:var(--text-muted);font-weight:400}.picker-item{cursor:pointer;border-left:3px solid #0000;grid-template-columns:120px 1fr auto;align-items:center;gap:.75rem;padding:.6rem 1.5rem;transition:all .1s;display:grid}.picker-item:hover{border-left-color:var(--primary);background:#6366f11a}.picker-item-current{border-left-color:var(--primary);background:#6366f114}.picker-item-left{align-items:center;gap:.4rem;display:flex}.picker-item-code{color:var(--text-main);font-family:monospace;font-size:.85rem;font-weight:700}.picker-item-badge{background:var(--primary);color:#fff;border-radius:.2rem;padding:.1rem .3rem;font-size:.6rem;font-weight:600}.picker-item-label{color:var(--text-muted);font-size:.8rem;line-height:1.3}.picker-item-table{color:var(--text-muted);opacity:.6;font-family:monospace;font-size:.65rem}.picker-empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:3rem;display:flex}.converter-page{flex-direction:column;gap:1.5rem;display:flex}.dta-dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--bg-card);border-radius:1rem;padding:4rem 2rem;transition:all .2s}.dta-dropzone:hover{border-color:var(--primary);background:#6366f10d}.dta-dropzone-active{transform:scale(1.01);border-color:var(--primary)!important;background:#6366f11a!important}.dta-info-card{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.dta-info-grid{flex-wrap:wrap;gap:2rem;display:flex}.dta-info-item{flex-direction:column;gap:.2rem;display:flex}.dta-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.dta-info-value{font-size:.95rem;font-weight:600}.dta-actions{gap:.75rem;display:flex}.dta-var-list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.4rem;max-height:300px;display:grid;overflow-y:auto}.dta-var-item{background:#00000026;border-radius:.3rem;align-items:center;gap:.75rem;padding:.4rem .6rem;font-size:.8rem;display:flex}.dta-var-item code{color:var(--primary);min-width:80px;font-family:monospace;font-size:.8rem;font-weight:700}.dta-var-item span{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.login-container{background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";background:conic-gradient(from 0deg at 50% 50%, var(--primary) 0deg, transparent 60deg, transparent 300deg, var(--primary) 360deg);opacity:.03;width:200%;height:200%;animation:20s linear infinite rotate;position:absolute}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-card{z-index:1;border-radius:1.5rem;width:100%;max-width:420px;padding:3rem;animation:.5s fadeIn}.glass{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#1e293bb3;border:1px solid #ffffff1a;box-shadow:0 25px 50px -12px #00000080}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{background:#6366f11a;border-radius:1rem;margin-bottom:1.5rem;padding:1rem;display:inline-flex}.login-header h2{margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.login-header p{color:var(--text-muted);font-size:.9rem}.login-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;display:flex}.login-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.75rem;margin-top:1rem;padding:1rem;font-size:1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #6366f14d}.login-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.login-btn:disabled{opacity:.7;cursor:wait}.login-footer{text-align:center;color:var(--text-muted);margin-top:2rem;font-size:.875rem}.btn-link{color:var(--primary);cursor:pointer;font-weight:600;font-size:inherit;background:0 0;border:none;align-items:center;gap:.25rem;padding:0;display:inline-flex}.btn-link:hover{text-decoration:underline}.auth-error{color:#ef4444;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:.5rem;padding:.75rem;font-size:.85rem;animation:.4s shake}.auth-error.success{color:#22c55e;background:#22c55e1a;border-color:#22c55e33}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.user-profile{background:#ffffff08;border-radius:.75rem;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem .5rem;display:flex}.user-info{align-items:center;gap:.75rem;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.user-details{flex-direction:column;display:flex}.username{color:var(--text-main);font-size:.85rem;font-weight:600}.user-role{color:var(--text-muted);font-size:.7rem}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.4rem;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.logout-btn:hover{color:#ef4444;background:#ef44441a}
