:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;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}}:root{--primary-color: #c0c0c0;--secondary-color: #808080;--background-dark: #0a0a0a;--background-light: #1a1a1a;--text-primary: #e0e0e0;--text-secondary: #999999;--border-color: #333333;--success-color: #888888;--warning-color: #999999;--danger-color: #777777}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,var(--background-dark) 0%,var(--background-light) 100%);color:var(--text-primary);line-height:1.6}.dps-meter-container{width:100%;max-width:1400px;margin:0 auto;padding:20px;min-height:100vh}.dps-meter-header{width:100%;text-align:center;margin-bottom:40px;padding:30px 20px;background:#1e1e1e80;border-radius:12px;border:1px solid var(--border-color);box-sizing:border-box}.dps-meter-header h1{font-size:2.5em;margin-bottom:10px;color:#fff}.dps-meter-header p{font-size:1.1em;color:var(--text-secondary)}.file-upload-container{margin-bottom:40px}.log-location-info{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px;padding:12px 20px;background:#3c3c3c4d;border-radius:8px;border:1px solid rgba(80,80,80,.5)}.location-label{color:var(--text-secondary);font-size:.95em;font-weight:500}.location-path{background:#0006;padding:8px 16px;border-radius:6px;font-family:Courier New,Courier,monospace;color:#ccc;font-size:.9em;cursor:pointer;transition:all .3s ease;border:1px solid rgba(80,80,80,.5);-webkit-user-select:all;user-select:all}.location-path:hover{background:#6464644d;border-color:#999;transform:scale(1.02)}.location-path:active{transform:scale(.98)}.copy-success{color:var(--success-color);font-size:.9em;font-weight:600;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.upload-box{border:2px dashed var(--border-color);border-radius:12px;padding:60px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#2828284d}.upload-box:hover{border-color:#666;background:#32323266;transform:translateY(-2px)}.upload-icon{font-size:3em;margin-bottom:15px}.upload-box h3{font-size:1.5em;margin-bottom:8px;color:var(--text-primary)}.upload-box p{color:var(--text-secondary);margin:5px 0}.file-hint{font-size:.9em;color:var(--text-secondary);margin-top:10px}.meter-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.file-info{display:flex;flex-direction:column;gap:15px;margin-bottom:30px;padding:20px;background:#4ecdc40d;border-left:4px solid var(--secondary-color);border-radius:8px}.file-info-header{display:flex;justify-content:space-between;align-items:center;gap:15px}.file-summary{flex:1}.file-name{font-weight:600;color:var(--secondary-color);font-size:1.05em}.entry-count{color:var(--text-secondary);font-size:.95em;display:block;margin-bottom:5px}.uploaded-files-list{margin-top:10px}.uploaded-files-list h3{font-size:.95em;color:var(--text-secondary);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.uploaded-files-list ul{list-style:none;display:flex;flex-direction:column;gap:8px}.damage-by-target{display:flex;flex-direction:column;gap:12px}.target-card{border:1px solid var(--border-color);background:#00000040;padding:12px;border-radius:8px}.target-header{display:flex;align-items:center;gap:12px}.target-toggle{background:transparent;color:var(--text-primary);border:none;font-size:1.05em;cursor:pointer}.target-name{font-size:1.05em;color:var(--secondary-color);margin:0}.target-summary{margin-left:auto;color:var(--text-secondary)}.caster-block{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(255,255,255,.03)}.caster-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.caster-name{color:var(--text-primary)}.caster-damage{color:var(--primary-color);font-weight:600}.skills-table{width:100%;border-collapse:collapse;margin-top:8px}.skills-table th,.skills-table td{padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.skills-table td.skill-name{color:var(--text-primary)}.file-item{display:flex;flex-direction:column;padding:10px 12px;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;transition:all .2s ease}.file-item>div:first-child{display:flex;justify-content:space-between;align-items:center;width:100%}.file-item:hover{background:#50505033;border-color:#666}.file-item-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.file-item .file-name{font-size:.95em;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-entries{color:var(--text-secondary);font-size:.85em;white-space:nowrap}.file-time{color:var(--text-secondary);font-size:.8em;white-space:nowrap}.btn-remove{background:#ff6b6b33;color:var(--primary-color);border:1px solid rgba(255,107,107,.4);border-radius:4px;padding:6px 10px;cursor:pointer;font-size:.9em;font-weight:600;transition:all .2s ease;white-space:nowrap;margin-left:8px}.btn-remove:hover{background:#ff6b6b66;border-color:var(--primary-color);transform:scale(1.05)}.btn-remove:active{transform:scale(.95)}.btn-remove-inline{background:transparent;color:#ff6b6bb3;border:none;cursor:pointer;font-size:1em;padding:4px;transition:all .2s ease;border-radius:4px;margin-right:8px;display:flex;align-items:center;justify-content:center}.btn-remove-inline:hover{background:#ff6b6b33;transform:scale(1.15)}.btn-remove-inline:active{transform:scale(.95)}.file-preview{margin-top:12px;padding:10px;background:#00000080;border-radius:4px;border-left:3px solid var(--secondary-color)}.preview-line{font-family:Courier New,Courier,monospace;font-size:.8em;color:var(--text-secondary);line-height:1.6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 0}.btn-clear-all{background:#ff6b6b26;color:var(--primary-color);border:1px solid rgba(255,107,107,.3);border-radius:6px;padding:8px 14px;cursor:pointer;font-size:.9em;font-weight:600;transition:all .2s ease;white-space:nowrap}.btn-clear-all:hover{background:#ff6b6b40;border-color:var(--primary-color);box-shadow:0 2px 8px #ff6b6b33}.btn-clear-all:active{transform:scale(.98)}.charts-section{margin-bottom:50px;background:var(--background-light);border:1px solid var(--border-color);border-radius:12px;padding:25px}.charts-section h2{margin-bottom:20px;color:var(--text-primary);font-size:1.4em}.dps-chart-wrapper{background:#0000004d;border-radius:8px;padding:15px}.stats-section{background:var(--background-light);border:1px solid var(--border-color);border-radius:12px;padding:25px}.stats-section h2{margin-bottom:20px;color:var(--text-primary);font-size:1.4em}.stats-table-wrapper{overflow-x:auto;border-radius:8px;background:#0000004d}.stats-table{width:100%;border-collapse:collapse;font-size:.95em}.stats-table thead{background:linear-gradient(135deg,#ff6b6b1a,#4ecdc41a);border-bottom:2px solid var(--border-color)}.stats-table th{padding:15px;text-align:left;color:var(--secondary-color);font-weight:600}.stats-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.stats-table tbody tr:hover{background:#4ecdc40d}.stats-table tbody tr.rank-1{background:#ff6b6b14}.stats-table td{padding:12px 15px;color:var(--text-primary)}.rank-badge{display:inline-block;padding:4px 8px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;border-radius:4px;font-weight:600;font-size:.85em}.rank-badge.rank-1{background:linear-gradient(135deg,gold,orange);box-shadow:0 0 8px #ffd7004d}.rank-badge.rank-2{background:linear-gradient(135deg,silver,gray)}.rank-badge.rank-3{background:linear-gradient(135deg,#cd7f32,#8b4513)}.player-name{font-weight:600;color:var(--text-primary)}.dps-value{color:var(--primary-color);font-weight:600;font-size:1.05em}.damage-value{color:var(--secondary-color);font-weight:500}.hit-count{color:var(--text-secondary)}.avg-damage{color:var(--warning-color)}.max-damage{text-align:center}.max-badge{display:inline-block;padding:4px 8px;background:#ff6b6b26;color:var(--primary-color);border-radius:4px;font-weight:600}.duration{color:var(--text-secondary);font-size:.9em}.empty-state{text-align:center;padding:40px;color:var(--text-secondary);font-style:italic}.recharts-surface{background:transparent!important}.recharts-cartesian-axis-tick{fill:#d0d0d0!important;color:#d0d0d0!important}.recharts-cartesian-axis-line{stroke:var(--border-color)!important}.recharts-cartesian-grid-horizontal line{stroke:var(--border-color)!important;opacity:.3}.recharts-cartesian-grid-vertical line{stroke:var(--border-color)!important;opacity:.3}.recharts-tooltip-wrapper{outline:none!important}.recharts-default-tooltip{background-color:var(--background-light)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;padding:10px!important;color:var(--text-primary)!important}.recharts-tooltip-label,.recharts-tooltip-label-list,.recharts-tooltip-item{color:var(--text-primary)!important}.recharts-label,.recharts-text{fill:#d0d0d0!important}.recharts-legend-item-text{color:#e0e0e0!important}@media(max-width:768px){.dps-meter-header h1{font-size:1.8em}.file-info-header,.file-item{flex-direction:column;align-items:flex-start}.file-item-info{flex-wrap:wrap;margin-bottom:8px;width:100%}.btn-remove{align-self:flex-end;margin-left:0;margin-top:-30px}.stats-table{font-size:.85em}.stats-table th,.stats-table td{padding:10px 8px}.upload-box{padding:40px 15px}.upload-icon{font-size:2em}.dps-meter-header{margin-bottom:20px;padding:20px 15px}}@media(max-width:480px){.dps-meter-container{padding:10px}.dps-meter-header h1{font-size:1.4em}.charts-section,.stats-section{padding:15px}.upload-box{padding:30px 10px}.stats-table{font-size:.75em}.stats-table th,.stats-table td{padding:8px 5px}}.raw-log-viewer{margin-top:20px;background:var(--background-light);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.raw-log-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#4ecdc40d;border-bottom:1px solid var(--border-color)}.raw-log-header h3{margin:0;color:var(--text-primary);font-size:1.3em}.raw-log-info{color:var(--text-secondary);font-size:.9em}.raw-log-content{max-height:600px;overflow-y:auto;background:#0d0d0d}.raw-log-content pre{margin:0;padding:20px;font-family:Courier New,Courier,monospace;font-size:.85em;line-height:1.5;color:#0f0;white-space:pre-wrap;word-wrap:break-word}.raw-log-content code{color:#0f0}.raw-log-footer{padding:15px 20px;text-align:center;border-top:1px solid var(--border-color);background:#4ecdc408}.btn-load-more{padding:10px 20px;background:var(--secondary-color);color:var(--background-dark);border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-load-more:hover{background:#3db5ad;transform:translateY(-2px);box-shadow:0 4px 12px #4ecdc44d}.btn-load-more:active{transform:translateY(0)}.processing-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.processing-modal{background:var(--background-light);border:1px solid var(--border-color);border-radius:12px;padding:40px;max-width:500px;width:90%;text-align:center;box-shadow:0 8px 32px #00000080}.processing-spinner{width:60px;height:60px;margin:0 auto 20px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.processing-modal h3{font-size:1.5em;margin-bottom:10px;color:var(--text-primary)}.processing-stage{color:var(--text-secondary);margin-bottom:20px;font-size:1.1em;min-height:1.5em}.progress-bar{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:15px}.progress-fill{height:100%;background:linear-gradient(90deg,#888,#ccc);transition:width .3s ease;border-radius:4px}.processing-count{color:var(--text-secondary);font-size:.95em;margin:0}.about-container{max-width:900px;margin:0 auto;padding:40px 20px;color:var(--text-primary)}.about-header{text-align:center;margin-bottom:60px;padding-bottom:30px;border-bottom:2px solid var(--border-color)}.about-header h1{font-size:3em;margin-bottom:10px;color:#fff}.about-header .subtitle{font-size:1.2em;color:var(--text-secondary);margin:0}.about-section{margin-bottom:50px}.about-section h2{font-size:2em;margin-bottom:20px;color:#ccc;border-left:4px solid #666666;padding-left:15px}.about-section p{font-size:1.1em;line-height:1.8;color:var(--text-secondary);margin-bottom:15px}.about-section strong{color:var(--text-primary)}.features-list{list-style:none;padding:0;margin:20px 0}.features-list li{padding:20px;margin-bottom:15px;background:#0000004d;border-left:4px solid #555555;border-radius:8px;transition:all .3s ease}.features-list li:hover{background:#00000080;border-left-color:#888;transform:translate(5px)}.features-list li strong{display:block;font-size:1.2em;color:#ddd;margin-bottom:8px}.features-list li span{color:var(--text-secondary);font-size:.95em}.steps{margin:30px 0}.step{display:flex;gap:20px;margin-bottom:30px;padding:25px;background:#0000004d;border-radius:10px;border:1px solid var(--border-color)}.step-number{flex-shrink:0;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#666;border-radius:50%;font-size:1.5em;font-weight:700;color:#fff}.step-content h3{font-size:1.3em;color:#ccc;margin:0 0 10px}.step-content p{margin:0;line-height:1.6}.step-content code{background:#00000080;padding:2px 8px;border-radius:4px;font-family:Courier New,Courier,monospace;color:#bbb;font-size:.9em}.code-block{background:#00000080;border:1px solid var(--border-color);border-left:4px solid #555555;padding:20px;border-radius:8px;margin:20px 0;overflow-x:auto}.code-block code{font-family:Courier New,Courier,monospace;color:#bbb;font-size:.9em;line-height:1.6;white-space:pre-wrap;word-break:break-all}.format-note{font-size:.95em;font-style:italic;color:var(--text-secondary);margin-top:10px}.format-note code{background:#00000080;padding:2px 6px;border-radius:3px;font-family:Courier New,Courier,monospace;color:#bbb}.tech-info{background:#0000004d;border:1px solid var(--border-color);border-radius:10px;padding:30px}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-top:20px}.tech-item{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;background:#0006;border-radius:8px;transition:all .3s ease}.tech-item:hover{background:#0009;transform:translateY(-5px)}.tech-icon{font-size:2.5em}.tech-name{color:var(--text-primary);font-weight:600;font-size:1.1em}.about-footer{text-align:center;margin-top:80px;padding-top:30px;border-top:2px solid var(--border-color)}.about-footer p{margin:10px 0;color:var(--text-secondary)}.about-footer .version{font-size:.9em;color:#fff6}@media(max-width:768px){.about-container{padding:20px 15px}.about-header h1{font-size:2em}.about-header .subtitle{font-size:1em}.about-section h2{font-size:1.5em}.step{flex-direction:column;align-items:flex-start}.step-number{width:40px;height:40px;font-size:1.2em}.tech-grid{grid-template-columns:repeat(2,1fr)}.code-block code{font-size:.75em}}@media(max-width:480px){.tech-grid{grid-template-columns:1fr}.features-list li{padding:15px}}#root{width:100%;margin:0;padding:0;min-height:100vh}.app{width:100%;min-height:100vh;margin:0;padding:0;display:flex;flex-direction:column}.main-nav{background:#000000e6;border-bottom:1px solid #444444;padding:0;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-content{max-width:1400px;margin:0 auto;padding:15px 30px;display:flex;justify-content:space-between;align-items:center}.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;font-size:1.5em;font-weight:700;color:#fff;transition:all .3s ease}.nav-logo:hover{color:#ccc;transform:scale(1.05)}.logo-icon{font-size:1.3em}.logo-text{color:#fff}.nav-links{display:flex;gap:30px}.nav-link{text-decoration:none;color:#fffc;font-size:1.1em;font-weight:500;padding:8px 16px;border-radius:6px;transition:all .3s ease;position:relative}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:#aaa;transition:width .3s ease}.nav-link:hover{color:#fff;background:#64646433}.nav-link:hover:after{width:80%}.nav-link.active{color:#ccc;background:#64646440}.nav-coffee-link{text-decoration:none}.btn-coffee{padding:8px 16px;background:#fd0;border:none;border-radius:6px;cursor:pointer;font-weight:700;color:#000;font-size:.95em;transition:all .3s ease;white-space:nowrap}.btn-coffee:hover{background:#ffe74c;transform:translateY(-2px);box-shadow:0 4px 8px #ffdd004d}.btn-coffee:active{transform:translateY(0)}@media(max-width:768px){.nav-content{flex-direction:column;gap:15px;padding:15px 20px}.nav-links{gap:15px}.nav-link{font-size:1em;padding:6px 12px}.nav-logo{font-size:1.3em}}
