@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f4f0ef;color:#332f2e}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#4f61f3;color:#fff;padding:.5rem 2rem}.app-header h1{font-size:1.8rem;margin-bottom:.5rem;font-weight:700}.app-header p{opacity:.9;font-weight:400;font-size:.9rem}.header-container{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;width:100%}.header-logo{flex:0 0 auto;display:flex;align-items:center}.bmat-logo{height:90px;width:auto;max-width:180px;object-fit:contain;filter:brightness(0) invert(1)}.header-title{flex:1;text-align:center}.header-title h1{font-size:1.8rem;margin-bottom:.25rem;font-weight:700}.header-title p{opacity:.9;font-weight:400;font-size:.85rem;margin:0}.header-spacer{flex:0 0 auto;width:120px}.app-main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.app-footer{text-align:center;padding:1.5rem;color:#332f2e;background:#f4f0ef;font-size:.85rem;border-top:1px solid #ddd}button,.reset-btn,.compare-btn,.toggle-explanation-btn,.small-btn,.preset-btn,.tab{transition:all .2s ease}.reset-btn,.compare-btn,.toggle-explanation-btn,.small-btn,.preset-btn{background:#4f61f3;color:#f4f0ef;border:none;cursor:pointer;font-weight:500}.reset-btn:hover,.compare-btn:hover,.toggle-explanation-btn:hover,.small-btn:hover,.preset-btn:hover{background:#4f61f3;transform:translateY(-2px)}.reset-btn:active,.compare-btn:active,.toggle-explanation-btn:active,.small-btn:active,.preset-btn:active{transform:translateY(0)}.reset-btn{background:#4f61f3;color:#f4f0ef;padding:.5rem 1rem;border-radius:8px;font-size:.9rem}.compare-btn{background:#4f61f3;color:#f4f0ef;padding:.5rem 1.5rem;border-radius:8px;font-weight:600;height:42px}.compare-btn:disabled{background:#999;cursor:not-allowed;transform:none}.toggle-explanation-btn{background:#4f61f3;color:#f4f0ef;padding:.5rem 1rem;border-radius:20px;font-size:.85rem}.small-btn{background:#4f61f3;color:#f4f0ef;padding:.25rem .75rem;border-radius:20px;font-size:.75rem}.preset-btn{background:#4f61f3;color:#f4f0ef;padding:.35rem .75rem;border-radius:20px;font-size:.75rem}.tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid #ddd;overflow-x:auto;flex-wrap:wrap}.tab{background:none;border:none;padding:.5rem 1rem;font-size:.8rem;font-weight:500;cursor:pointer;color:#332f2e;transition:all .2s;border-radius:6px 6px 0 0;white-space:nowrap}.tab:hover{color:#0dc8d9;background:#0dc8d91a}.tab-active{background:none;border:none;padding:.5rem 1rem;font-size:.8rem;font-weight:600;cursor:pointer;color:#0dc8d9;border-bottom:3px solid #0dc8d9}.upload-section{max-width:800px;margin:0 auto}.info-box{background:#f4f0ef;border-left:4px solid #4f61f3;padding:1rem;margin-top:1.5rem;border-radius:8px;font-size:.9rem}.info-box pre{background:#fff;padding:.75rem;border-radius:4px;margin-top:.5rem;overflow-x:auto;font-size:.8rem;color:#332f2e}.error-message{background:#ffe0e0;color:#ff456e;padding:1rem;border-radius:8px;margin-top:1rem;border-left:4px solid #ff456e}.file-uploader{width:100%}.dropzone{border:2px dashed #ddd;border-radius:12px;padding:2.5rem;text-align:center;cursor:pointer;transition:all .2s ease;background:#f4f0ef}.dropzone:hover{border-color:#0dc8d9;background:#0dc8d90d}.dropzone.drag-active{border-color:#0dc8d9;background:#0dc8d91a}.dropzone.loading{cursor:wait;opacity:.7}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-hint{font-size:.85rem;color:#332f2e;opacity:.7;margin-top:.5rem}.upload-filename{margin-top:.75rem;color:#0dc8d9;font-weight:500}.upload-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem}.spinner{width:40px;height:40px;border:3px solid #ddd;border-top-color:#0dc8d9;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.upload-requirements{margin-top:1rem;padding:1rem;background:#f4f0ef;border-radius:8px;font-size:.85rem}.upload-requirements ul{margin-top:.5rem;margin-left:1.5rem;color:#332f2e}.dashboard-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #ddd}.session-info{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.badge{background:#0dc8d9;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-family:monospace}.warning{background:#fff3e0;color:#f9c534;padding:.25rem .75rem;border-radius:20px;font-size:.85rem}.kpis-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.kpis-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:1.5rem}.kpis-header h3{margin:0;font-weight:600}.kpis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{background:#f4f0ef;border-radius:10px;padding:1rem;border:1px solid #ddd}.kpi-card .radio-name{margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid #0dc8d9;font-size:1rem;font-weight:600}.kpi-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem}.kpi-icon{font-size:1.1rem;width:30px}.kpi-label{flex:1;color:#332f2e;opacity:.7;font-size:.8rem}.kpi-value{font-weight:700;color:#0dc8d9;font-size:1rem}.kpis-explanations{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #ddd}.kpis-explanations h4{margin-bottom:1rem;font-size:1rem;font-weight:600}.explanations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1rem}.explanation-card{background:#f4f0ef;border-radius:10px;padding:1rem;border-left:4px solid #0dc8d9}.explanation-title{font-weight:700;font-size:.95rem;margin-bottom:.5rem;color:#332f2e}.explanation-description{font-size:.85rem;color:#332f2e;opacity:.7;margin-bottom:.5rem}.explanation-formula,.explanation-use{font-size:.75rem;color:#332f2e;opacity:.6;margin-top:.25rem}.explanations-footer{background:#0dc8d91a;border-radius:8px;padding:.75rem;font-size:.8rem;color:#0dc8d9}.top-tracks-unified{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.top-tracks-header{margin-bottom:1.5rem}.top-tracks-header h3{font-weight:600}.section-description{color:#332f2e;opacity:.7;font-size:.85rem;margin-bottom:1.5rem}.top-tracks-controls{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f4f0ef;border-radius:8px}.top-tracks-controls .control-group{display:flex;flex-direction:column;gap:.5rem}.top-tracks-controls .control-group label{font-size:.7rem;font-weight:600;color:#332f2e;opacity:.7;text-transform:uppercase}.top-tracks-controls .radio-buttons{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.top-tracks-controls .radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem}.top-tracks-controls select{padding:.4rem;border-radius:6px;border:1px solid #ddd;background:#fff;font-family:Poppins,sans-serif;font-size:.8rem;min-width:100px}.top-tracks-table-container{overflow-x:auto;max-height:500px;overflow-y:auto}.top-tracks-table{width:100%;border-collapse:collapse;font-size:.75rem}.top-tracks-table th,.top-tracks-table td{border:1px solid #ddd;padding:6px 4px;text-align:center}.top-tracks-table th{background:#f4f0ef;font-weight:600;color:#332f2e;position:sticky;top:0;z-index:10}.top-tracks-table .rank{font-weight:600;color:#0dc8d9;width:50px}.top-tracks-table .track-name{text-align:left;font-weight:500}.top-tracks-table .artist-name{text-align:left;color:#7d3aad}.top-tracks-table .plays{font-family:monospace}.top-tracks-table .total-plays{font-weight:700;background:#f4f0ef}.top-tracks-table tbody tr:hover{background:#0dc8d90d}.date-range-picker{background:#fff;border:1px solid #ddd;border-radius:12px;padding:1rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.date-range-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.date-range-title{font-weight:600;color:#0dc8d9;font-size:.9rem}.date-range-info{font-size:.75rem;color:#332f2e;background:#f4f0ef;padding:.25rem .5rem;border-radius:20px}.date-range-inputs{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.date-input-wrapper{flex:1;min-width:140px}.date-input-wrapper label{display:block;font-size:.7rem;font-weight:500;color:#332f2e;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.date-input{width:100%;padding:.4rem .6rem;border:1px solid #ddd;border-radius:8px;font-size:.8rem;font-family:Poppins,monospace;transition:all .2s}.date-input:focus{outline:none;border-color:#0dc8d9;box-shadow:0 0 0 2px #0dc8d91a}.date-separator{color:#94a3b8;font-size:1rem;padding-bottom:.25rem}.date-presets{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.date-range-slider{margin-top:.5rem}.slider{width:100%;height:4px;-webkit-appearance:none;background:#ddd;border-radius:2px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#0dc8d9;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0003}.slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.65rem;color:#94a3b8}.clock-widget{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.clock-controls{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem;padding:1rem;background:#f4f0ef;border-radius:8px}.control-group{display:flex;flex-direction:column;gap:.25rem}.control-group label{font-size:.7rem;font-weight:600;color:#332f2e;text-transform:uppercase}.control-group select{padding:.4rem;border-radius:6px;border:1px solid #ddd;background:#fff;font-family:Poppins,sans-serif;font-size:.8rem;min-width:150px}.clock-container{position:relative;display:flex;justify-content:center;margin:2rem 0}.clock-circle{transition:box-shadow .2s}.clock-circle:hover{box-shadow:0 8px 30px #00000026}.clock-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.clock-hour{font-size:16px;font-weight:700;color:#0dc8d9}.clock-tooltip{animation:fadeIn .15s ease;background:#332f2e;color:#fff;border-radius:8px;padding:8px 12px;font-size:11px;box-shadow:0 2px 10px #0003}.clock-tracklist{margin-top:2rem;padding-top:1rem;border-top:1px solid #ddd}.clock-tracklist h4{margin-bottom:1rem;font-size:.95rem;font-weight:600}.clock-tracklist ul{list-style:none;padding:0}.clock-tracklist li{display:flex;gap:1rem;padding:.5rem;border-bottom:1px solid #f4f0ef;font-size:.8rem}.clock-tracklist .track-time{font-family:monospace;font-weight:600;color:#0dc8d9;min-width:70px;font-size:.75rem}.clock-tracklist .track-name{flex:1;font-weight:500}.clock-tracklist .track-artist{color:#7d3aad;min-width:120px;font-size:.75rem}.clock-tracklist .track-duration{color:#94a3b8;font-family:monospace;font-size:.7rem}.clock-tracklist .gap-item{background-color:#0dc8d90d;border-left:3px solid #0dc8d9}.clock-tracklist .short-item{background-color:#ff456e0d;border-left:3px solid #ff456e}.short-badge{background-color:#ff456e;color:#fff;font-size:9px;padding:2px 6px;border-radius:12px;margin-left:8px}.clock-legend{display:flex;justify-content:center;gap:1.5rem;margin:1.5rem 0;padding-top:1rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.legend-color{width:18px;height:18px;border-radius:4px}.rotation-curves{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.rotation-curves .filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;background:#f4f0ef;padding:1rem;border-radius:8px}.filter-group{margin-bottom:1rem}.radio-buttons{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem}.track-select{padding:.4rem;border-radius:6px;border:1px solid #ddd;font-family:Poppins,sans-serif;font-size:.8rem;min-width:250px}.heatmap-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.heatmap-controls{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.5rem;padding:1rem;background:#f4f0ef;border-radius:8px}.heatmap-wrapper{overflow-x:auto;margin-bottom:1rem}.heatmap-table{width:100%;border-collapse:collapse;font-size:.7rem;min-width:600px}.heatmap-table th,.heatmap-table td{border:1px solid #ddd;padding:5px 6px;text-align:center}.heatmap-table th{background:#f4f0ef;font-weight:600;position:sticky;top:0}.hour-cell{background:#f4f0ef;font-weight:600;position:sticky;left:0}.heatmap-cell{transition:all .2s}.heatmap-cell:hover{transform:scale(1.05);box-shadow:0 2px 8px #0000001a}.heatmap-legend .legend-title{font-size:.7rem;color:#332f2e;margin-bottom:.5rem}.heatmap-legend .legend-colors{display:flex;gap:1rem;flex-wrap:wrap}.week-note{margin-top:1rem;padding:.5rem;background:#0dc8d91a;border-radius:6px;font-size:.7rem;color:#0dc8d9}.overlap-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.overlap-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:#0dc8d9;border-radius:12px;padding:1rem;text-align:center;color:#fff;transition:transform .2s}.summary-card:hover{transform:translateY(-3px)}.summary-icon{font-size:2rem;margin-bottom:.5rem}.summary-value{font-size:2rem;font-weight:700}.summary-label{font-size:.85rem;opacity:.9}.summary-desc{font-size:.7rem;opacity:.7;margin-top:.25rem}.exclusivity-section{margin-bottom:2rem}.exclusivity-section h4{margin-bottom:1rem;font-size:1rem;font-weight:600}.exclusivity-grid{display:flex;flex-direction:column;gap:.75rem}.exclusivity-card{background:#f4f0ef;border-radius:10px;border:1px solid #ddd;cursor:pointer;transition:all .2s}.exclusivity-card:hover{border-color:#0dc8d9;box-shadow:0 2px 8px #0000000d}.exclusivity-card.expanded{border-color:#0dc8d9;background:#0dc8d90d}.exclusivity-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem}.radio-info{display:flex;align-items:center;gap:.5rem;min-width:150px}.radio-icon{font-size:1.1rem}.radio-name{font-weight:600;font-size:.9rem}.exclusivity-stats{flex:1;display:flex;align-items:center;gap:.75rem;margin:0 1rem}.exclusivity-count{font-size:1.1rem;font-weight:700;color:#0dc8d9;min-width:40px}.exclusivity-unit{font-size:.65rem;color:#332f2e;opacity:.7}.exclusivity-bar-container{flex:1;height:6px;background:#ddd;border-radius:3px;overflow:hidden}.exclusivity-bar{height:100%;border-radius:3px;transition:width .3s}.expand-icon{color:#94a3b8;font-size:.7rem;width:24px;text-align:center}.exclusivity-content{padding:0 1rem 1rem;border-top:1px solid #ddd}.exclusive-list{list-style:none;padding:0;margin:0;max-height:300px;overflow-y:auto}.exclusive-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-bottom:1px solid #f4f0ef}.exclusive-item:hover{background:#fff;border-radius:6px}.track-icon{font-size:.8rem}.track-info{flex:1}.track-name{font-weight:500;font-size:.8rem}.track-artist{color:#7d3aad;font-size:.75rem;margin-left:.5rem}.common-section{margin-bottom:2rem}.common-section h4{margin-bottom:.5rem;font-size:1rem;font-weight:600}.subsection-desc{font-size:.75rem;color:#332f2e;opacity:.7;margin-bottom:1rem}.common-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;margin-top:1rem}.common-card{display:flex;align-items:center;gap:.75rem;padding:.6rem;background:#6cedad1a;border-radius:8px;border-left:3px solid #6cedad}.common-icon{font-size:1rem}.common-info{flex:1}.common-track{font-weight:500;font-size:.8rem}.common-artist{color:#7d3aad;font-size:.7rem}.jaccard-section{margin-top:1rem}.jaccard-section h4{margin-bottom:.5rem;font-size:1rem;font-weight:600}.jaccard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:1rem}.jaccard-card{background:#f4f0ef;border-radius:10px;padding:.8rem;border:1px solid #ddd}.jaccard-pair{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem}.jaccard-pair .radio-name{font-weight:600;font-size:.85rem}.jaccard-pair .vs{color:#94a3b8;font-size:.75rem}.jaccard-value-container{text-align:center}.jaccard-value{font-size:1.3rem;font-weight:700;margin-bottom:.25rem;color:#0dc8d9}.jaccard-bar-container{height:6px;background:#ddd;border-radius:4px;overflow:hidden;margin:.5rem 0}.jaccard-bar{height:100%;border-radius:4px;transition:width .3s}.jaccard-label{font-size:.65rem;color:#332f2e;opacity:.7}.tooltip-icon{display:inline-block;margin-left:.5rem;cursor:help;color:#94a3b8;font-size:.75rem;position:relative}.tooltip-content{position:absolute;background:#332f2e;color:#fff;padding:6px 10px;border-radius:8px;font-size:.7rem;max-width:250px;z-index:100;margin-top:5px;margin-left:-120px}.empty-message{text-align:center;padding:1rem;color:#94a3b8;font-size:.8rem}.artist-dashboard{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.artist-selector{margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.artist-selector label{font-weight:600;color:#332f2e;font-size:.9rem}.artist-select{padding:.4rem .8rem;border-radius:8px;border:1px solid #ddd;min-width:250px;font-size:.85rem;font-family:Poppins,sans-serif}.artist-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.artist-kpis .kpi-card{background:#f4f0ef;border-radius:10px;padding:.8rem;text-align:center;border:1px solid #ddd}.artist-kpis .kpi-value{font-size:1.6rem;font-weight:700;color:#0dc8d9}.artist-kpis .kpi-label{font-size:.75rem;color:#332f2e;opacity:.7;margin-top:.25rem}.artist-radio-distribution,.artist-top-songs,.artist-daily-evolution{margin-bottom:2rem}.artist-radio-distribution h4,.artist-top-songs h4,.artist-daily-evolution h4{margin-bottom:1rem;font-size:1rem;font-weight:600}.top-songs-table{width:100%;border-collapse:collapse}.top-songs-table th,.top-songs-table td{padding:8px;text-align:left;border-bottom:1px solid #ddd;font-size:.85rem}.top-songs-table th{background:#f4f0ef;font-weight:600}.collaboration-info{display:flex;align-items:flex-start;gap:1rem;background:#0dc8d91a;border-radius:10px;padding:.8rem;margin-bottom:1.5rem;border-left:4px solid #0dc8d9}.info-icon{font-size:1.3rem}.info-text{flex:1;font-size:.85rem}.matched-artists{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.matched-artist-tag{background:#fff;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;color:#0dc8d9;border:1px solid #0dc8d9}.info-note{font-size:.7rem;color:#332f2e;opacity:.7}.artist-collaboration-chart,.double-ring-container{margin-bottom:2rem;text-align:center;background:#f4f0ef;border-radius:12px;padding:1rem}.double-ring-title h4{margin-bottom:.5rem;font-size:.95rem;font-weight:600}.double-ring-chart{max-width:400px;margin:0 auto}.double-ring-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem;flex-wrap:wrap}.double-ring-legend .legend-item{display:flex;align-items:center;gap:.6rem;background:#fff;padding:.4rem .8rem;border-radius:10px;box-shadow:0 1px 3px #0000001a}.double-ring-legend .legend-text{display:flex;flex-direction:column;align-items:flex-start;font-size:.8rem}.double-ring-legend .legend-detail{font-size:.65rem;color:#332f2e;opacity:.7;margin-top:2px}.double-ring-note{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem;font-size:.65rem;color:#94a3b8;flex-wrap:wrap}.inner-ring-note:before{content:"● ";color:#0dc8d9;font-size:.75rem}.outer-ring-note:before{content:"◯ ";color:#ff456e;font-size:.75rem}.period-comparison{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.period-selectors{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:2rem;padding:1rem;background:#f4f0ef;border-radius:8px;align-items:flex-end}.period{flex:1;min-width:250px}.period label{display:block;font-weight:600;margin-bottom:.5rem;font-size:.8rem;color:#332f2e}.date-inputs{display:flex;align-items:center;gap:.5rem}.date-inputs input{flex:1;padding:.4rem;border-radius:6px;border:1px solid #ddd;font-family:Poppins,sans-serif;font-size:.8rem}.kpi-comparison{display:flex;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.kpi-comparison .kpi-card{flex:1;background:#f4f0ef;border-radius:10px;padding:.8rem;text-align:center;border:1px solid #ddd}.kpi-comparison .kpi-label{font-size:.75rem;color:#332f2e;opacity:.7;margin-bottom:.5rem}.kpi-comparison .kpi-values{display:flex;justify-content:center;gap:.75rem;font-size:1rem;font-weight:600;margin-bottom:.5rem}.kpi-comparison .period1{color:#0dc8d9}.kpi-comparison .period2{color:#ff456e}.kpi-comparison .vs{color:#94a3b8;font-size:.8rem}.kpi-variation{font-size:.8rem;font-weight:600}.top-comparison{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.top-column{background:#f4f0ef;border-radius:10px;padding:.8rem;border:1px solid #ddd}.top-column h5{margin-bottom:.8rem;padding-bottom:.4rem;border-bottom:1px solid #ddd;font-weight:600;font-size:.9rem}.top-column ul{list-style:none;padding:0;margin:0}.top-column li{display:flex;gap:.5rem;padding:.4rem 0;border-bottom:1px solid #f4f0ef;font-size:.75rem}.top-column .rank{font-weight:700;color:#0dc8d9;width:30px}.top-column .track-name{flex:1;font-weight:500}.top-column .artist-name{color:#7d3aad;min-width:90px;font-size:.7rem}.top-column .plays{color:#94a3b8;font-family:monospace;font-size:.7rem}.info-message{text-align:center;padding:1.5rem;color:#332f2e;background:#f4f0ef;border-radius:8px;font-size:.85rem}.loading-message{text-align:center;padding:1.5rem;color:#0dc8d9;font-size:.85rem}@media (max-width: 768px){.app-header{padding:1rem}.header-container{flex-wrap:wrap;justify-content:center;gap:.5rem}.header-logo{order:1}.header-title{order:2;flex:0 0 100%;margin-top:.5rem}.header-spacer{display:none}.bmat-logo{height:35px}.header-title h1{font-size:1.3rem}.tabs{overflow-x:auto;flex-wrap:nowrap}.tab,.tab-active{padding:.4rem .8rem;font-size:.75rem}.top-comparison{grid-template-columns:1fr}.double-ring-legend{flex-direction:column;align-items:center}.double-ring-chart{max-width:100%}.period-selectors{flex-direction:column;align-items:stretch}.compare-btn{width:100%}.date-range-inputs{flex-direction:column;align-items:stretch}.date-separator{display:none}.session-info{flex-direction:column;align-items:flex-start}.kpis-grid{grid-template-columns:1fr}}html,body{margin:0;padding:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
