: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;display:flex;place-items:center;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}}.player-card{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;padding:0;margin-bottom:24px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;overflow:hidden}.spotify-header{background:#fff;color:#374151;padding:6px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;border-top:3px solid #1DB954;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif}.spotify-indicator{display:flex;align-items:center;gap:8px}.spotify-logo{display:flex;align-items:center;color:#1db954}.spotify-text{font-size:11px;font-weight:400;color:#9ca3af;text-transform:lowercase;letter-spacing:.2px}.playback-controls{display:flex;align-items:center;gap:12px}.device-info{display:flex;align-items:center;gap:4px;font-size:11px;color:#6b7280}.device-icon{display:flex;align-items:center;color:#9ca3af}.device-name{font-weight:400;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-main-content{display:flex;gap:20px;padding:24px;margin-bottom:0}.album-art-section{flex-shrink:0}.album-art{width:150px;height:150px;border-radius:2px;object-fit:cover;background:#f5f5f5;border:1px solid #e0e0e0}.track-info-section{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}.track-title{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 4px;line-height:1.2;letter-spacing:-.3px}.track-artist{font-size:16px;font-weight:500;color:#333;margin:0 0 2px;line-height:1.3}.track-album{font-size:14px;font-weight:400;color:#666;margin:0 0 16px;line-height:1.3}.framework-display{display:flex;align-items:center;gap:8px;margin-bottom:16px}.framework-label{font-size:13px;color:#666;font-weight:500}.framework-badge{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff}.framework-badge.sage{background:#a7bca4}.framework-badge.cinnamon{background:#d27d2d}.framework-badge.vanilla{background:#8b7355}.framework-badge.default{background:#666}.analysis-progress-indicator{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9fa;border-radius:2px;margin-bottom:16px;border-left:3px solid #2E7D32}.analysis-progress-indicator[data-step=fetching]{border-left-color:#9c27b0;background:#f3e5f5}.analysis-progress-indicator[data-step=fetching] .progress-label{color:#7b1fa2}.analysis-progress-indicator[data-step=processing]{border-left-color:#ff9800;background:#fff3e0}.analysis-progress-indicator[data-step=processing] .progress-label{color:#f57c00}.analysis-progress-indicator[data-step=analyzing]{border-left-color:#2196f3;background:#e3f2fd}.analysis-progress-indicator[data-step=analyzing] .progress-label{color:#1976d2}.analysis-progress-indicator[data-step=error]{border-left-color:#d32f2f;background:#ffebee}.analysis-progress-indicator[data-step=error] .progress-label{color:#d32f2f}.analysis-progress-indicator[data-step=no-framework]{border-left-color:#666;background:#f5f5f5}.analysis-progress-indicator[data-step=no-framework] .progress-label{color:#666}.progress-icon{font-size:20px;flex-shrink:0}.progress-info{display:flex;flex-direction:column;gap:2px}.progress-label{font-size:13px;font-weight:600;color:#2e7d32;text-transform:uppercase;letter-spacing:.3px}.progress-description{font-size:12px;color:#666;line-height:1.3;margin-top:4px}.analysis-summary{background:#f8f9fa;border-left:3px solid #2E7D32;border-radius:0 2px 2px 0;padding:16px;margin-bottom:16px}.summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.summary-controls{display:flex;align-items:center;gap:12px}.summary-title{font-size:13px;font-weight:600;color:#2e7d32;text-transform:uppercase;letter-spacing:.3px}.distortion-metric{display:flex;align-items:center;gap:8px;font-size:12px;padding:6px 12px;border-radius:12px;border:1px solid #e0e0e0;background:#f8f9fa}.distortion-metric.low{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-color:#4caf50;color:#2e7d32}.distortion-metric.moderate{background:linear-gradient(135deg,#fff8e1,#fffde7);border-color:#ff9800;color:#e65100}.distortion-metric.high{background:linear-gradient(135deg,#ffebee,#fce4ec);border-color:#f44336;color:#c62828}.distortion-metric.clean{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-color:#4caf50;color:#2e7d32}.distortion-metric.clean .metric-value{color:#4caf50;font-weight:600}.distortion-metric.clean .metric-level{color:#2e7d32;font-weight:600}.distortion-metric.clean:before{content:"✨";margin-right:4px;font-size:12px}.metric-label{font-size:11px;color:#666;font-weight:500}.metric-value{font-size:14px;font-weight:700;color:#2e7d32}.metric-level{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.2px}.summary-content{margin-top:12px}.summary-text{font-size:14px;color:#333;line-height:1.5;margin:0}.summary-text.clean{color:#2e7d32;font-weight:500}.analysis-summary.clean{background:linear-gradient(135deg,#f8fff8,#f1f8e9);border:1px solid #C8E6C9}.analysis-summary.clean .summary-title{color:#2e7d32}.analysis-summary.clean .summary-title:before{content:"🌟 ";margin-right:4px}.debug-calculation{font-size:12px;color:#333;margin-bottom:8px}.debug-scores{font-size:11px;color:#333}.playback-status{background:#fafafa;border-top:1px solid #e0e0e0;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#666}.status-left{display:flex;align-items:center;gap:12px}.status-duration{font-weight:500;color:#333}.status-playing{display:flex;align-items:center;gap:4px;color:#2e7d32;font-weight:500}.status-playing-icon{width:8px;height:8px;background:#2e7d32;border-radius:50%}.status-next{color:#666;font-size:12px}.no-track-state{text-align:center;padding:40px 20px;color:#999}.no-track-icon{font-size:48px;margin-bottom:16px;display:block;opacity:.5}.no-track-message{font-size:16px;margin-bottom:8px}.no-track-submessage{font-size:14px;color:#666}.loading-state{text-align:center;padding:40px 20px;color:#666}.loading-spinner{display:inline-block;width:24px;height:24px;border:2px solid #e0e0e0;border-top:2px solid #2E7D32;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-state{text-align:center;padding:40px 20px;color:#d32f2f;background:#ffebee;border-left:3px solid #d32f2f;border-radius:0 2px 2px 0}.error-icon{font-size:32px;margin-bottom:12px;display:block}.error-message{font-size:14px;font-weight:500}@media (max-width: 768px){.player-card{padding:0}.player-main-content{flex-direction:column;gap:16px;padding:20px}.album-art-section{align-self:center}.album-art{width:120px;height:120px}.track-title{font-size:20px;text-align:center}.track-artist,.track-album{text-align:center}.playback-status{flex-direction:column;gap:8px;text-align:center}}.section-title{margin:0 0 8px;font-size:13px;color:#6b7280;font-weight:500}.violations-section{margin-top:12px}.violations-grid{display:grid;gap:6px}.violation-item{border:1px solid #f5c6cb;background-color:#f8d7da;color:#721c24;border-radius:8px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center}.violation-label{font-size:13px;font-weight:600}.violation-details{font-size:12px;color:#721c24}.no-violations{border:1px solid #c3e6cb;background-color:#d4edda;color:#155724;border-radius:8px;padding:8px 10px;font-size:13px}.maturity-section{margin-top:12px}.maturity-display{display:flex;align-items:center;gap:8px}.maturity-empty{color:#999;font-size:12px}.maturity-badge{border:1px solid rgba(0,0,0,.05);padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600}.maturity-badge.maturity-high{background-color:#ffebee;color:#b91c1c}.maturity-badge.maturity-mid{background-color:#fff3e0;color:#9a3412}.maturity-badge.maturity-low{background-color:#e8f5e8;color:#15803d}.maturity-score{margin-left:6px;font-weight:400;opacity:.7}@media (max-width: 480px){.player-card{padding:0}.album-art{width:100px;height:100px}.track-title{font-size:18px}.track-artist{font-size:15px}.track-album{font-size:13px}}.cbt-analysis-container{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;margin:24px 0;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif}.cbt-header{display:flex;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #f0f0f0;gap:12px}.framework-indicator{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff;min-width:60px;text-align:center}.cbt-header h2{margin:0;font-size:18px;font-weight:500;color:#1a1a1a;letter-spacing:-.2px}.cbt-navigation{display:flex;background:#fafafa;border-bottom:1px solid #e8e8e8}.nav-button{flex:1;padding:12px 16px;border:none;background:transparent;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.nav-button:hover{background:#f0f0f0;color:#333}.nav-button.active{background:#fff;color:#1a1a1a;border-bottom-color:#2e7d32}.cbt-loading,.cbt-error{display:flex;align-items:center;justify-content:center;padding:48px 24px;gap:12px}.loading-pulse{width:16px;height:16px;border-radius:50%;background:#2e7d32;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.cbt-error{flex-direction:column;gap:8px}.error-icon{font-size:24px;color:#d32f2f}.error-content h3{margin:0;font-size:16px;font-weight:500;color:#1a1a1a}.error-content p{margin:4px 0 0;font-size:14px;color:#666}.cbt-section{padding:24px}.primary-metric{margin-bottom:32px}.metric-card{background:#fafafa;border-radius:2px;padding:24px;text-align:center}.metric-header h3{margin:0 0 20px;font-size:14px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.metric-value-container{display:flex;flex-direction:column;align-items:center;gap:16px}.metric-circle{position:relative;width:120px;height:120px}.metric-progress{width:100%;height:100%;border-radius:50%;background:conic-gradient(var(--color) 0deg,var(--color) calc(var(--progress) * 3.6deg),#e8e8e8 calc(var(--progress) * 3.6deg),#e8e8e8 360deg);display:flex;align-items:center;justify-content:center;position:relative}.metric-progress:before{content:"";position:absolute;width:80px;height:80px;background:#fff;border-radius:50%}.metric-percentage{position:relative;z-index:1;font-size:24px;font-weight:300;color:#1a1a1a}.metric-interpretation{font-size:13px;color:#666;font-weight:500}.summary-card{background:#f8f9fa;border-left:3px solid #2E7D32;padding:20px;margin:24px 0;border-radius:0 2px 2px 0}.summary-card h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#1a1a1a}.summary-card p{margin:0;font-size:14px;line-height:1.5;color:#333}.top-distortions h3{margin:0 0 16px;font-size:14px;font-weight:600;color:#1a1a1a}.distortion-preview{display:flex;flex-direction:column;gap:12px}.distortion-item{display:flex;align-items:center;gap:12px}.distortion-name{min-width:120px;font-size:12px;font-weight:500;color:#666}.distortion-bar{flex:1;height:4px;background:#e8e8e8;border-radius:2px;overflow:hidden}.distortion-fill{height:100%;transition:width .3s ease}.distortion-value{min-width:32px;font-size:12px;font-weight:600;color:#1a1a1a;text-align:right}.distortions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.distortion-card{background:#fafafa;border-radius:2px;padding:20px;transition:transform .2s ease}.distortion-card:hover{transform:translateY(-1px)}.distortion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.distortion-header h4{margin:0;font-size:14px;font-weight:500;color:#1a1a1a;text-transform:capitalize}.distortion-score{font-size:16px;font-weight:600}.distortion-visual{margin-bottom:12px}.distortion-bar-full{width:100%;height:6px;background:#e8e8e8;border-radius:3px;overflow:hidden;position:relative}.distortion-bar-full:after{content:"";position:absolute;left:0;top:0;height:100%;width:var(--fill);background:var(--color);transition:width .3s ease}.distortion-note{font-size:11px;color:#d32f2f;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.scores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.score-card{background:#fafafa;border-radius:2px;padding:20px;text-align:center}.score-header h4{margin:0 0 16px;font-size:12px;font-weight:500;color:#666;text-transform:capitalize}.score-content{display:flex;flex-direction:column;align-items:center;gap:12px}.score-circle-small{position:relative;width:80px;height:80px}.score-progress{width:100%;height:100%;border-radius:50%;border:3px solid var(--color);background:conic-gradient(var(--color) 0deg,var(--color) calc(var(--progress) * 3.6deg),#e8e8e8 calc(var(--progress) * 3.6deg),#e8e8e8 360deg);display:flex;align-items:center;justify-content:center;position:relative;box-sizing:border-box}.score-progress:before{content:"";position:absolute;width:60px;height:60px;background:#fff;border-radius:50%}.score-circle-small .score-percentage{position:relative;z-index:1;font-size:16px;font-weight:400;color:#1a1a1a}.score-label{font-size:11px;color:#666;font-weight:500;text-align:center;max-width:120px}@media (max-width: 768px){.cbt-section{padding:16px}.distortions-grid,.scores-grid{grid-template-columns:1fr}.metric-circle{width:100px;height:100px}.metric-progress:before{width:70px;height:70px}.metric-percentage{font-size:20px}}.debug-section{margin-top:16px;padding:12px 0;border-top:1px solid #e0e0e0}.debug-button{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;padding:8px 12px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:#666;transition:all .2s ease;width:100%}.debug-button:hover{background:#e9ecef;border-color:#999;color:#333}.debug-panel{margin-top:16px;padding:12px;background:#f0f0f0;border-radius:2px;border:1px solid #ddd}.debug-header{font-size:12px;font-weight:600;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}.debug-scores{font-size:11px;color:#333;margin-bottom:12px}.debug-scores pre{background:#fff;padding:8px;border-radius:2px;border:1px solid #ddd;margin:4px 0 0;overflow-x:auto;font-family:SF Mono,Monaco,monospace;font-size:10px;line-height:1.4}.analysis-progress{border-radius:8px;padding:16px;margin:16px 0;position:relative;overflow:hidden;transition:all .3s ease;background-color:#1e1e1e;color:#e0e0e0;border-left:4px solid #666;box-shadow:0 2px 10px #0003}.analysis-progress.cancelled{border-left-color:#ff9800;background-color:#2a1f15}.analysis-progress.cancelled .progress-header{border-bottom-color:#ff980033}.analysis-progress .MuiTypography-h6{font-weight:600;color:var(--text-base);margin:0;line-height:1.2}.analysis-progress .framework-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:capitalize;letter-spacing:.3px}.task-status-container{margin:16px 0;padding:12px;background:var(--background-elevated-highlight);border-radius:8px;border-left:3px solid var(--text-positive)}.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.insight-card.distortion{border-left-color:#ff6b35}.insight-card.pattern{border-left-color:#ffc107}.insight-card.positive{border-left-color:#28a745}.insight-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.insight-label{font-size:11px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.3px}.insight-score{font-size:11px;font-weight:600}.insight-value{font-size:13px;font-weight:600}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #333;flex-wrap:wrap;gap:8px}.lyrics-section{margin:0 24px 24px}.lyrics-toggle{display:flex;align-items:center;gap:8px;background:none;border:1px solid #ddd;padding:8px 12px;border-radius:2px;font-size:13px;color:#666;cursor:pointer;transition:all .2s ease}.lyrics-toggle:hover{background:#f5f5f5;border-color:#999}.toggle-icon{font-size:10px;color:#999}.lyrics-content{margin-top:12px;padding:16px;background:#fff;border:1px solid #e0e0e0;border-radius:2px;max-height:200px;overflow-y:auto}.lyrics-content pre{margin:0;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;line-height:1.5;color:#333;white-space:pre-wrap}.status-container{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.action-buttons{display:flex;gap:4px;align-items:center}.analysis-summary{margin:0 24px 24px;padding:16px;background:#f8f9fa;border-left:3px solid #2E7D32;border-radius:0 2px 2px 0}.analysis-summary h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#1a1a1a}.analysis-summary p{margin:0;font-size:13px;color:#333;line-height:1.5}@media (max-width: 768px){.analysis-progress{border-radius:0;margin:0;padding:12px}.analysis-summary,.error-message,.progress-message{margin:0 0 12px;padding:0 8px}.insights-grid{grid-template-columns:1fr}.progress-header{padding:0 0 12px;flex-direction:row;gap:8px;align-items:center}.status-container{min-width:0;overflow:hidden}.status-container .MuiTypography-root{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.action-buttons{flex-shrink:0}.step-icon{width:32px;height:32px;font-size:14px}}.protection-indicator{background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:12px 16px;margin-bottom:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.protection-content{display:flex;align-items:center;gap:12px}.protection-indicator-dot{font-size:14px;line-height:1;width:16px;text-align:center}.protection-text{flex:1;display:flex;flex-direction:column;gap:2px}.protection-title{font-size:14px;font-weight:500;margin:0;line-height:1.2}.protection-subtitle{font-size:12px;margin:0;opacity:.7;line-height:1.2}.framework-name{font-size:12px;color:#fff;font-weight:500;white-space:nowrap;padding:4px 8px;border-radius:12px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.protection-full .protection-indicator-dot{color:#16a34a}.protection-partial .protection-indicator-dot{color:#d97706}.protection-monitoring .protection-indicator-dot{color:#2563eb}.protection-unknown .protection-indicator-dot{color:#6b7280}@media (max-width: 768px){.protection-indicator{padding:10px 12px}.protection-content{gap:10px}.protection-title{font-size:13px}.protection-subtitle,.framework-name{font-size:11px}}.dashboard-page{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;color:#1a1a1a;line-height:1.5}.dashboard-header{margin-bottom:32px}.dashboard-header h1{font-size:28px;font-weight:300;margin:0 0 8px;letter-spacing:-.5px}.dashboard-header p{font-size:14px;color:#666;margin:0;font-weight:400}.dashboard-content{margin-top:24px}.main-column{width:100%}.player-section{margin-bottom:32px}.analysis-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;align-items:start}.analysis-results-section,.lyrics-analysis-section{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;overflow:hidden}.analysis-results-section h3,.lyrics-analysis-section h3{margin:0;padding:24px 24px 0;font-size:16px;font-weight:500;color:#1a1a1a;letter-spacing:-.2px}.progress-section{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;margin-bottom:24px}.trigger-actions-panel{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;padding:24px;margin-bottom:24px}.trigger-actions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.trigger-actions-header h3{margin:0;font-size:16px;font-weight:500;color:#1a1a1a;letter-spacing:-.2px}.trigger-status-indicator{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.trigger-status-indicator.log{background:#e3f2fd;color:#1976d2}.trigger-status-indicator.skip{background:#ffebee;color:#d32f2f}.trigger-status-indicator.none{background:#f5f5f5;color:#666}.trigger-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.trigger-action-card{padding:16px;border:1px solid #e0e0e0;border-radius:2px;transition:all .2s ease;cursor:pointer}.trigger-action-card:hover{border-color:#999;transform:translateY(-1px)}.trigger-action-card.active{border-color:#2e7d32;background:#f8f9fa}.trigger-action-card.active.log{border-color:#1976d2;background:#e3f2fd}.trigger-action-card.active.skip{border-color:#d32f2f;background:#ffebee}.action-icon{font-size:24px;margin-bottom:8px;display:block}.action-title{font-size:14px;font-weight:600;margin-bottom:4px;color:#1a1a1a}.action-description{font-size:12px;color:#666;line-height:1.4}.lyrics-display{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;padding:24px}.lyrics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.lyrics-header h3{margin:0;font-size:16px;font-weight:500;color:#1a1a1a;letter-spacing:-.2px}.lyrics-meta{font-size:12px;color:#666}.lyrics-content{max-height:800px;overflow-y:auto;padding:16px;background:#fafafa;border-radius:2px;border:1px solid #e0e0e0;scrollbar-width:thick;scrollbar-color:#888 #f1f1f1}.lyrics-content::-webkit-scrollbar{width:12px}.lyrics-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:6px}.lyrics-content::-webkit-scrollbar-thumb{background:#888;border-radius:6px;border:2px solid #f1f1f1}.lyrics-content::-webkit-scrollbar-thumb:hover{background:#555}.lyrics-content pre{margin:0;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;line-height:1.6;color:#333;white-space:pre-wrap}.lyrics-placeholder{text-align:center;padding:40px 20px;color:#999}.lyrics-placeholder-icon{font-size:32px;margin-bottom:12px;display:block}.analysis-results-section{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014}.violations-summary{margin-top:20px;padding:16px;background:#fff3e0;border-left:3px solid #ff9800;border-radius:0 2px 2px 0}.violations-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#e65100;margin-bottom:12px}.violations-list{display:flex;flex-direction:column;gap:8px}.violation-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:2px;font-size:13px}.violation-metric{font-weight:500;color:#333}.violation-values{font-family:SF Mono,Monaco,monospace;font-size:12px;color:#d32f2f;font-weight:600}.fetching-lyrics{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#6b7280;background:#fafafa;border-radius:2px;border:1px solid #e0e0e0}.fetching-lyrics-spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top:3px solid #8B7355;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.fetching-lyrics-text{font-size:14px;font-weight:500;color:#374151;margin-bottom:4px}.fetching-lyrics-subtext{font-size:12px;color:#6b7280}@media (max-width: 1200px){.analysis-layout{grid-template-columns:1fr;gap:20px}}@media (max-width: 768px){.dashboard-content{gap:20px}.analysis-layout{gap:16px}.trigger-actions-grid{grid-template-columns:1fr;gap:12px}.dashboard-header h1{font-size:24px}.trigger-actions-panel,.lyrics-display{padding:20px}}@media (max-width: 480px){.dashboard-header h1{font-size:20px}.trigger-actions-panel,.lyrics-display{padding:16px}.lyrics-content{max-height:300px}}.logout-button{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.logout-button:hover{background:#b91c1c}.profile-sections{display:flex;flex-direction:column;gap:32px}.delete-warning{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #f87171;border-radius:8px;padding:16px;margin-bottom:16px}.delete-warning h3{color:#dc2626;margin:0 0 8px;font-size:16px;font-weight:600}.delete-warning p{color:#7f1d1d;margin:0;font-size:14px;line-height:1.4}.login-prompt{text-align:center;padding:40px 20px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;border:1px solid #cbd5e1;max-width:500px;margin:0 auto}.login-prompt h2{color:#1e293b;margin:0 0 12px;font-size:24px;font-weight:600}.login-prompt p{color:#64748b;margin:0 0 20px;font-size:16px;line-height:1.5}.profile-section{background:#fff;border:1px solid #e0e0e0;border-radius:2px;padding:24px;box-shadow:0 1px 3px #00000014}.profile-section h2{font-size:16px;font-weight:500;color:#1a1a1a;margin:0 0 20px;border-bottom:1px solid #e0e0e0;padding-bottom:12px;letter-spacing:-.2px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.profile-field{display:flex;flex-direction:column;gap:6px}.profile-field label{font-size:12px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.profile-field span{font-size:14px;color:#1a1a1a}.status-badge{display:inline-block;padding:4px 8px;border-radius:2px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-badge.verified,.status-badge.active,.status-badge.connected{background:#dcfce7;color:#166534}.status-badge.unverified{background:#fef3c7;color:#92400e}.status-badge.inactive{background:#fee2e2;color:#991b1b}.connected-accounts{display:flex;flex-direction:column;gap:16px}.connected-account{display:flex;align-items:center;justify-content:space-between;padding:16px;border:1px solid #e0e0e0;border-radius:2px;background:#fafafa}.account-info{display:flex;align-items:center;gap:12px}.account-icon{width:24px;height:24px;flex-shrink:0}.account-icon svg{width:100%;height:100%}.account-details{display:flex;flex-direction:column;gap:4px}.provider-name{font-size:14px;font-weight:500;color:#1a1a1a;text-transform:capitalize}.connection-date{font-size:12px;color:#666}.action-buttons{display:flex;flex-wrap:wrap;gap:12px}.action-button{padding:10px 16px;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid}.action-button.primary{background:#8b7355;color:#fff;border-color:#8b7355}.action-button.primary:hover{background:#6d5a47;border-color:#6d5a47}.action-button.secondary{background:#fff;color:#1a1a1a;border-color:#e0e0e0}.action-button.secondary:hover{background:#f5f5f5;border-color:#999}.action-button.danger{background:#dc2626;color:#fff;border-color:#dc2626}.action-button.danger:hover{background:#b91c1c;border-color:#b91c1c}.delete-warning{margin-top:16px;padding:12px 16px;background:#fee2e2;border:1px solid #fecaca;border-radius:2px}.delete-warning p{margin:0;font-size:14px;color:#991b1b}.error-message{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:2px;border:1px solid #fecaca;margin-bottom:24px;font-size:14px}.dashboard-container{min-height:100vh;background:#f8f9fa;padding:24px}.dashboard-content{max-width:1200px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.dashboard-header h1{font-size:28px;font-weight:300;margin:0;letter-spacing:-.5px;color:#1a1a1a}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#666}.loading-spinner{width:32px;height:32px;border:2px solid #e0e0e0;border-top:2px solid #8B7355;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@media (max-width: 768px){.dashboard-container{padding:16px}.profile-grid{grid-template-columns:1fr}.connected-account{flex-direction:column;align-items:flex-start;gap:12px}.action-buttons{flex-direction:column}.action-button{width:100%}}.legal-content{line-height:1.6;text-align:left}.legal-content p{margin-bottom:16px;color:#1a1a1a;text-align:left}.legal-content ul{margin:12px 0 16px 20px;padding:0;text-align:left}.legal-content li{margin-bottom:8px;color:#1a1a1a;text-align:left}.legal-content strong{font-weight:600;color:#1a1a1a}.legal-footer{margin-top:24px;padding-top:16px;border-top:1px solid #e0e0e0;font-size:14px;color:#666}.framework-selector{padding:0;margin:0}.framework-selector h3{margin:0 0 16px;font-size:14px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.framework-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}.framework-card{padding:16px 20px;border:1px solid #e0e0e0;border-radius:2px;background-color:#fff;color:#333;font-weight:400;font-size:14px;cursor:pointer;transition:all .2s ease;text-align:left;box-shadow:0 1px 3px #00000014;position:relative}.framework-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.framework-icon{display:flex;align-items:center;color:#666}.framework-name{margin:0;font-size:16px;font-weight:600;color:#1a1a1a}.framework-description{margin:0;font-size:13px;color:#666;line-height:1.4}.framework-card:hover{border-color:#999;transform:translateY(-1px);box-shadow:0 2px 6px #0000001f}.framework-card.selected{font-weight:500;color:#1a1a1a;background-color:#f8f9fa;border-color:#2e7d32;border-width:2px}.framework-card.selected:after{content:"✓";position:absolute;top:8px;right:12px;color:#2e7d32;font-weight:600;font-size:16px}.current-framework-text{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8f9fa;border-radius:2px;border:1px solid #e0e0e0;font-size:13px;color:#666;margin:0}.current-framework-text strong{color:#1a1a1a;font-weight:500}.current-framework-text:before{content:"→";color:#2e7d32;font-weight:600}.framework-selector p{padding:20px;text-align:center;color:#666;font-size:14px;margin:0;background:#f8f9fa;border-radius:2px;border:1px solid #e0e0e0}@media (max-width: 768px){.framework-list{grid-template-columns:1fr;gap:8px}.framework-card{padding:14px 16px}}@media (max-width: 480px){.framework-card{padding:12px 14px;font-size:13px}}.dynamic-slider label{display:block;margin-bottom:16px;font-weight:500;color:#1a1a1a;font-size:14px;letter-spacing:-.1px}.dynamic-slider label strong{color:#2e7d32;font-weight:600;margin-left:4px}.dynamic-slider input[type=range]{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;margin:12px 0;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.dynamic-slider input[type=range]::-webkit-slider-track{width:100%;height:6px;cursor:pointer;background:#e0e0e0;border-radius:3px;border:none}.dynamic-slider input[type=range]::-webkit-slider-thumb{height:20px;width:20px;border-radius:50%;background:#2e7d32;cursor:pointer;-webkit-appearance:none;border:2px solid #ffffff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.dynamic-slider input[type=range]::-webkit-slider-thumb:hover{background:#1b5e20;transform:scale(1.1)}.dynamic-slider input[type=range]::-moz-range-track{width:100%;height:6px;cursor:pointer;background:#e0e0e0;border-radius:3px;border:none}.dynamic-slider input[type=range]::-moz-range-thumb{height:16px;width:16px;border-radius:50%;background:#2e7d32;cursor:pointer;border:2px solid #ffffff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.dynamic-slider input[type=range]::-moz-range-thumb:hover{background:#1b5e20;transform:scale(1.1)}.slider-range-labels{display:flex;justify-content:space-between;font-size:11px;color:#666;margin-top:8px;padding:0 2px}.slider-range-labels span{text-align:center;flex:1;padding:0 4px;line-height:1.2}.dynamic-slider input[type=range]:focus{outline:none}.dynamic-slider input[type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 0 3px #2e7d3233}.dynamic-slider input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 3px #2e7d3233}@media (max-width: 480px){.dynamic-slider input[type=range]::-webkit-slider-thumb{height:24px;width:24px}.dynamic-slider input[type=range]::-moz-range-thumb{height:20px;width:20px}.slider-range-labels{font-size:10px}}.dynamic-dropdown label{display:block;margin-bottom:12px;font-weight:500;color:#1a1a1a;font-size:14px;letter-spacing:-.1px}.dynamic-dropdown select{width:100%;padding:12px 40px 12px 16px;border:1px solid #e0e0e0;border-radius:2px;background:#fff;color:#333;font-size:14px;font-family:inherit;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.dynamic-dropdown select:hover{border-color:#999}.dynamic-dropdown select:focus{outline:none;border-color:#2e7d32;box-shadow:0 0 0 2px #2e7d321a}.dynamic-dropdown select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed;border-color:#e0e0e0}.dynamic-dropdown select option{padding:8px 12px;background:#fff;color:#333}.dynamic-dropdown select option:hover{background:#f8f9fa}.dynamic-dropdown select option:checked{background:#2e7d32;color:#fff}.dynamic-dropdown .filter-interpretation-note{font-size:12px;color:#666;margin-top:8px;padding:8px 12px;background:#f8f9fa;border-radius:2px;border:1px solid #e9ecef;line-height:1.4}@media (max-width: 480px){.dynamic-dropdown select{padding:10px 36px 10px 14px;font-size:13px;background-size:14px;background-position:right 10px center}}.filter-panel{padding:0;margin:0}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:16px}.filter-panel h4{margin:0;font-size:14px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px;flex:1}.reset-defaults-button{background:#f8f9fa;border:1px solid #e0e0e0;color:#666;padding:8px 16px;border-radius:2px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.reset-defaults-button:hover:not(:disabled){background:#e9ecef;border-color:#ced4da;color:#495057}.reset-defaults-button:disabled{opacity:.6;cursor:not-allowed}.filter-control-container{margin-bottom:24px;padding:20px;background:#fff;border:1px solid #e0e0e0;border-radius:2px;box-shadow:0 1px 3px #00000014;transition:all .2s ease}.filter-control-container:hover{box-shadow:0 2px 6px #0000001f}.filter-control-container:last-child{margin-bottom:0}.filter-control-container>div[style*=marginTop]{margin-top:12px!important;padding:8px 12px;background:#f8f9fa;border-radius:2px;border:1px solid #e9ecef;font-size:12px!important;color:#666!important}.filter-control-container>div[style*=marginTop] span[style*=fontWeight]{color:#333!important;font-weight:500!important}.filter-item{margin-bottom:20px;padding:16px;border:1px solid #e0e0e0;border-radius:2px;background-color:#fff;box-shadow:0 1px 3px #00000014}.filter-item label{display:block;margin-bottom:12px;font-weight:500;color:#333;font-size:14px;letter-spacing:-.1px}.filter-item select{width:100%;padding:10px 12px;border-radius:2px;border:1px solid #e0e0e0;box-sizing:border-box;font-size:14px;background:#fff;color:#333;transition:border-color .2s ease}.filter-item select:focus{outline:none;border-color:#2e7d32;box-shadow:0 0 0 2px #2e7d321a}.filter-interpretation-note{font-size:12px;color:#666;margin-top:8px;padding:8px 12px;background:#f8f9fa;border-radius:2px;border:1px solid #e9ecef}.filter-panel-status{margin-top:16px;padding:12px 16px;border-radius:2px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px}.filter-panel-status.saving{background:#e3f2fd;color:#1565c0;border:1px solid #bbdefb}.filter-panel-status.saving:before{content:"";display:inline-block;width:12px;height:12px;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M21 12a9 9 0 11-6.219-8.56'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.filter-panel-status.error{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}.filter-panel-status.error:before{content:"";display:inline-block;width:12px;height:12px;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/%3E%3Cline x1='12' y1='9' x2='12' y2='13'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.filter-panel>p{padding:20px;text-align:center;color:#666;font-size:14px;margin:0;background:#f8f9fa;border-radius:2px;border:1px solid #e0e0e0}@media (max-width: 768px){.filter-control-container{padding:16px;margin-bottom:16px}.filter-panel-header{flex-direction:column;align-items:stretch;gap:12px}.filter-panel h4{text-align:center}.reset-defaults-button{width:100%;justify-content:center}}@media (max-width: 480px){.filter-control-container{padding:14px;margin-bottom:12px}.filter-item{padding:14px}.reset-defaults-button{padding:10px 16px;font-size:11px}}.email-preferences{width:100%}.email-preferences-header{margin-bottom:24px}.email-preferences-header h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#333}.email-preferences-header p{margin:0;font-size:14px;color:#666;line-height:1.4}.email-preferences-list{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.email-preference-item{display:flex;align-items:flex-start;justify-content:space-between;padding:16px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;transition:all .2s ease}.email-preference-item:hover{background:#f1f3f4;border-color:#dee2e6}.preference-content{flex:1;margin-right:16px}.preference-header{display:flex;align-items:center;margin-bottom:6px}.preference-icon{font-size:18px;margin-right:8px}.preference-title{margin:0;font-size:16px;font-weight:600;color:#333}.preference-description{margin:0;font-size:14px;color:#666;line-height:1.4}.preference-toggle{flex-shrink:0}.toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background-color:#007bff}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}.toggle-switch input:disabled+.toggle-slider{opacity:.6;cursor:not-allowed}.update-status{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:6px;font-size:14px;font-weight:500;margin-bottom:16px}.update-status.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.update-status.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.status-icon{font-weight:700}.email-preferences-footer{margin-top:20px;padding-top:16px;border-top:1px solid #e9ecef}.privacy-note{margin:0;font-size:13px;color:#666;line-height:1.4}.privacy-note strong{color:#333}@media (max-width: 768px){.email-preference-item{flex-direction:column;align-items:stretch}.preference-content{margin-right:0;margin-bottom:12px}.preference-toggle{align-self:flex-end}}.settings-page{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;color:#1a1a1a;line-height:1.5;padding:24px;max-width:800px;margin:0 auto}.settings-header{display:flex;align-items:center;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.back-button{background:none;border:none;font-size:24px;cursor:pointer;margin-right:16px;padding:8px;border-radius:2px;display:flex;align-items:center;color:#666;transition:all .2s ease}.back-button:hover{background-color:#f5f5f5;color:#333}.settings-header h1{margin:0;font-size:28px;font-weight:300;letter-spacing:-.5px;color:#1a1a1a}.settings-section{background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;margin-bottom:32px;overflow:hidden}.section-header{padding:24px 24px 0;margin-bottom:20px}.section-header h2{margin:0 0 8px;font-size:18px;font-weight:500;color:#1a1a1a;letter-spacing:-.3px}.section-description{font-size:14px;color:#666;margin:0;line-height:1.4}.section-content{padding:0 24px 24px}.protection-mode-section{border-left:3px solid #2E7D32}.protection-mode-controls{display:flex;align-items:center;gap:16px;margin-bottom:20px}.protection-mode-label{font-size:16px;font-weight:500;color:#1a1a1a;min-width:120px}.protection-toggle{display:inline-flex;border:1px solid #e0e0e0;border-radius:2px;overflow:hidden;background:#fff}.protection-toggle button{padding:12px 20px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;background:transparent;color:#666}.protection-toggle button.active{background:#1a1a1a;color:#fff}.protection-toggle button:not(.active):hover{background:#f5f5f5;color:#333}.protection-status{display:flex;align-items:center;gap:12px;padding:16px;background:#f8f9fa;border-radius:2px;border:1px solid #e0e0e0}.protection-status-icon{font-size:20px}.protection-status.protect{background:#e8f5e8;border-color:#2e7d32;color:#1b5e20}.protection-status.monitor{background:#e3f2fd;border-color:#bbdefb;color:#1565c0}.protection-status-text{font-size:14px;font-weight:500}.framework-section .section-content,.filter-settings-section .section-content{padding-top:0}.timezone-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.timezone-select{padding:10px 12px;border:1px solid #e0e0e0;border-radius:2px;font-size:14px;background:#fff;color:#333;min-width:200px}.timezone-detect-btn{padding:10px 16px;background:#f5f5f5;color:#333;border:1px solid #e0e0e0;border-radius:2px;cursor:pointer;font-size:14px;transition:all .2s ease}.timezone-detect-btn:hover{background:#e0e0e0}.timezone-status{color:#666;font-size:12px;font-style:italic}.spotify-status{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.status-indicator{font-weight:500;padding:4px 8px;border-radius:2px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.status-indicator.connected{background:#dcfce7;color:#166534}.status-indicator.disconnected{background:#fee2e2;color:#991b1b}.primary-button{background:#8b7355;color:#fff;border:1px solid #8B7355;padding:8px 16px;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.primary-button:hover{background:#6d5a47;border-color:#6d5a47}@media (max-width: 768px){.settings-page{padding:16px}.settings-header h1{font-size:24px}.protection-toggle{flex-direction:column;gap:8px}.protection-toggle button{width:100%}.trigger-actions-grid{grid-template-columns:1fr}.spotify-status{flex-direction:column;align-items:flex-start;gap:4px}.timezone-controls{flex-direction:column;align-items:flex-start}.timezone-select{min-width:100%}}@media (max-width: 480px){.settings-header h1{font-size:20px}.section-header,.section-content{padding-left:16px;padding-right:16px}.protection-toggle button{padding:10px 16px;font-size:13px}}.password-input-container{width:100%}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input{padding-right:48px!important}.password-toggle-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:#6b7280;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .2s ease}.password-toggle-btn:hover{color:#374151;background-color:#f3f4f6}.password-toggle-btn:focus{outline:2px solid #3b82f6;outline-offset:2px}.password-strength{margin-top:8px;display:flex;align-items:center;gap:8px}.password-strength-bar{flex:1;height:4px;background-color:#e5e7eb;border-radius:2px;overflow:hidden}.password-strength-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:2px}.password-strength-label{font-size:12px;font-weight:500;min-width:60px;text-align:right}.password-requirements{margin-top:8px;padding:12px;background-color:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.requirement{font-size:12px;color:#6b7280;margin-bottom:4px;display:flex;align-items:center;gap:4px}.requirement:last-child{margin-bottom:0}.requirement.met{color:#16a34a}.requirement:not(.met){opacity:.6}@media (prefers-color-scheme: dark){.password-toggle-btn{color:#9ca3af}.password-toggle-btn:hover{color:#d1d5db;background-color:#374151}.password-strength-bar{background-color:#374151}.password-requirements{background-color:#1f2937;border-color:#374151}.requirement{color:#9ca3af}.requirement.met{color:#22c55e}}.auth-page{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;min-height:100vh;background:#fafafa;display:flex;align-items:center;justify-content:center;padding:24px}.auth-container{width:100%;max-width:400px;background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;padding:48px 40px}.auth-header{text-align:center;margin-bottom:40px}.auth-header h1{font-size:24px;font-weight:300;margin:0 0 8px;letter-spacing:-.5px;color:#1a1a1a}.auth-header p{font-size:14px;color:#666;margin:0;font-weight:400}.auth-header a{color:#8b7355;text-decoration:none;font-weight:500}.auth-header a:hover{color:#6b5a42}.auth-form{margin-bottom:32px}.form-group:last-child{margin-bottom:0}.form-input{width:100%;padding:16px;border:1px solid #e0e0e0;border-radius:2px;font-size:14px;font-family:inherit;color:#1a1a1a;background:#fff;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#8b7355;box-shadow:0 0 0 2px #8b73551a}.form-input::placeholder{color:#999;font-weight:400}.form-input-group{display:flex;flex-direction:column;gap:0}.form-input-group .form-input:first-child{border-bottom:none;border-radius:2px 2px 0 0}.form-input-group .form-input:last-child{border-radius:0 0 2px 2px}.form-input-group .form-input:not(:first-child):not(:last-child){border-radius:0;border-bottom:none}.message{padding:16px;border-radius:2px;margin-bottom:20px;font-size:13px;line-height:1.4}.message.error{background:#ffebee;color:#d32f2f;border-left:3px solid #d32f2f}.message.success{background:#e8f5e8;color:#2e7d32;border-left:3px solid #2e7d32}.auth-button{width:100%;padding:16px;border:none;border-radius:2px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;box-sizing:border-box}.auth-button.primary{background:#8b7355;color:#fff}.auth-button.primary:hover:not(:disabled){background:#6b5a42;transform:translateY(-1px)}.auth-button.primary:disabled{background:#ccc;cursor:not-allowed;transform:none}.auth-button.secondary{background:#fff;color:#666;border:1px solid #e0e0e0}.auth-button.secondary:hover{background:#f5f5f5;border-color:#999;transform:translateY(-1px)}.oauth-section{margin-top:32px}.oauth-divider{position:relative;text-align:center;margin:24px 0}.oauth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e0e0e0}.oauth-divider span{background:#fff;padding:0 16px;font-size:12px;color:#999;font-weight:400}.oauth-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 640px){.oauth-buttons{grid-template-columns:1fr}}.oauth-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px;background:#fff;border:1px solid #e0e0e0;border-radius:2px;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;text-decoration:none}.oauth-button:hover{background:#f5f5f5;border-color:#999;transform:translateY(-1px)}.oauth-button.facebook{background:#1877f2;color:#fff;border-color:#1877f2}.oauth-button.facebook:hover{background:#166fe5;border-color:#166fe5}.oauth-button.apple{background:#000;color:#fff;border-color:#000}.oauth-button.apple:hover{background:#333;border-color:#333}.oauth-icon{width:18px;height:18px}.google-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px;background:#fff;border:1px solid #e0e0e0;border-radius:2px;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;text-decoration:none}.google-button:hover{background:#f5f5f5;border-color:#999;transform:translateY(-1px)}.google-icon{width:18px;height:18px}.auth-links{display:flex;flex-direction:column;gap:12px;margin-top:20px;text-align:center}.auth-link{font-size:13px;color:#8b7355;text-decoration:none;font-weight:500}.auth-link:hover{color:#6b5a42}.auth-link-button{background:none;border:none;font-size:13px;color:#8b7355;text-decoration:none;font-weight:500;cursor:pointer;padding:0;font-family:inherit;transition:color .2s ease}.auth-link-button:hover:not(:disabled){color:#6b5a42}.auth-link-button:disabled{color:#ccc;cursor:not-allowed}.loading-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-page{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;min-height:100vh;background:#fafafa;display:flex;align-items:center;justify-content:center;padding:24px}.status-container{width:100%;max-width:400px;background:#fff;border-radius:2px;box-shadow:0 1px 3px #00000014;padding:48px 40px;text-align:center}.status-icon{width:48px;height:48px;margin:0 auto 24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px}.status-icon.success{background:#e8f5e8;color:#2e7d32}.status-icon.error{background:#ffebee;color:#d32f2f}.status-title{font-size:20px;font-weight:300;margin:0 0 12px;letter-spacing:-.3px;color:#1a1a1a}.status-message{font-size:14px;color:#666;margin:0 0 32px;line-height:1.5}@media (max-width: 480px){.auth-container,.status-container{padding:32px 24px;margin:16px}.auth-header h1,.status-title{font-size:20px}.form-input,.auth-button{padding:14px}}.change-password-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.change-password-modal{background:#fff;border-radius:8px;padding:0;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.close-button{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover:not(:disabled){background-color:#f3f4f6;color:#374151}.close-button:disabled{opacity:.5;cursor:not-allowed}.change-password-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:6px;margin-bottom:16px;font-size:14px}.success-message{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:12px;border-radius:6px;margin-bottom:16px;font-size:14px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.cancel-button{background:#fff;border:1px solid #d1d5db;color:#374151;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.cancel-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.cancel-button:disabled{opacity:.5;cursor:not-allowed}.submit-button{background:#3b82f6;border:1px solid #3b82f6;color:#fff;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.submit-button:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.submit-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.change-password-modal{width:95%;margin:20px}.modal-header{padding:16px 20px}.change-password-form{padding:20px}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%;justify-content:center}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:1rem}.error-boundary-content{text-align:center;max-width:500px}.error-icon{color:#dc2626;margin-bottom:1rem;display:flex;justify-content:center}.error-boundary h2{color:#991b1b;margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.error-boundary p{color:#7f1d1d;margin-bottom:1.5rem;line-height:1.5}.error-boundary-button{background-color:#dc2626;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.error-boundary-button:hover{background-color:#b91c1c}.error-details{margin-top:1rem;text-align:left;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:1rem}.error-details summary{cursor:pointer;font-weight:600;margin-bottom:.5rem;color:#374151}.error-details pre{background-color:#1f2937;color:#f9fafb;padding:.75rem;border-radius:4px;overflow-x:auto;font-size:.875rem;margin:.5rem 0}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#212529}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#555}.app-footer{background:#1e293b;color:#e2e8f0;padding:24px 0;margin-top:40px;border-top:1px solid #334155}.footer-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.footer-nav{display:flex;gap:24px;flex-wrap:wrap}.footer-link{color:#cbd5e1;text-decoration:none;font-size:14px;transition:color .2s ease}.footer-link:hover{color:#f1f5f9}.footer-info p{margin:0;font-size:14px;color:#94a3b8}@media (max-width: 768px){.footer-content{flex-direction:column;text-align:center}.footer-nav{justify-content:center}}
