.basic-metric-detail{max-width:900px;margin:0 auto}.basic-metric-detail .detail-header{display:flex;align-items:center;gap:22px;margin-bottom:35px}.basic-metric-detail .detail-header h1{font-size:2.2em;color:#6b4c7a;margin:0;text-shadow:0 2px 10px rgba(255,158,199,.2)}.value-section{background:linear-gradient(135deg,#ff9ec7,#c9a0ff,#e8c5ff);background-size:200% 200%;border-radius:30px;padding:40px;color:#fff;margin-bottom:35px;box-shadow:0 10px 40px #ff9ec766,0 0 60px #c9a0ff4d;animation:shimmer 5s ease-in-out infinite;position:relative;overflow:hidden}@keyframes shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.value-row{display:flex;align-items:center;justify-content:space-around;gap:30px;margin-bottom:25px}.value-display{display:flex;flex-direction:column;align-items:center;gap:8px}.value-number{font-size:4em;font-weight:700;text-shadow:0 0 30px rgba(255,255,255,.5),0 4px 15px rgba(0,0,0,.1)}.value-unit{font-size:1.4em;opacity:.95;font-weight:600}.circular-progress-container{position:relative;display:flex;align-items:center;justify-content:center}.circular-progress{transform:rotate(0);filter:drop-shadow(0 4px 15px rgba(255,107,157,.3))}.circular-progress-content{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.percentile-label{font-size:.85em;opacity:.9;font-weight:500}.percentile-value{font-size:2em;font-weight:700;text-shadow:0 2px 10px rgba(0,0,0,.1)}.normal-range{display:flex;align-items:center;justify-content:center;gap:12px;font-size:1.1em}.range-label{opacity:.9;font-weight:500}.range-value{background:#ffffff40;padding:8px 20px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:600}.basic-metric-detail .detail-section{background:linear-gradient(135deg,#fff,#ffeef8);border-radius:25px;padding:28px;margin-bottom:22px;box-shadow:0 6px 25px #ff9ec71f,inset 0 0 20px #ffffff80;border:2px solid rgba(255,158,199,.1)}.basic-metric-detail .detail-section h2{font-size:1.25em;color:#6b4c7a;margin-bottom:18px;padding-bottom:12px;border-bottom:3px solid rgba(255,158,199,.2);display:flex;align-items:center;gap:10px}.basic-metric-detail .detail-section h2:before{content:"";display:inline-block;width:8px;height:8px;background:linear-gradient(135deg,#ff6b9d,#c9a0ff);border-radius:50%}.description-box,.interpretation-box{background:linear-gradient(135deg,#f5e6ff,#e8d5f9);padding:22px;border-radius:18px;line-height:1.9;color:#6b4c7a}.interpretation-box{background:linear-gradient(135deg,#a0d4ff40,#c9a0ff40);border-left:5px solid #a0d4ff;box-shadow:0 4px 15px #a0d4ff26}.functions-list{display:grid;gap:14px}.function-item{display:flex;align-items:flex-start;gap:14px;padding:15px 18px;background:linear-gradient(135deg,#f5e6ff,#e8d5f9);border-radius:15px;transition:all .3s ease}.function-item:hover{transform:translate(5px);box-shadow:0 4px 15px #c9a0ff33}.function-bullet{color:#ff6b9d;font-weight:700;font-size:1.2em}.basic-metric-detail .references-list{display:flex;flex-direction:column;gap:12px}.basic-metric-detail .reference-item{display:flex;gap:12px;font-size:.9em;color:#7a5a8a;padding:12px;background:linear-gradient(135deg,#f5e6ff,#e8d5f9);border-radius:12px}.basic-metric-detail .ref-number{color:#ff6b9d;font-weight:700;flex-shrink:0}.basic-metric-detail .detail-footer{padding:22px;background:linear-gradient(135deg,#fff8e1,#ffecb3);border-radius:20px;border-left:5px solid #ffb74d;margin-top:35px;box-shadow:0 4px 20px #ffb74d26}.basic-metric-detail .detail-footer p{color:#f57c00;margin:0;font-size:.9em;line-height:1.7}@media (max-width: 768px){.value-row{flex-direction:column;gap:25px}.value-number{font-size:3em}.value-section{padding:30px 20px}.circular-progress-container svg{width:120px;height:120px}.percentile-value{font-size:1.6em}}.index-detail-page{max-width:900px;margin:0 auto}.back-button{display:inline-flex;align-items:center;gap:10px;padding:12px 24px;background:linear-gradient(135deg,#fff,#ffeef8);border:2px solid #ff9ec7;border-radius:30px;color:#ff6b9d;font-size:.95em;font-weight:700;cursor:pointer;transition:all .3s ease;margin-bottom:28px;box-shadow:0 4px 15px #ff9ec733}.back-button:hover{background:linear-gradient(135deg,#ff9ec7,#c9a0ff);color:#fff;transform:translate(-5px);box-shadow:0 6px 25px #ff9ec766,0 0 40px #c9a0ff4d}.detail-header{margin-bottom:35px}.detail-header h1{font-size:2.2em;color:#6b4c7a;margin-bottom:8px;text-shadow:0 2px 10px rgba(255,158,199,.2)}.detail-header h1:before{content:"✨ "}.detail-name-en{color:#b8a0c8;font-size:.95em;font-style:italic}.detail-score-section{background:linear-gradient(135deg,#fff,#ffeef8,#f5e6ff);padding:35px;border-radius:30px;box-shadow:0 8px 35px #ff9ec733,inset 0 0 30px #ffffff80;border:2px solid rgba(255,158,199,.2);margin-bottom:35px;position:relative;overflow:hidden}.detail-score-section:before{content:"💖";position:absolute;top:20px;right:25px;font-size:1.5em;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.score-display{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.score-main{display:flex;flex-direction:column}.score-number{font-size:4.5em;font-weight:700;background:linear-gradient(135deg,#ff6b9d,#c44dff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;text-shadow:0 0 30px rgba(255,107,157,.3)}.score-unit{font-size:1em;color:#b8a0c8;margin-top:8px;font-weight:600}.score-percentile{display:flex;flex-direction:column;align-items:center;gap:12px}.percentile-circle{width:110px;height:110px;border-radius:50%;border:6px solid;display:flex;align-items:center;justify-content:center;font-size:1.15em;font-weight:700;background:linear-gradient(135deg,#fff,#ffeef8);box-shadow:0 6px 25px #ff9ec74d,inset 0 0 15px #ffffff80;animation:glow-pulse 3s ease-in-out infinite}@keyframes glow-pulse{0%,to{box-shadow:0 6px 25px #ff9ec74d,inset 0 0 15px #ffffff80}50%{box-shadow:0 10px 35px #ff9ec780,inset 0 0 20px #ffffffb3}}.percentile-label{padding:8px 20px;border-radius:25px;color:#fff;font-weight:700;font-size:.9em;box-shadow:0 4px 15px #0000001a}.percentile-bar-large{margin-top:25px}.bar-track{position:relative;height:22px;background:linear-gradient(90deg,#ffe4ec,#e8d5f9,#d4e5ff);border-radius:12px;overflow:visible;box-shadow:inset 0 2px 8px #0000000d}.bar-fill{height:100%;border-radius:12px;transition:width .5s ease;box-shadow:0 0 15px #ff9ec780}.bar-marker{position:absolute;top:-6px;width:34px;height:34px;background:linear-gradient(135deg,#fff,#ffeef8);border:5px solid #ff6b9d;border-radius:50%;transform:translate(-50%);box-shadow:0 4px 15px #ff6b9d66,0 0 25px #ff9ec74d}.bar-labels{display:flex;justify-content:space-between;margin-top:10px;font-size:.85em;color:#b8a0c8;font-weight:500}.detail-section{background:linear-gradient(135deg,#fff,#ffeef8);padding:28px;border-radius:25px;box-shadow:0 6px 25px #ff9ec71f,inset 0 0 20px #ffffff80;border:2px solid rgba(255,158,199,.1);margin-bottom:22px}.detail-section h2{font-size:1.25em;color:#6b4c7a;margin-bottom:18px;padding-bottom:12px;border-bottom:3px solid rgba(255,158,199,.2)}.detail-section h2:before{content:"🎀 "}.interpretation-box{background:linear-gradient(135deg,#a0d4ff33,#c9a0ff33);padding:22px;border-radius:18px;border-left:5px solid #a0d4ff;box-shadow:0 4px 15px #a0d4ff26}.interpretation-box p{color:#5a7a9a;line-height:1.9;margin:0}.threshold-box{background:linear-gradient(135deg,#f5e6ff,#e8d5f9);padding:18px 22px;border-radius:15px}.threshold-box code{font-family:SF Mono,Monaco,monospace;font-size:.95em;color:#6b4c7a}.method-box{display:flex;flex-direction:column;gap:18px}.method-item{display:flex;flex-direction:column;gap:10px}.method-label{font-weight:700;color:#7a5a8a;font-size:.9em}.formula{background:linear-gradient(135deg,#2d1b4e,#1a1a2e);color:#c9a0ff;padding:15px 20px;border-radius:15px;font-family:SF Mono,Monaco,monospace;font-size:.9em;overflow-x:auto;box-shadow:0 4px 15px #2d1b4e4d}.regions-list{display:flex;flex-wrap:wrap;gap:12px}.region-chip{background:linear-gradient(135deg,#ff9ec7,#c9a0ff);color:#fff;padding:10px 18px;border-radius:22px;font-size:.9em;font-weight:600;box-shadow:0 4px 12px #ff9ec74d,0 0 20px #c9a0ff33;transition:all .3s ease}.region-chip:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #ff9ec766,0 0 30px #c9a0ff4d}.table-container{overflow-x:auto;margin-bottom:18px;border-radius:15px}.zscore-table{width:100%;border-collapse:collapse;font-size:.9em;min-width:600px}.zscore-table th,.zscore-table td{padding:14px 18px;text-align:center;border-bottom:2px solid rgba(255,158,199,.1)}.zscore-table th{background:linear-gradient(135deg,#ff9ec7,#c9a0ff);color:#fff;font-weight:700;position:sticky;top:0}.zscore-table tr:hover{background:linear-gradient(135deg,#ff9ec714,#c9a0ff14)}.zscore-table .region-name{text-align:left;font-weight:700;color:#6b4c7a}.zscore-table .positive{color:#4caf50;font-weight:700}.zscore-table .negative{color:#ff6b9d;font-weight:700}.zscore-table .weights-cell{font-family:monospace;font-size:.85em;color:#7a5a8a}.table-note{color:#7a5a8a;font-size:.85em;margin:0;padding:12px;background:linear-gradient(135deg,#f5e6ff,#e8d5f9);border-radius:12px}.references-list{display:flex;flex-direction:column;gap:12px}.reference-item{display:flex;gap:12px;padding:12px;background:linear-gradient(135deg,#f5e6ff,#e8d5f9);border-radius:12px}.ref-number{color:#ff6b9d;font-weight:700;flex-shrink:0}.ref-text{color:#6b4c7a}.detail-footer{padding:22px;background:linear-gradient(135deg,#fff8e1,#ffecb3);border-radius:20px;border-left:5px solid #ffb74d;margin-top:35px;box-shadow:0 4px 20px #ffb74d26}.detail-footer p{color:#f57c00;margin:0;font-size:.9em}@media (max-width: 768px){.score-display{flex-direction:column;gap:25px;text-align:center}.score-number{font-size:3.5em}.percentile-circle{width:90px;height:90px;font-size:.95em}}.lateralization-bar-large{margin-top:25px}.lat-bar-track{position:relative;height:22px;background:linear-gradient(to right,#a0d4ff,#c9a0ff,#ff9ec7,#c9a0ff,#a0d4ff);border-radius:12px;overflow:visible;box-shadow:0 0 20px #ff9ec74d}.lat-bar-center-line{position:absolute;left:50%;top:-4px;width:4px;height:30px;background:#fff;transform:translate(-50%);box-shadow:0 0 10px #fffc;z-index:1;border-radius:2px}.lat-bar-track .lat-bar-marker{position:absolute;top:-6px;width:34px;height:34px;background:linear-gradient(135deg,#fff,#ffeef8);border:5px solid #6b4c7a;border-radius:50%;transform:translate(-50%);box-shadow:0 4px 15px #6b4c7a66,0 0 25px #ff9ec74d;z-index:2}.lat-bar-labels{display:flex;justify-content:space-between;margin-top:12px;font-size:.95em;font-weight:700}.lat-label-left{color:#5a8ac4}.lat-label-center{color:#9a7aaa}.lat-label-right{color:#ff6b9d}.eye-contact-tip{background:linear-gradient(135deg,#fff5f8,#f0f8ff);border-radius:20px;padding:20px;margin-top:20px;border:2px solid #ffb6c1}.eye-contact-tip h2{color:#e91e63;margin-bottom:15px}.tip-box{background:#fff;border-radius:15px;padding:20px;box-shadow:0 4px 15px #ffb6c133;border-left:4px solid #ff6b9d}.tip-box p{color:#5a4a6a;line-height:1.8;margin:0;font-size:.95em}.page-wrapper,.page-wrapper.fade-in{animation:fadeInUp .4s ease-out}.page-wrapper.fade-out{animation:fadeOutDown .3s ease-in forwards}.page-wrapper.clearing{animation:fadeOut .5s ease-out forwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOutDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.combined-report{max-width:1100px;margin:0 auto;padding:30px 20px}.combined-loading,.combined-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#7a5a8a}.loading-spinner{width:60px;height:60px;border:5px solid rgba(255,158,199,.2);border-top-color:#ff9ec7;border-right-color:#c9a0ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px;box-shadow:0 0 20px #ff9ec74d}@keyframes spin{to{transform:rotate(360deg)}}.report-header{text-align:center;margin-bottom:40px}.report-header h1{font-size:2.5em;color:#6b4c7a;margin-bottom:12px;text-shadow:0 2px 15px rgba(255,158,199,.3)}.report-header h1:before{content:"👑 "}.report-header h1:after{content:" 👑"}.report-subject{display:flex;align-items:center;justify-content:center;gap:10px;color:#6b4c7a;font-size:1.1em;margin-bottom:8px}.report-subject strong{color:#ff6b9d;font-weight:700}.report-date{color:#b8a0c8;font-size:.9em}.hero-section{position:relative;margin-bottom:30px;padding:40px 20px;background:transparent;min-height:300px}.hero-section.drop-zone{display:flex;align-items:center;justify-content:center;border:3px dashed rgba(255,158,199,.4);border-radius:30px;transition:all .3s ease}.hero-section.drop-zone.dragging{border-color:#ff6b9d;background:#ff9ec71a;transform:scale(1.02)}.drop-zone-content{text-align:center;color:#9a7aaa}.drop-icon{font-size:5em;margin-bottom:20px;animation:bounce-emoji 2s ease-in-out infinite}@keyframes bounce-emoji{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.drop-zone-content h2{font-size:1.5em;color:#6b4c7a;margin-bottom:10px}.drop-zone-content p{font-size:1em;opacity:.8}.upload-divider{display:flex;align-items:center;margin:30px 0;color:#b8a0c8;font-size:.95em}.upload-divider:before,.upload-divider:after{content:"";flex:1;height:2px;background:linear-gradient(90deg,transparent,rgba(255,158,199,.3),transparent)}.upload-divider span{padding:0 20px;font-weight:600}.github-import-section{background:linear-gradient(135deg,#fff,#ffeef8,#f5e6ff);border-radius:25px;padding:30px;box-shadow:0 4px 20px #ff9ec726;border:2px solid rgba(255,158,199,.1)}.github-import-section h3{color:#6b4c7a;font-size:1.2em;margin-bottom:18px;display:flex;align-items:center;gap:10px}.github-import-section h3:before{content:"🔗"}.github-input-row{display:flex;gap:12px}.github-url-input{flex:1;padding:14px 20px;border:2px solid rgba(255,158,199,.3);border-radius:15px;font-size:.95em;background:#fff;color:#6b4c7a;transition:all .3s ease}.github-url-input:focus{outline:none;border-color:#ff9ec7;box-shadow:0 0 15px #ff9ec733}.github-url-input::placeholder{color:#c9a0ff;opacity:.7}.github-url-input:disabled{background:#f5f5f5;opacity:.7}.github-import-btn{padding:14px 28px;background:linear-gradient(135deg,#ff9ec7,#c9a0ff);border:none;border-radius:15px;color:#fff;font-size:.95em;font-weight:700;cursor:pointer;transition:all .3s ease;white-space:nowrap}.github-import-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff9ec766}.github-import-btn:disabled{opacity:.6;cursor:not-allowed}.import-error{color:#ff6b9d;font-size:.9em;margin-top:12px;padding:10px 15px;background:#ff6b9d1a;border-radius:10px;border-left:3px solid #ff6b9d}.basic-section,.indices-section{margin-bottom:50px}.basic-section h2,.indices-section h2{font-size:1.5em;margin-bottom:10px;color:#6b4c7a}.basic-section h2:before{content:"📊 "}.section-subtitle,.section-hint{color:#b8a0c8;font-size:.95em;margin-bottom:22px}.basic-metrics-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.basic-metric-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px;cursor:pointer;transition:all .3s ease;border-radius:20px;background:linear-gradient(135deg,#fff,#ffeef8,#f5e6ff);box-shadow:0 4px 20px #ff9ec726;border:2px solid rgba(255,158,199,.1);position:relative;overflow:hidden}.basic-metric-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.basic-metric-item:hover:before{left:100%}.basic-metric-item:hover{transform:translateY(-5px);box-shadow:0 10px 30px #ff9ec740;border-color:#ff9ec7}.mini-circular-progress{position:relative;display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin-bottom:12px}.mini-circular-progress svg{filter:drop-shadow(0 2px 6px rgba(255,107,157,.25))}.mini-percentile{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.85em;font-weight:700;color:#ff6b9d}.mini-percentile.rarity-text{font-size:.7em;white-space:nowrap;display:flex;flex-direction:column;align-items:center;line-height:1.1}.rarity-label{font-size:.6em;color:#b8a0c8;font-weight:500}.bm-value{font-size:1.8em;font-weight:700;color:#ff6b9d;line-height:1.2;margin-bottom:6px}.bm-value small{font-size:.5em;color:#c9a0ff;font-weight:600;margin-left:2px}.bm-label{font-size:.85em;color:#9a7aaa;font-weight:600}.indices-grid{display:flex;flex-direction:column;gap:12px}.index-card-clickable{background:linear-gradient(135deg,#fff,#ffeef8,#f5e6ff);padding:14px 20px;border-radius:16px;box-shadow:0 4px 20px #ff9ec726;border:2px solid rgba(255,158,199,.15);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.index-card-clickable:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.index-card-clickable:hover:before{left:100%}.index-card-clickable:hover{transform:translateY(-3px);box-shadow:0 8px 30px #ff9ec740;border-color:#ff9ec7}.card-content{display:flex;align-items:center;gap:14px}.card-content .mini-circular-progress{flex-shrink:0;margin-bottom:0}.card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.card-info .card-name{font-weight:700;font-size:.95em;color:#6b4c7a;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.card-zscore{font-size:.75em;color:#b8a0c8;font-weight:500}.card-content .card-badge{padding:6px 14px;border-radius:12px;color:#fff;font-size:.75em;font-weight:600;flex-shrink:0;max-width:none;line-height:1.4;text-align:center}.special-section{margin-bottom:50px}.special-section h2{font-size:1.5em;margin-bottom:22px;color:#6b4c7a}.special-section h2:before{content:"✨ "}.special-cards{display:flex;flex-direction:column;gap:15px}.special-card{display:flex;align-items:center;gap:18px;padding:20px 28px;background:linear-gradient(135deg,#fff,#ffeef8,#f5e6ff);border-radius:20px;border-left:5px solid #ff9ec7;box-shadow:0 4px 20px #ff9ec726;transition:all .3s ease}.special-card:hover{transform:translate(5px);box-shadow:0 6px 25px #ff9ec740}.special-icon{font-size:1.8em;flex-shrink:0}.special-text{font-weight:600;color:#ff6b9d;font-size:1.05em;line-height:1.6}.suggestions-section{margin-bottom:50px}.suggestions-section h2{font-size:1.5em;margin-bottom:22px;color:#6b4c7a}.suggestions-section h2:before{content:"💡 "}.suggestions-list{display:flex;flex-direction:column;gap:15px}.suggestion-item{display:flex;align-items:flex-start;gap:15px;padding:20px 25px;background:linear-gradient(135deg,#ff9ec71a,#c9a0ff1a);border-radius:20px;border-left:5px solid #ff9ec7;transition:all .3s ease}.suggestion-item:hover{transform:translate(5px);box-shadow:0 4px 20px #ff9ec733}.suggestion-icon{font-size:1.3em;flex-shrink:0}.suggestion-item p{color:#6b4c7a;line-height:1.7;margin:0}.report-footer{padding:22px;background:linear-gradient(135deg,#fff8e1,#ffecb3);border-radius:20px;border-left:5px solid #ffb74d;box-shadow:0 4px 20px #ffb74d26}.report-footer p{color:#f57c00;line-height:1.7;margin:0;font-size:.9em}@media (max-width: 768px){.basic-metrics-card{grid-template-columns:repeat(2,1fr)}.bm-icon{font-size:2em}.bm-value{font-size:1.5em}.indices-grid{grid-template-columns:1fr}.card-content .card-badge{max-width:70px;font-size:.65em}.github-input-row{flex-direction:column}.github-import-btn{width:100%}.github-import-section{padding:20px}}.language-switcher{position:relative}.language-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,#ffffff4d,#ffffff1a);border:2px solid rgba(255,255,255,.4);border-radius:20px;cursor:pointer;transition:all .3s ease;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #ff9ec733}.language-button:hover{background:linear-gradient(135deg,#ffffff80,#ffffff4d);transform:translateY(-2px);box-shadow:0 6px 20px #ff9ec74d,0 0 30px #c9a0ff33}.language-button .flag{font-size:1.3em}.language-button .arrow{font-size:.8em;opacity:.9;transition:transform .3s ease}.language-switcher:hover .language-button .arrow{transform:rotate(180deg)}.language-dropdown{position:absolute;top:100%;right:0;margin-top:10px;background:linear-gradient(135deg,#fff,#ffeef8,#f5e6ff);border-radius:20px;box-shadow:0 8px 30px #ff9ec74d,0 0 50px #c9a0ff33;overflow:hidden;z-index:1000;min-width:160px;border:2px solid rgba(255,158,199,.2);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .25s ease}.language-switcher:hover .language-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.language-option{display:flex;align-items:center;gap:12px;width:100%;padding:14px 18px;border:none;background:none;cursor:pointer;transition:all .2s ease;text-align:left}.language-option:hover{background:linear-gradient(135deg,#ff9ec726,#c9a0ff26)}.language-option.active{background:linear-gradient(135deg,#ff9ec7,#c9a0ff)}.language-option.active .name{color:#fff;font-weight:700}.language-option .flag{font-size:1.4em}.language-option .name{color:#6b4c7a;font-size:.95em;font-weight:600}.language-option:not(.active):hover .name{color:#ff6b9d}.admin-login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-login-modal{background:linear-gradient(135deg,#fff5f8,#fff);border-radius:20px;padding:32px;width:90%;max-width:400px;box-shadow:0 20px 60px #ff6b9d4d;position:relative;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.admin-login-modal .close-btn{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#999;transition:color .2s}.admin-login-modal .close-btn:hover{color:#ff6b9d}.admin-login-modal h2{margin:0 0 24px;text-align:center;color:#333;font-size:1.5rem}.admin-login-modal .form-group{margin-bottom:20px}.admin-login-modal label{display:block;margin-bottom:8px;color:#666;font-size:.9rem}.admin-login-modal input{width:100%;padding:12px 16px;border:2px solid #ffe0eb;border-radius:12px;font-size:1rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.admin-login-modal input:focus{outline:none;border-color:#ff6b9d;box-shadow:0 0 0 4px #ff6b9d1a}.admin-login-modal input:disabled{background:#f5f5f5;cursor:not-allowed}.admin-login-modal .error-message{background:#fff0f0;color:#e74c3c;padding:12px;border-radius:8px;margin-bottom:16px;font-size:.9rem;text-align:center}.admin-login-modal .login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#ff6b9d,#c9a0ff);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.admin-login-modal .login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #ff6b9d66}.admin-login-modal .login-btn:disabled{opacity:.7;cursor:not-allowed}.admin-login-modal .login-hint{margin:16px 0 0;text-align:center;color:#999;font-size:.8rem}.admin-panel{padding:24px;max-width:1400px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #ffe0eb}.admin-header h1{margin:0;color:#333;font-size:1.8rem}.logout-btn{padding:10px 20px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.logout-btn:hover{background:#ff6b9d;color:#fff;border-color:#ff6b9d}.github-token-section{background:linear-gradient(135deg,#fff5f8,#f8f0ff);border-radius:16px;padding:20px;margin-bottom:20px}.github-token-section label{display:block;font-weight:600;color:#333;margin-bottom:12px}.token-input-row{display:flex;gap:12px;margin-bottom:12px}.token-input{flex:1;padding:12px 16px;border:2px solid #ffe0eb;border-radius:12px;font-size:.95rem;font-family:monospace;transition:border-color .2s}.token-input:focus{outline:none;border-color:#ff6b9d}.save-token-btn{padding:12px 24px;background:linear-gradient(135deg,#ff6b9d,#c9a0ff);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s}.save-token-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ff6b9d66}.save-token-btn:disabled{opacity:.5;cursor:not-allowed}.token-saved-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#e8f8e8;border-radius:12px;margin-bottom:12px}.token-saved-indicator{color:#27ae60;font-weight:600}.token-preview{font-family:monospace;color:#666;background:#f0f0f0;padding:4px 8px;border-radius:6px}.edit-token-btn,.cancel-edit-btn{padding:8px 16px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:.85rem;transition:all .2s}.edit-token-btn:hover{background:#ff6b9d;color:#fff;border-color:#ff6b9d}.cancel-edit-btn{background:#f5f5f5}.cancel-edit-btn:hover{background:#e0e0e0}.token-hint{margin:0;font-size:.8rem;color:#888;line-height:1.6}.token-hint code{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:.75rem}.admin-actions{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.action-btn{padding:12px 24px;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;background:#f0f0f0;color:#333}.action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.action-btn:disabled{opacity:.6;cursor:not-allowed}.action-btn.primary{background:linear-gradient(135deg,#ff6b9d,#c9a0ff);color:#fff}.action-btn.primary:hover:not(:disabled){box-shadow:0 4px 16px #ff6b9d66}.action-btn.recalculate{background:linear-gradient(135deg,#3498db,#2ecc71);color:#fff}.action-btn.recalculate:hover:not(:disabled){box-shadow:0 4px 16px #3498db66}.action-btn.danger{background:#fff0f0;color:#e74c3c}.action-btn.danger:hover:not(:disabled){background:#e74c3c;color:#fff}.admin-error{background:#fff0f0;color:#e74c3c;padding:16px;border-radius:12px;margin-bottom:20px;font-size:.95rem}.admin-stats{display:flex;gap:20px;margin-bottom:24px;flex-wrap:wrap}.admin-stats .stat{padding:8px 16px;background:#f8f8f8;border-radius:20px;font-size:.9rem;color:#666}.admin-stats .stat.success{background:#e8f8e8;color:#27ae60}.admin-stats .stat.error{background:#fff0f0;color:#e74c3c}.admin-stats .stat.pending{background:#fff8e8;color:#f39c12}.admin-stats .stat.searching{background:linear-gradient(135deg,#e8f4ff,#f0e8ff);color:#3498db;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.results-table-container{overflow-x:auto;border-radius:16px;box-shadow:0 4px 20px #00000014}.results-table{width:100%;border-collapse:collapse;background:#fff;font-size:.9rem}.results-table th,.results-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #f0f0f0}.results-table th{background:linear-gradient(135deg,#fff5f8,#f8f0ff);font-weight:600;color:#333;position:sticky;top:0}.results-table tbody tr:hover{background:#fafafa}.results-table a{color:#ff6b9d;text-decoration:none;font-weight:500}.results-table a:hover{text-decoration:underline}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.status-badge.pending{background:#fff8e8;color:#f39c12}.status-badge.analyzing{background:#e8f4ff;color:#3498db}.status-badge.done{background:#e8f8e8;color:#27ae60}.status-badge.cached{background:#f0e8ff;color:#9b59b6}.status-badge.error{background:#fff0f0;color:#e74c3c}.top-indices{display:flex;flex-wrap:wrap;gap:6px}.index-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:linear-gradient(135deg,#fff5f8,#f8f0ff);border-radius:8px;font-size:.75rem;color:#666;white-space:nowrap}.index-tag .rarity{color:#ff6b9d;font-weight:600}@media (max-width: 768px){.admin-panel{padding:16px}.admin-header{flex-direction:column;gap:12px;text-align:center}.admin-actions{flex-direction:column}.action-btn{width:100%}.admin-stats{justify-content:center}.results-table{font-size:.8rem}.results-table th,.results-table td{padding:10px 8px}}.admin-stats .stat.cache{background:#f0e8ff;color:#9b59b6}.view-report-btn{padding:6px 12px;background:linear-gradient(135deg,#ff6b9d,#c9a0ff);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.view-report-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b9d66}.stat-toggle-btn{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.stat-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.stats-chart-section{background:#fff;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 4px 20px #00000014}.stats-chart-section h3{margin:0 0 8px;color:#333;font-size:1.2rem}.stats-description{margin:0 0 20px;color:#888;font-size:.85rem}.stats-chart-container{display:flex;flex-direction:column;gap:8px;max-height:500px;overflow-y:auto;padding-right:8px}.stat-row{display:flex;align-items:center;gap:12px;padding:6px 0}.stat-name{width:140px;font-size:.8rem;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.stat-bar-container{flex:1;height:24px;position:relative;background:#f5f5f5;border-radius:4px;overflow:hidden}.stat-bar-bg{position:absolute;top:0;right:0;bottom:0;left:0}.reference-line{position:absolute;top:0;bottom:0;width:1px;background:#ccc}.reference-line.light{background:#e0e0e0}.stat-range{position:absolute;top:2px;bottom:2px;border-radius:2px}.stat-std-range{position:absolute;top:4px;bottom:4px;border-radius:2px}.stat-mean-dot{position:absolute;top:50%;width:10px;height:10px;border-radius:50%;transform:translate(-50%,-50%);border:2px solid white;box-shadow:0 1px 3px #0000004d}.stat-values{display:flex;gap:8px;width:180px;flex-shrink:0;font-size:.75rem}.stat-mean{color:#666}.stat-std{color:#888}.stat-deviation{font-weight:600}.stats-legend{display:flex;gap:20px;margin-top:16px;padding-top:16px;border-top:1px solid #eee;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#666}.legend-dot{width:12px;height:12px;border-radius:50%}@media (max-width: 768px){.stats-chart-section{padding:16px}.stat-row{flex-wrap:wrap}.stat-name{width:100%;margin-bottom:4px}.stat-values{width:100%;justify-content:flex-start;margin-top:4px}.stats-legend{justify-content:center}}.problem-indices-summary{background:#fff5f5;border:1px solid #ffcccc;border-radius:12px;padding:16px;margin-bottom:20px;font-size:.85rem}.problem-indices-summary strong{color:#e74c3c}.problem-indices-summary ul{margin:8px 0 0;padding-left:20px}.problem-indices-summary li{margin:4px 0;color:#666}.problem-indices-summary li strong{color:#333}.stat-rank{width:32px;font-weight:700;font-size:.8rem;flex-shrink:0}.stat-row.highlight-problem{background:#fff5f5;border-radius:8px;padding:6px 8px;margin:0 -8px}.stat-range-text{color:#999;font-size:.7rem}.stat-values{width:220px}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.stats-header h3{margin:0}.export-csv-btn{padding:8px 16px;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.export-csv-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #27ae6066}.action-btn.resume{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.action-btn.resume:hover:not(:disabled){box-shadow:0 4px 16px #f39c1266}.subject-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace;font-size:.85rem;color:#666}.app-container{min-height:100vh;position:relative}.main-content{padding:80px 30px 30px;overflow-y:auto;position:relative}.top-bar{position:fixed;top:20px;right:30px;display:flex;align-items:center;gap:15px;z-index:9999}.top-bar-right{display:flex;align-items:center;gap:10px}.admin-btn{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:linear-gradient(135deg,#ffffff4d,#ffffff1a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.admin-btn:hover{background:linear-gradient(135deg,#ff6b9dcc,#c9a0ffcc);border-color:transparent;transform:scale(1.1);box-shadow:0 4px 15px #ff9ec766}.admin-btn.logged-in{border-color:#ff6b9d;box-shadow:0 0 10px #ff6b9d80}.clear-btn{padding:10px 20px;background:linear-gradient(135deg,#ffffff4d,#ffffff1a);color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #ff9ec733;transition:all .3s ease,opacity .4s ease,transform .4s ease}.clear-btn.show{opacity:1;transform:translate(0);pointer-events:auto}.clear-btn.hide{opacity:0;transform:translate(20px);pointer-events:none}.clear-btn:hover:not(.hide){background:linear-gradient(135deg,#ff6b9dcc,#c9a0ffcc);border-color:transparent;transform:translateY(-2px);box-shadow:0 8px 25px #ff9ec799,0 0 50px #c9a0ff80,0 0 80px #ff9ec74d,inset 0 0 30px #ffffff4d}.upload-page{position:relative}.upload-language-switcher{position:absolute;top:20px;right:20px;z-index:100}@media (max-width: 768px){.main-content{padding:80px 20px 20px}.top-bar{top:15px;right:15px}.reupload-btn{padding:10px 18px;font-size:12px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Quicksand,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,#ffe4ec,#ffd6e7,#e8d5f9,#d4e5ff,#ffe4f3);background-attachment:fixed;min-height:100vh;line-height:1.6;color:#6b4c7a;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20px 30px,#ffb6d9,transparent),radial-gradient(2px 2px at 40px 70px,#c9b1ff,transparent),radial-gradient(2px 2px at 50px 160px,#ffb6d9,transparent),radial-gradient(2px 2px at 90px 40px,#b8d4ff,transparent),radial-gradient(2px 2px at 130px 80px,#ffb6d9,transparent),radial-gradient(3px 3px at 160px 120px,#c9b1ff,transparent),radial-gradient(2px 2px at 200px 50px,#ffb6d9,transparent),radial-gradient(2px 2px at 250px 90px,#b8d4ff,transparent),radial-gradient(2px 2px at 300px 150px,#ffb6d9,transparent),radial-gradient(3px 3px at 350px 30px,#c9b1ff,transparent),radial-gradient(2px 2px at 400px 100px,#ffb6d9,transparent),radial-gradient(2px 2px at 450px 60px,#b8d4ff,transparent),radial-gradient(2px 2px at 500px 130px,#c9b1ff,transparent),radial-gradient(2px 2px at 550px 80px,#ffb6d9,transparent),radial-gradient(3px 3px at 600px 140px,#b8d4ff,transparent);animation:twinkle 4s ease-in-out infinite alternate;pointer-events:none;z-index:0}body:after{content:"💖 ✨ 💜 ⭐ 💗 ✨ 💜 ⭐ 💖 ✨";position:fixed;top:10%;left:0;width:200%;font-size:1.5em;letter-spacing:100px;opacity:.15;animation:floatHearts 30s linear infinite;pointer-events:none;z-index:0}@keyframes twinkle{0%{opacity:.5}to{opacity:1}}@keyframes floatHearts{0%{transform:translate(0)}to{transform:translate(-50%)}}#root{min-height:100vh;position:relative;z-index:1}::-webkit-scrollbar{width:14px;height:14px}::-webkit-scrollbar-track{background:linear-gradient(180deg,#ffe4ec,#e8d5f9);border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#ff9ec7,#c9a0ff,#ff9ec7);border-radius:10px;border:3px solid rgba(255,255,255,.5);box-shadow:0 0 10px #ff9ec780,0 0 20px #c9a0ff4d,inset 0 0 10px #ffffff4d}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#ff7eb3,#b080ff,#ff7eb3);box-shadow:0 0 15px #ff7eb399,0 0 30px #b080ff66,inset 0 0 15px #fff6}::selection{background:linear-gradient(135deg,#ff9ec7,#c9a0ff);color:#fff;text-shadow:0 0 10px rgba(255,255,255,.8)}@keyframes sparkle{0%,to{opacity:1;transform:scale(1);filter:brightness(1)}50%{opacity:.9;transform:scale(1.02);filter:brightness(1.1)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #ff9ec780,0 0 40px #c9a0ff4d,0 0 60px #ff9ec733}50%{box-shadow:0 0 30px #ff9ec7b3,0 0 60px #c9a0ff80,0 0 90px #ff9ec74d}}@keyframes rainbow-glow{0%{box-shadow:0 0 20px #ff9ec7,0 0 40px #ff9ec7}25%{box-shadow:0 0 20px #c9a0ff,0 0 40px #c9a0ff}50%{box-shadow:0 0 20px #a0d4ff,0 0 40px #a0d4ff}75%{box-shadow:0 0 20px #c9a0ff,0 0 40px #c9a0ff}to{box-shadow:0 0 20px #ff9ec7,0 0 40px #ff9ec7}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}
