.modal-body p[data-v-fe08546c]{margin:0 0 12px}.modal-button-secondary[data-v-fe08546c]{background:var(--color-dark-border-primary)}.modal-button-secondary[data-v-fe08546c]:hover{background:var(--color-dark-border-secondary)}.banner-trial[data-v-b8ce7b4b]{background:linear-gradient(135deg,#667eea,#764ba2);border-left:4px solid #667eea}.banner-trial .banner-message[data-v-b8ce7b4b]{color:#fff;font-weight:500}.btn-action-trial[data-v-b8ce7b4b]{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-action-trial[data-v-b8ce7b4b]:hover{background:#ffffff4d;border-color:#ffffff80}.banner-trial .close-button[data-v-b8ce7b4b]{color:#fffc}.banner-trial .close-button[data-v-b8ce7b4b]:hover{color:#fff;background:#ffffff1a}.plan-card[data-v-7ee95b10]{border:2px solid var(--color-border-primary);border-radius:var(--radius-xl);padding:var(--spacing-4xl);position:relative;transition:var(--transition-slow);background:var(--color-card-bg);display:flex;flex-direction:column}.plan-card[data-v-7ee95b10]:hover{border-color:var(--brand-accent);box-shadow:var(--shadow-card-hover)}.plan-card.recommended[data-v-7ee95b10]{border-color:var(--brand-accent);box-shadow:var(--shadow-card)}.plan-card.compact[data-v-7ee95b10]{padding:var(--spacing-2xl)}.plan-badge[data-v-7ee95b10]{position:absolute;top:0;right:var(--spacing-xl);transform:translateY(-50%);background:var(--gradient-accent);color:var(--color-text-inverse);padding:var(--spacing-xs) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);box-shadow:var(--shadow-md);border:2px solid var(--color-card-bg)}.plan-card:not(.recommended) .plan-badge[data-v-7ee95b10]{background:var(--color-bg-secondary);color:var(--color-text-primary);border:2px solid var(--color-card-bg)}.plan-header[data-v-7ee95b10]{margin-bottom:var(--spacing-2xl)}.plan-header h3[data-v-7ee95b10]{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.plan-card.compact .plan-header h3[data-v-7ee95b10]{font-size:var(--font-size-xl)}.plan-subtitle[data-v-7ee95b10]{color:var(--color-text-tertiary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin:var(--spacing-xs) 0 0 0}.plan-card.compact .plan-subtitle[data-v-7ee95b10]{font-size:var(--font-size-xs)}.plan-description[data-v-7ee95b10]{color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);min-height:2.5em}.plan-card.compact .plan-description[data-v-7ee95b10]{font-size:var(--font-size-sm);min-height:2em}.plan-price[data-v-7ee95b10]{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-2xl);border-bottom:1px solid var(--color-border)}.price-line[data-v-7ee95b10]{display:flex;align-items:baseline}.price-text[data-v-7ee95b10]{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.plan-card.compact .price-text[data-v-7ee95b10]{font-size:var(--font-size-3xl)}.period[data-v-7ee95b10]{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.plan-card.compact .period[data-v-7ee95b10]{font-size:var(--font-size-base)}.plan-features[data-v-7ee95b10]{list-style:none;padding:0;margin:0 0 var(--spacing-3xl) 0;flex:1}.plan-features li[data-v-7ee95b10]{padding:var(--spacing-sm) 0;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-base)}.plan-card.compact .plan-features li[data-v-7ee95b10]{font-size:var(--font-size-sm);padding:var(--spacing-xs) 0}.checkmark[data-v-7ee95b10]{color:var(--brand-success);font-weight:var(--font-weight-bold);font-size:var(--font-size-xl)}.btn-action[data-v-7ee95b10]{width:100%;padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-lg);border-radius:var(--radius-lg);margin-top:auto}.btn-action-compact[data-v-7ee95b10]{padding:var(--spacing-md) var(--spacing-2xl);font-size:var(--font-size-base)}.disabled-notice[data-v-7ee95b10]{text-align:center;padding:var(--spacing-lg);background:var(--color-bg-secondary);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-style:italic}.modal-overlay[data-v-8f00a899]{animation:fadeIn var(--transition-normal)}.modal-content[data-v-8f00a899]{animation:slideUp var(--transition-slow)}.modal-header[data-v-8f00a899]{padding:var(--spacing-2xl) var(--spacing-3xl);border-bottom:1px solid var(--color-border)}.modal-header h2[data-v-8f00a899]{font-size:var(--font-size-2xl)}.modal-body[data-v-8f00a899]{padding:var(--spacing-3xl)}.description[data-v-8f00a899]{text-align:center;font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--spacing-3xl)}.loading-message[data-v-8f00a899]{text-align:center;padding:var(--spacing-4xl);color:var(--color-text-secondary);font-size:var(--font-size-md)}.modal-footer[data-v-8f00a899]{gap:var(--spacing-md);padding:var(--spacing-2xl) var(--spacing-3xl);border-top:1px solid var(--color-border);justify-content:center}.hamburger-menu[data-v-848cbab1]{position:relative}.hamburger-button[data-v-848cbab1]{background:none;border:none;font-size:var(--font-size-xl);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-beige);transition:var(--transition-normal);line-height:var(--line-height-none)}.hamburger-button[data-v-848cbab1]:hover{color:var(--color-text-inverse)}.hamburger-button[data-v-848cbab1]:focus{outline:2px solid var(--brand-accent);outline-offset:2px;border-radius:var(--radius-sm)}.menu-overlay[data-v-848cbab1]{position:fixed;inset:0;background:var(--color-overlay);z-index:var(--z-overlay)}.menu-panel[data-v-848cbab1]{position:fixed;top:0;left:0;bottom:0;width:300px;background:var(--color-card-bg);box-shadow:var(--shadow-lg);z-index:var(--z-dialog);display:flex;flex-direction:column}.menu-header[data-v-848cbab1]{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.menu-header h2[data-v-848cbab1]{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary)}.menu-items[data-v-848cbab1]{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto}.menu-items li[data-v-848cbab1]{border-bottom:1px solid var(--color-divider)}.menu-item[data-v-848cbab1]{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);color:var(--color-text-primary);text-decoration:none;transition:var(--transition-normal)}.menu-item[data-v-848cbab1]:hover{background-color:var(--color-hover)}.menu-item.router-link-active[data-v-848cbab1]{background-color:var(--brand-accent);color:var(--color-dark-text-primary)}.menu-icon[data-v-848cbab1]{width:24px;text-align:center}.menu-label[data-v-848cbab1]{font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.admin-menu-item[data-v-848cbab1]{border-top:2px solid var(--color-border)}.slide-enter-active[data-v-848cbab1],.slide-leave-active[data-v-848cbab1]{transition:var(--transition-slow)}.slide-enter-from[data-v-848cbab1],.slide-leave-to[data-v-848cbab1]{transform:translate(-100%)}.slide-enter-to[data-v-848cbab1],.slide-leave-from[data-v-848cbab1]{transform:translate(0)}@media (max-width: 768px){.menu-panel[data-v-848cbab1]{width:80%;max-width:300px}}:root{--brand-header: #cc0000;--brand-header-dark: #990000;--brand-header-light: #ff0000;--brand-accent: #667eea;--brand-accent-dark: #764ba2;--brand-accent-hover: #5568d3;--brand-accent-light: #8799ee;--brand-success: #28a745;--brand-success-dark: #20873a;--brand-success-light: #2ecc51;--brand-warning: #ffc107;--brand-warning-dark: #ff9800;--brand-warning-light: #ffcd38;--brand-warning-light-alt: #ffa726;--brand-warning-orange: #ffa500;--brand-warning-darker: #e65100;--brand-warning-medium: #fb8c00;--brand-warning-hover: #f57c00;--brand-warning-bg: #fff3cd;--brand-warning-text: #856404;--brand-danger: #dc3545;--brand-danger-dark: #c82333;--brand-danger-light: #e74c3c;--brand-danger-darker: #da190b;--brand-info: #1565c0;--brand-info-light: #3b82f6;--brand-amber: #f59e0b;--color-gold: #ffd700;--color-beige: #f5f5dc;--brand-spotify: #1DB954;--brand-spotify-hover: #1ed760;--button-success: #4caf50;--button-success-hover: #43a047;--button-danger: #ef5350;--button-danger-hover: #d32f2f;--button-neutral: #444444;--button-neutral-hover: #555555;--gradient-header: linear-gradient(135deg, var(--brand-header) 0%, var(--brand-header-dark) 100%);--gradient-accent: linear-gradient(135deg, var(--brand-accent) 0%, var(--brand-accent-dark) 100%);--gradient-success: linear-gradient(135deg, var(--brand-success) 0%, var(--brand-success-dark) 100%);--gradient-success-hover: linear-gradient(135deg, var(--brand-success-light) 0%, var(--brand-success) 100%);--gradient-danger: linear-gradient(135deg, var(--brand-danger) 0%, var(--brand-danger-dark) 100%);--gradient-danger-hover: linear-gradient(135deg, var(--brand-danger-light) 0%, var(--brand-danger) 100%);--gradient-warning: linear-gradient(135deg, var(--brand-warning) 0%, var(--brand-warning-dark) 100%);--gradient-warning-hover: linear-gradient(135deg, var(--brand-warning-light) 0%, var(--brand-warning-light-alt) 100%);--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f5;--color-bg-tertiary: #f8f9fa;--color-bg-overlay: rgba(255, 255, 255, .95);--color-card-bg: #ffffff;--color-card-bg-gradient: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);--color-card-bg-light: linear-gradient(135deg, #f8f9ff 0%, #f0f3ff 100%);--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-tertiary: #999999;--color-text-disabled: #cccccc;--color-text-inverse: #ffffff;--color-border-primary: var(--color-status-neutral-bg);--color-border-secondary: var(--color-bg-neutral-4);--color-border-focus: var(--brand-accent);--color-border-inverse: rgba(255, 255, 255, .5);--color-hover-bg: #e9ecef;--color-hover-bg-light: var(--color-bg-secondary);--color-hover-inverse: rgba(255, 255, 255, .1);--color-active-bg: rgba(102, 126, 234, .1);--color-current-song-bg: linear-gradient(135deg, #fff5f5 0%, #ffe0e0 100%);--color-current-song-border: var(--brand-header);--color-drag-over-bg: linear-gradient(90deg, rgba(102, 126, 234, .2) 0%, rgba(118, 75, 162, .2) 100%);--color-banner-info: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);--color-banner-warning: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);--color-status-success-bg: #e8f5e9;--color-status-success-text: #2e7d32;--color-status-info-bg: #e3f2fd;--color-status-info-text: #1565c0;--color-status-warning-bg: #fff3e0;--color-status-warning-text: #e65100;--color-status-error-bg: #ffebee;--color-status-error-text: #c62828;--color-status-neutral-bg: #e0e0e0;--color-status-neutral-text: #666666;--color-bg-error-light: #ffcdd2;--color-bg-neutral-1: #fafafa;--color-bg-neutral-2: #f5f5f5;--color-bg-neutral-3: var(--color-bg-secondary);--color-bg-neutral-4: #eeeeee;--color-bg-neutral-5: var(--color-status-neutral-bg);--color-bg-neutral-6: var(--color-dark-text-tertiary);--color-border-error: #ef9a9a;--color-border-light: #f0f0f0;--color-border-medium: var(--color-dark-text-secondary);--color-spinner-track: #e0e0e0;--color-spinner-active: #333333;--color-modal-overlay: rgba(0, 0, 0, .6);--color-modal-overlay-dark: rgba(0, 0, 0, .7);--color-hamburger-overlay: rgba(0, 0, 0, .5);--color-overlay-subtle: rgba(0, 0, 0, .1);--color-overlay-medium: rgba(0, 0, 0, .2);--color-white-alpha-20: rgba(255, 255, 255, .2);--color-white-alpha-95: rgba(255, 255, 255, .95);--color-danger-alpha-10: rgba(244, 67, 54, .1);--color-success-alpha-10: rgba(76, 175, 80, .1);--color-dark-bg-primary: #1a1a1a;--color-dark-bg-secondary: #2a2a2a;--color-dark-bg-tertiary: #2d2d2d;--color-dark-bg-quaternary: #3a3a3a;--color-dark-bg-hover: #333333;--color-dark-bg-active: #404040;--color-dark-text-primary: #ffffff;--color-dark-text-secondary: #dddddd;--color-dark-text-tertiary: #cccccc;--color-dark-text-muted: #999999;--color-dark-text-subtle: #666666;--color-dark-text-code: #d4d4d4;--color-dark-border-primary: #444444;--color-dark-border-secondary: #555555;--color-dark-border-subtle: #333333;--spacing-xxs: 2px;--spacing-xs: 4px;--spacing-6: 6px;--spacing-sm: 8px;--spacing-10: 10px;--spacing-md: 12px;--spacing-15: 15px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 30px;--spacing-32: 32px;--spacing-4xl: 40px;--spacing-48: 48px;--spacing-huge: 64px;--radius-none: 0;--radius-xs: 3px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 50px;--radius-circle: 50%;--button-height-sm: 32px;--button-height-md: 40px;--button-height-lg: 48px;--input-height-sm: 32px;--input-height-md: 40px;--input-height-lg: 48px;--icon-size-md: 20px;--z-base: 1;--z-footer: 50;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 999;--z-menu: 1000;--z-dialog: 1000;--z-modal: 2000;--z-modal-max: 2500;--z-toast: 5000;--z-upload-progress: 10000;--z-max: 10000;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .15);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .2);--shadow-dialog: 0 4px 20px rgba(0, 0, 0, .3);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .3);--shadow-primary-sm: 0 4px 12px rgba(102, 126, 234, .15);--shadow-primary-md: 0 8px 24px rgba(102, 126, 234, .2);--shadow-primary-lg: 0 8px 24px rgba(102, 126, 234, .4);--shadow-primary-hover: 0 6px 20px rgba(102, 126, 234, .4);--shadow-primary-selected: 0 8px 24px rgba(102, 126, 234, .3);--shadow-button: 0 2px 4px rgba(0, 0, 0, .1);--shadow-button-hover: 0 4px 8px rgba(0, 0, 0, .2);--shadow-button-active: 0 1px 2px rgba(0, 0, 0, .1);--shadow-header: 0 2px 8px rgba(204, 0, 0, .2);--shadow-success-hover: 0 8px 16px rgba(40, 167, 69, .4);--shadow-warning-hover: 0 4px 12px rgba(251, 140, 0, .4);--shadow-danger-glow: 0 0 12px rgba(255, 51, 51, .8), 0 0 24px rgba(255, 51, 51, .4);--shadow-danger-glow-intense: 0 0 16px rgba(255, 0, 0, 1), 0 0 32px rgba(255, 0, 0, .6);--shadow-warning-glow: 0 0 6px rgba(253, 216, 53, .5);--shadow-spotify: 0 2px 8px rgba(29, 185, 84, .3);--shadow-spotify-hover: 0 4px 12px rgba(29, 185, 84, .4);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-timing-ease-out: cubic-bezier(.4, 0, .2, 1);--transition-timing-ease-in: cubic-bezier(.4, 0, 1, 1);--transition-timing-ease-in-out: cubic-bezier(.4, 0, .2, 1);--font-family-base: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--font-family-mono: "Courier New", Courier, monospace;--font-size-xs: .75em;--font-size-sm: .875em;--font-size-base: 1em;--font-size-md: 1.125em;--font-size-lg: 1.25em;--font-size-xl: 1.5em;--font-size-2xl: 2em;--font-size-3xl: 2.5em;--font-size-4xl: 3em;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-none: 1;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.6;--line-height-loose: 1.8;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .5px;--letter-spacing-wider: 1px;--opacity-disabled: .4;--opacity-muted: .5;--opacity-secondary: .6;--opacity-hint: .7;--opacity-moderate: .75;--opacity-visible: .85;--opacity-near-full: .95;--opacity-full: 1;--vh: 1vh;--header-height: calc(var(--vh, 1vh) * 7.2);--main-padding: calc(var(--vh, 1vh) * 6);--playlist-selector-height: calc(var(--vh, 1vh) * 19);--playlist-header-height: calc(var(--vh, 1vh) * 6);--playlist-container-padding: calc(var(--vh, 1vh) * 4);--body-padding: var(--spacing-4xl);--component-gaps: calc(var(--vh, 1vh) * 4);--playlist-max-height-offset: calc( var(--header-height) + var(--main-padding) + var(--playlist-selector-height) + var(--playlist-header-height) + var(--playlist-container-padding) + var(--body-padding) + var(--component-gaps) );--dialog-width-xs: 400px;--dialog-width-sm: 500px;--dialog-width-md: 600px;--dialog-width-lg: 800px;--dialog-width-xl: 1000px;--scrollbar-width: 8px;--scrollbar-track-bg: #f1f1f1;--scrollbar-thumb-bg: var(--gradient-accent);--scrollbar-thumb-hover-bg: var(--gradient-accent)}.modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center}.modal-overlay-dialog{background:var(--color-hamburger-overlay);z-index:var(--z-dialog)}.modal-overlay-modal{background:var(--color-modal-overlay-dark);z-index:var(--z-modal)}.modal-overlay-light{background:var(--color-overlay)}.spinner{border:4px solid var(--color-spinner-track);border-top:4px solid var(--color-spinner-active);border-radius:var(--radius-circle);animation:spin 1s linear infinite}.spinner-sm{width:32px;height:32px}.spinner-md{width:40px;height:40px}.spinner-lg{width:var(--spacing-4xl);height:var(--spacing-4xl)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.message{padding:var(--spacing-md);border-radius:var(--radius-lg);text-align:center}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2xl);border-bottom:1px solid var(--color-border-primary)}.modal-header h2,.modal-header h3{margin:0;color:var(--color-text-primary)}.modal-header-compact{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-dark-border-primary)}.modal-header-compact h3{font-size:var(--font-size-md);color:var(--color-dark-text-primary)}.modal-body{padding:var(--spacing-xl)}.modal-body p{margin:0;color:var(--color-dark-text-secondary);line-height:var(--line-height-normal)}.modal-footer{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-dark-border-primary);display:flex;justify-content:flex-end;gap:var(--spacing-10)}.modal-input{width:100%;padding:var(--spacing-sm) 12px;border:1px solid var(--color-dark-border-primary);border-radius:var(--radius-sm);background:var(--color-dark-bg-primary);color:var(--color-dark-text-primary);font-size:var(--font-size-sm);box-sizing:border-box}.modal-input:focus{outline:none;border-color:var(--brand-accent)}.modal-dialog{background:var(--color-dark-bg-tertiary);border-radius:var(--radius-lg);min-width:400px;max-width:500px;box-shadow:var(--shadow-dialog)}@media (max-width: 480px){.modal-dialog{min-width:0;width:95%}}.modal-container{background:#fff;border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-dialog)}.modal-content{background:var(--color-card-bg);border-radius:var(--radius-xl);max-width:800px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-modal)}.modal-button{padding:var(--spacing-10) var(--spacing-xl);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);cursor:pointer;transition:all .2s}.modal-button-primary{background:var(--gradient-accent);color:var(--color-dark-text-primary)}.modal-button-primary:hover{background:var(--brand-accent-hover)}.modal-button-secondary{background:var(--button-neutral);color:var(--color-dark-text-primary)}.modal-button-secondary:hover{background:var(--button-neutral-hover)}.btn-primary{padding:var(--spacing-10) var(--spacing-xl);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);cursor:pointer;transition:all .2s;background:var(--gradient-accent);color:var(--color-dark-text-primary)}.btn-primary:hover:not(:disabled){background:var(--brand-accent-hover)}.btn-secondary{padding:var(--spacing-10) var(--spacing-xl);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);cursor:pointer;transition:all .2s;background:var(--color-dark-border-secondary);color:var(--color-dark-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-dark-text-subtle)}.btn-danger{padding:var(--spacing-10) var(--spacing-xl);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);cursor:pointer;transition:all .2s;background:var(--button-danger);color:var(--color-dark-text-primary)}.btn-danger:hover:not(:disabled){background:var(--brand-danger-darker);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:disabled,.btn-secondary:disabled,.btn-danger:disabled{opacity:var(--opacity-muted);cursor:not-allowed}.btn-action{background:var(--gradient-accent);color:var(--color-dark-text-primary);border:none;padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);white-space:nowrap}.btn-action:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-primary-lg);filter:brightness(1.1)}.btn-action:active:not(:disabled){transform:translateY(0)}.btn-action:disabled{opacity:var(--opacity-muted);cursor:not-allowed;transform:none}.btn-action-sm{padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-sm)}.btn-action-lg{padding:var(--spacing-lg) var(--spacing-4xl);font-size:var(--font-size-lg)}.btn-outline{background:transparent;color:var(--color-text-secondary);border:2px solid var(--color-border);padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);white-space:nowrap}.btn-outline:hover:not(:disabled){background:var(--color-hover-bg);border-color:var(--color-text-primary);color:var(--color-text-primary);transform:translateY(-2px)}.btn-outline:active:not(:disabled){transform:translateY(0)}.btn-outline:disabled{opacity:var(--opacity-muted);cursor:not-allowed}.btn-outline-inverse{background:transparent;color:var(--color-dark-text-primary);border:2px solid white;padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);white-space:nowrap}.btn-outline-inverse:hover:not(:disabled){background:#fff;color:var(--brand-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline-lg{padding:var(--spacing-lg) var(--spacing-3xl);font-size:var(--font-size-md)}.btn-tertiary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal)}.btn-tertiary:hover:not(:disabled){background:var(--color-hover-bg);border-color:var(--color-border-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-tertiary:active:not(:disabled){transform:scale(.98)}.btn-tertiary:disabled{opacity:var(--opacity-muted);cursor:not-allowed}.btn-action-warning{background:var(--brand-warning-medium);border:2px solid var(--brand-warning-darker);color:var(--color-dark-text-primary)}.btn-action-warning:hover:not(:disabled){background:var(--brand-warning-hover);box-shadow:var(--shadow-warning-hover)}.btn-action-inverse{background:#fff;color:var(--brand-accent)}.btn-action-inverse:hover:not(:disabled){box-shadow:var(--shadow-md)}.close-button{background:transparent;border:none;font-size:var(--font-size-xl);color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-normal);line-height:var(--line-height-none)}.close-button:hover{color:var(--color-text-primary)}.error-message-bordered{background:var(--color-danger-alpha-10);color:var(--button-danger);padding:var(--spacing-10);border-radius:var(--radius-sm);border-left:var(--spacing-xs) solid var(--button-danger)}.error-message{margin-top:var(--spacing-lg)}.error-message-minimal{color:var(--button-danger-hover)}.success-message{background:#667eea1a;color:var(--brand-accent);padding:var(--spacing-10);border-radius:var(--radius-sm);border-left:var(--spacing-xs) solid var(--brand-accent)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-48);text-align:center}.loading-message{text-align:center;padding:var(--spacing-huge) var(--spacing-xl)}.loading-message p{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin-top:var(--spacing-lg)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item.full-width{grid-column:1 / -1}.info-item label{font-size:var(--font-size-sm);color:var(--color-dark-text-subtle);font-weight:var(--font-weight-semibold)}.info-item span{font-size:var(--font-size-base);color:var(--color-dark-bg-hover)}.badge{display:inline-block;padding:.25rem .6rem;border-radius:var(--radius-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.badge.active{background:var(--color-status-success-bg);color:var(--color-status-success-text)}.badge.blocked{background:var(--button-danger);color:var(--color-dark-text-primary)}.badge.unverified{background:var(--brand-warning-orange);color:var(--color-dark-text-primary)}.badge.free{background:var(--color-status-neutral-bg);color:var(--color-dark-text-subtle)}.badge.basic{background:var(--color-status-info-bg);color:var(--color-status-info-text)}.badge.premium{background:var(--color-status-success-bg);color:var(--color-status-success-text)}.playlist-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--color-bg-neutral-2);border-radius:var(--radius-sm);border:1px solid var(--color-border-primary)}.activity-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--color-bg-neutral-2);border-radius:var(--radius-sm)}.no-data,.empty-message{text-align:center;padding:var(--spacing-32);color:var(--color-dark-text-muted)}.empty-message{padding:var(--spacing-huge) var(--spacing-xl);color:var(--color-text-secondary);font-size:var(--font-size-lg)}.btn-retry{padding:.5rem 1rem;background:var(--color-dark-bg-hover);color:var(--color-dark-text-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.btn-retry:hover{background:var(--color-dark-border-secondary)}.modal-enter-active,.modal-leave-active{transition:var(--transition-fast)}.modal-enter-from,.modal-leave-to{opacity:0}.modal-enter-active .modal-dialog,.modal-leave-active .modal-dialog{transition:var(--transition-fast)}.modal-enter-from .modal-dialog,.modal-leave-to .modal-dialog{transform:scale(.9)}.banner-base{position:sticky;top:0;z-index:var(--z-sticky);padding:var(--spacing-md) var(--spacing-xl);border-bottom:1px solid var(--color-overlay-subtle);animation:slideDown .3s ease-out}.banner-info{background:var(--color-banner-info);color:var(--brand-info)}.banner-warning{background:var(--color-banner-warning);color:var(--brand-warning-darker)}.banner-error{background:var(--color-bg-error-light);color:var(--color-text-error);border-color:var(--color-border-error)}.banner-content{display:flex;align-items:center;gap:var(--spacing-md);max-width:1200px;margin:0 auto}.banner-message{flex:1;font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.banner-button{border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;white-space:nowrap;transition:var(--transition-fast)}.banner-button:hover{transform:translateY(-2px)}.banner-button:active{transform:translateY(0)}.tab-card{background:var(--color-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md)}.card-title{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-lg) 0;font-size:var(--font-size-lg);color:var(--color-text-primary)}.icon-nano{font-size:var(--font-size-sm)}.icon-micro{font-size:var(--font-size-base)}.icon-tiny{font-size:var(--font-size-md);flex-shrink:0}.icon-xs{font-size:var(--font-size-lg)}.icon-sm{font-size:var(--font-size-xl)}.icon-lg{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg)}.card-interactive{background:var(--color-card-bg);border-radius:var(--radius-xl);padding:var(--spacing-3xl);box-shadow:var(--shadow-card);transition:var(--transition-normal);text-align:center;text-decoration:none;color:inherit;cursor:pointer;display:block;max-width:400px;margin:0 auto}.card-interactive:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.section-header{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-4xl);text-align:center;color:var(--color-text-primary)}.page-header{text-align:center;margin-bottom:var(--spacing-huge)}.page-header-left{text-align:left;margin-bottom:var(--spacing-xl)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.page-title-hero{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg);color:var(--color-text-primary);background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-title-lg{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.subtitle{font-size:var(--font-size-xl);color:var(--color-text-secondary);margin:0}.subtitle-lg{font-size:var(--font-size-xl);color:var(--color-text-secondary);margin-bottom:var(--spacing-4xl)}.section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.grid-responsive{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-2xl)}.grid-responsive-lg{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-3xl)}.flex-between{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border-light)}.info-row:last-child{border-bottom:none}.info-label{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.info-value{color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.badge-active{background:var(--brand-success-bg);color:var(--brand-success)}.badge-expired{background:var(--brand-danger-bg);color:var(--brand-danger)}.badge-free{background:var(--color-bg-tertiary);color:var(--color-text-tertiary)}.badge-warning{background:var(--brand-warning-bg);color:var(--brand-warning)}.section-header-collapsible{display:flex;align-items:center;gap:10px;padding:var(--spacing-15) var(--spacing-xl);background:var(--gradient-accent);color:var(--color-text-inverse);min-height:50px;box-sizing:border-box;flex-wrap:nowrap}.section-header-collapsible h3{margin:0;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);line-height:var(--line-height-tight);color:var(--color-text-inverse)}.section-header-collapsible .collapse-button{background:transparent;border:none;color:var(--color-text-inverse);font-size:var(--font-size-base);cursor:pointer;padding:0;width:var(--icon-size-md);height:var(--icon-size-md);display:flex;align-items:center;justify-content:center;transition:var(--transition-normal);box-shadow:none;border-radius:var(--radius-none)}.section-header-collapsible .collapse-button:hover{transform:scale(1.1)}.section-header-collapsible .presenter-mode-indicator{font-size:var(--font-size-base)}.section-container-collapsible{background:var(--color-card-bg-gradient);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:calc(var(--vh, 1vh) * 2);overflow:hidden}:root{--vh: 1vh;--header-height: calc(var(--vh, 1vh) * 7.2);--main-padding: calc(var(--vh, 1vh) * 6);--playlist-selector-height: calc(var(--vh, 1vh) * 19);--playlist-header-height: calc(var(--vh, 1vh) * 6);--playlist-container-padding: calc(var(--vh, 1vh) * 4);--body-padding: var(--spacing-4xl);--component-gaps: calc(var(--vh, 1vh) * 4);--playlist-max-height-offset: calc(var(--header-height) + var(--main-padding) + var(--playlist-selector-height) + var(--playlist-header-height) + var(--playlist-container-padding) + var(--body-padding) + var(--component-gaps))}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-base);background:url(/masonic_cross.jpg) center/cover no-repeat fixed;color:var(--color-text-primary);min-height:calc(var(--vh, 1vh) * 100);padding:var(--spacing-xl);position:relative}body:before{content:"";position:fixed;inset:0;background:#ffffffb3;z-index:-1}#app{max-width:min(1400px,95vw);margin:0 auto;background:var(--color-card-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);overflow:visible}header{background:var(--gradient-header);color:var(--color-text-inverse);padding:var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-xl)}header .header-left{display:flex;align-items:center;gap:var(--spacing-md)}header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);text-shadow:0 2px 4px rgba(0,0,0,.2);margin:0}main{padding:calc(var(--vh, 1vh) * 3)}.main-layout{display:flex;gap:calc(var(--vh, 1vh) * 3);align-items:flex-start}.left-panel{flex:0 0 min(500px,35vw);display:flex;flex-direction:column;gap:calc(var(--vh, 1vh) * 2)}.right-panel{flex:1;min-width:0}#now-playing-container{margin-bottom:0}.now-playing{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm)}.current-song-info h3{color:var(--brand-header);font-size:var(--font-size-lg);margin-bottom:10px}.next-song-info{margin-top:15px;padding-top:15px;border-top:1px solid rgba(0,0,0,.1)}.next-song-info h4{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.song-details{margin-top:5px}.song-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:4px}.next-song-info .song-title{font-size:var(--font-size-base)}.song-artist{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.song-notes{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:3px}.controls{display:flex;justify-content:center;gap:15px;margin:var(--spacing-xl) 0;padding:var(--spacing-xl);border:2px solid var(--color-border-primary);border-radius:var(--radius-xl);background:#ffffff80}.fadeout-control{display:flex;flex-direction:column;align-items:center;gap:10px;padding:var(--spacing-xl);background:var(--color-card-bg-gradient);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl)}.fadeout-control label{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.fadeout-control #fadeout-value{color:var(--brand-header);font-weight:var(--font-weight-bold)}.fadeout-control input[type=range],.sound-control-item input[type=range]{width:100%;height:6px;border-radius:var(--radius-xs);background:var(--gradient-accent);outline:none;-webkit-appearance:none}.fadeout-control input[type=range]{max-width:300px}.fadeout-control input[type=range]::-webkit-slider-track,.sound-control-item input[type=range]::-webkit-slider-track{height:6px;border-radius:var(--radius-xs)}.fadeout-control input[type=range]::-moz-range-track,.sound-control-item input[type=range]::-moz-range-track{height:6px;border-radius:var(--radius-xs);background:var(--gradient-accent);border:none}.fadeout-control input[type=range]::-webkit-slider-thumb,.sound-control-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:var(--icon-size-md);height:var(--icon-size-md);border-radius:var(--radius-circle);background:var(--brand-header);cursor:pointer;box-shadow:var(--shadow-sm);transition:var(--transition-normal)}.fadeout-control input[type=range]::-webkit-slider-thumb:hover,.sound-control-item input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:var(--shadow-button-hover)}.fadeout-control input[type=range]::-moz-range-thumb,.sound-control-item input[type=range]::-moz-range-thumb{width:var(--icon-size-md);height:var(--icon-size-md);border-radius:var(--radius-circle);background:var(--brand-header);cursor:pointer;border:none;box-shadow:var(--shadow-sm);transition:var(--transition-normal)}.fadeout-control input[type=range]::-moz-range-thumb:hover,.sound-control-item input[type=range]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:var(--shadow-button-hover)}.sound-control-content{padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-xl)}.sound-control-item{display:flex;flex-direction:column;gap:10px}.sound-control-item label{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);display:flex;justify-content:space-between;align-items:center}.sound-control-item .control-value{color:var(--brand-header);font-weight:var(--font-weight-bold);margin-left:10px}.presenter-mode-toggle{border-top:1px solid var(--color-border-primary);padding-top:15px;margin-top:5px}.presenter-mode-toggle label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);justify-content:flex-start;line-height:var(--line-height-tight);min-height:var(--icon-size-md)}.presenter-mode-toggle label>span:first-of-type{flex:0 0 auto}.presenter-mode-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--brand-header)}.presenter-mode-toggle .lock-icon{margin-left:auto;font-size:var(--font-size-base);line-height:var(--line-height-none)}.presenter-mode-indicator{margin-left:10px;font-size:var(--font-size-base);line-height:var(--line-height-none);opacity:var(--opacity-visible);animation:subtle-pulse 2s ease-in-out infinite;display:inline-flex;align-items:center;justify-content:center}@keyframes subtle-pulse{0%,to{opacity:var(--opacity-visible)}50%{opacity:var(--opacity-secondary)}}.control-button{background:var(--gradient-accent);border:none;color:var(--color-text-inverse);padding:var(--spacing-xl);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--font-size-base);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:var(--transition-slow);box-shadow:var(--shadow-sm);min-width:120px;flex:1}.control-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-button-hover);filter:brightness(1.1)}.control-button:active{transform:translateY(0)}.control-button.play-pause{background:var(--gradient-header);position:relative;overflow:hidden}.control-button.fading{opacity:var(--opacity-hint);animation:pulse 1s infinite}.fadeout-cancel-area{position:absolute;top:0;left:6px;right:6px;height:35%;background:linear-gradient(180deg,#f33,#f33c);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:15;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 0 12px #f33c,0 0 24px #f336;animation:cancel-glow 1.5s infinite;transition:background .2s ease,box-shadow .2s ease}.fadeout-cancel-area:hover{background:linear-gradient(180deg,red,#ff0000e6);box-shadow:var(--shadow-danger-glow-intense)}.fadeout-cancel-area .cancel-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-inverse);text-shadow:0 0 8px rgba(0,0,0,.8),0 2px 4px rgba(0,0,0,.5);letter-spacing:1px}@keyframes cancel-glow{0%,to{box-shadow:var(--shadow-danger-glow)}50%{box-shadow:var(--shadow-danger-glow-intense)}}.fadeout-progress-bar-left{position:absolute;bottom:0;left:0;width:6px;background:linear-gradient(180deg,#fdd835,#f9a825);transition:height .1s linear;box-shadow:var(--shadow-warning-glow);z-index:10;border-radius:var(--radius-lg) 0 0 var(--radius-lg);opacity:var(--opacity-visible)}.fadeout-progress-bar-right{position:absolute;bottom:0;right:0;width:6px;background:linear-gradient(180deg,#fdd835,#f9a825);transition:height .1s linear;box-shadow:var(--shadow-warning-glow);z-index:10;border-radius:0 var(--radius-lg) var(--radius-lg) 0;opacity:var(--opacity-visible)}@keyframes pulse{0%,to{opacity:var(--opacity-hint)}50%{opacity:1}}.control-button .icon{font-size:var(--font-size-xl);pointer-events:none}.control-button .label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);pointer-events:none}.playlist{list-style:none;max-height:calc(var(--vh, 1vh) * 100 - var(--playlist-max-height-offset));overflow-y:auto;padding:calc(var(--vh, 1vh) * 2);padding-right:calc(var(--vh, 1vh) * 2 + 5px)}.playlist::-webkit-scrollbar{width:var(--scrollbar-width)}.playlist::-webkit-scrollbar-track{background:var(--scrollbar-track-bg);border-radius:var(--radius-sm)}.playlist::-webkit-scrollbar-thumb{background:var(--gradient-accent);border-radius:var(--radius-sm)}.playlist::-webkit-scrollbar-thumb:hover{background:var(--gradient-accent);filter:brightness(1.1)}.playlist-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 15px;border-bottom:1px solid var(--color-border-primary);transition:var(--transition-normal);cursor:move}.playlist-item[draggable=false]{cursor:default}.playlist-item:hover{background-color:var(--color-bg-secondary)}.playlist-item.current{background:linear-gradient(90deg,#cc00001a,#cc00000d);border-left:4px solid var(--brand-header);padding-left:11px}.playlist-item.dragging{opacity:var(--opacity-muted);cursor:grabbing}.playlist-item.drag-over{background:var(--color-drag-over-bg);border-top:2px solid var(--brand-accent);border-bottom:2px solid var(--brand-accent)}.playlist-item.not-playable{opacity:var(--opacity-moderate);position:relative}.playlist-item.not-playable:before{content:"🔒";position:absolute;left:5px;top:50%;transform:translateY(-50%);font-size:var(--font-size-sm);opacity:var(--opacity-secondary)}.playlist-item.not-playable .song-title{color:var(--color-text-secondary);padding-left:var(--spacing-xl)}.playlist-item.not-playable .song-artist{color:var(--color-text-tertiary)}.playlist-item.not-playable:hover{background-color:var(--color-banner-warning);cursor:help}.playlist-item:hover{background:#e9ecef}.playlist-item.current{background:var(--color-current-song-bg);border-left-color:var(--brand-header);box-shadow:var(--shadow-header)}.song-content{flex:1}.song-info-wrapper{display:flex;align-items:flex-start;gap:6px}.track-badge{flex-shrink:0;margin-top:2px}.song-text-content{flex:1;min-width:0}.playlist-item .song-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item .song-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item .song-notes{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px;margin-left:-3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-controls{display:flex;gap:5px;opacity:0;transition:var(--transition-normal);margin-left:10px}.playlist-item:hover .song-controls{opacity:1}.move-button{background:var(--gradient-accent);border:none;color:var(--color-text-inverse);width:28px;height:28px;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center;transition:var(--transition-normal);box-shadow:var(--shadow-sm)}.move-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-button-hover);background:var(--gradient-accent);filter:brightness(1.1)}.move-button:active:not(:disabled){transform:translateY(0)}.move-button:disabled{background:var(--color-dark-text-tertiary)!important;cursor:not-allowed;opacity:var(--opacity-disabled);box-shadow:none;filter:grayscale(100%)}.move-button.remove-button{background:var(--gradient-danger)}.move-button.remove-button:hover:not(:disabled){background:var(--gradient-danger-hover)}.move-button.duplicate-button{background:var(--gradient-success)}.move-button.duplicate-button:hover{background:var(--gradient-success-hover)}.move-button.notes-button{background:var(--gradient-warning)}.move-button.notes-button:hover:not(:disabled){background:var(--gradient-warning-hover)}.info-icon{margin-left:6px;font-size:var(--font-size-sm);color:var(--brand-warning);cursor:help;display:inline-flex;align-items:center;vertical-align:middle}.section-header-collapsible .playlist-toggle{display:flex;align-items:center;margin-left:auto}.section-header-collapsible .toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--font-size-sm);color:#fff;user-select:none}.section-header-collapsible .toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.section-header-collapsible .toggle-label:hover{color:#fffc}.section-header-collapsible .add-song-container-inline{display:flex;align-items:center;position:relative}.playlist.full-info .song-info-wrapper{align-items:flex-start}.playlist.full-info .song-title,.playlist.full-info .song-artist,.playlist.full-info .song-notes{white-space:normal;overflow:visible;text-overflow:clip;font-size:var(--font-size-sm)}.playlist.full-info .song-title{margin-bottom:4px}.playlist.full-info .song-notes,.playlist.full-info .song-artist{margin-top:0}.add-song-container{display:flex;justify-content:center;margin-bottom:0;position:relative}.add-song-button{background:var(--gradient-success);border:2px dashed transparent;color:var(--color-text-inverse);padding:var(--spacing-15) var(--spacing-3xl);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--font-size-base);display:flex;align-items:center;gap:10px;transition:var(--transition-slow);box-shadow:var(--shadow-sm)}.add-song-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-button-hover);background:var(--gradient-success-hover)}.add-song-button.drag-over{border-color:var(--brand-success);background:var(--gradient-success-hover);transform:scale(1.05);box-shadow:var(--shadow-success-hover)}.add-song-button .label{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.add-song-button .dropdown-arrow{font-size:var(--font-size-sm);margin-left:5px}.add-song-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:5px;background:var(--color-card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:220px;z-index:var(--z-dropdown);overflow:hidden;display:none}.add-song-dropdown.visible{display:block}.add-song-dropdown-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:var(--transition-normal);border-bottom:1px solid var(--color-border-secondary)}.add-song-dropdown-item:last-child{border-bottom:none}.add-song-dropdown-item:hover{background:var(--color-bg-secondary)}.add-song-dropdown-item .icon{font-size:var(--font-size-md)}.add-song-dropdown-item .label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.add-song-button-header{background:var(--gradient-success);border:none;color:var(--color-text-inverse);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);display:flex;align-items:center;gap:6px;transition:var(--transition-slow);box-shadow:var(--shadow-sm)}.add-song-button-header:hover{transform:translateY(-2px);box-shadow:var(--shadow-button-hover);background:var(--gradient-success-hover)}.add-song-button-header:active{transform:translateY(0)}.add-song-button-header .icon{font-size:var(--font-size-base)}.add-song-button-header .label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.section-header-collapsible .icon-button{margin-left:auto;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-xs)}.section-header-collapsible .icon-button:first-of-type{margin-left:auto}.section-header-collapsible .icon-button+.icon-button{margin-left:var(--spacing-sm)}.playlist-selector-controls{display:flex;padding:var(--spacing-lg) var(--spacing-xl);background:var(--color-card-bg-gradient);border:1px solid var(--color-border);border-left:none;border-right:none}.playlist-dropdown{flex:1;padding:var(--spacing-10) 15px;border:2px solid var(--brand-accent);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-card-bg);cursor:pointer;transition:var(--transition-normal);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.playlist-dropdown:hover:not(:disabled){border-color:var(--brand-accent-dark);box-shadow:var(--shadow-sm)}.playlist-dropdown:disabled{cursor:not-allowed;opacity:var(--opacity-muted);background:var(--color-disabled)}.icon-button{background:var(--gradient-accent);border:none;color:var(--color-text-inverse);padding:var(--spacing-10) 15px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);transition:var(--transition-normal);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:5px}.icon-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-button-hover)}.icon-button:active:not(:disabled){transform:translateY(0)}.icon-button:disabled{background:var(--color-disabled);cursor:not-allowed;opacity:var(--opacity-muted)}.icon-button.create{background:var(--gradient-success)}.icon-button.create:hover:not(:disabled){background:var(--gradient-success-hover)}.icon-button.delete{background:var(--gradient-danger)}.icon-button.delete:hover:not(:disabled){background:var(--gradient-danger-hover)}.playlist-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--spacing-10) 15px;background:var(--color-card-bg);border-radius:var(--radius-md);border-left:4px solid var(--brand-header)}.playlist-info strong{color:var(--brand-header)}@media (max-width: 1200px){.main-layout{flex-direction:column}.left-panel,.right-panel{flex:1;width:100%}}@media (max-width: 768px){header{flex-direction:column;align-items:flex-start;gap:15px}header h1{font-size:var(--font-size-xl)}.spotify-widget{width:100%}.spotify-widget.authenticated{flex-direction:column;align-items:flex-start}}.spotify-widget{padding:0;background:transparent;border-radius:var(--radius-none);box-shadow:none;margin-bottom:0}.spotify-widget.authenticated{display:flex;align-items:center}.spotify-connected-btn{display:flex;align-items:center;gap:var(--spacing-md);background:var(--brand-spotify);color:var(--color-text-inverse);border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-circle);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-normal);box-shadow:var(--shadow-spotify);white-space:nowrap;position:relative}.spotify-connected-btn:hover{background:var(--brand-spotify-hover);transform:translateY(-2px);box-shadow:var(--shadow-spotify-hover)}.spotify-connected-btn:active{transform:translateY(0)}.spotify-connected-btn .spotify-user-avatar{width:32px;height:32px;border-radius:var(--radius-circle);object-fit:cover;flex-shrink:0}.spotify-connected-btn .spotify-user-name{font-weight:var(--font-weight-bold);color:var(--color-text-inverse);font-size:var(--font-size-sm)}.spotify-warning-icon{color:var(--brand-warning);font-size:var(--font-size-base);margin-left:var(--spacing-xs)}.spotify-login-btn{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--brand-spotify);color:var(--color-text-inverse);border:none;padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-circle);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-normal);box-shadow:var(--shadow-spotify);white-space:nowrap;justify-content:center}.spotify-login-btn:hover{background:var(--brand-spotify-hover);transform:translateY(-2px);box-shadow:var(--shadow-spotify-hover)}.spotify-login-btn:active{transform:translateY(0)}.spotify-search-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:var(--z-modal-max);display:none;align-items:center;justify-content:center}.spotify-search-modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--color-overlay);backdrop-filter:blur(4px)}.spotify-search-modal-content{position:relative;background:var(--color-card-bg);border-radius:var(--radius-xl);padding:var(--spacing-3xl);box-shadow:var(--shadow-modal);max-width:700px;width:90%;max-height:80vh;display:flex;flex-direction:column;z-index:var(--z-max)}.spotify-search-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.spotify-search-modal-header h3{margin:0;color:var(--color-text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.spotify-modal-close-btn{background:transparent;border:none;color:var(--color-text-tertiary);font-size:var(--font-size-2xl);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-circle);transition:var(--transition-normal);line-height:var(--line-height-none)}.spotify-modal-close-btn:hover{background:var(--color-hover);color:var(--color-text-primary)}.spotify-search-input-group{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);align-items:center}.spotify-back-btn{background:var(--gradient-accent);color:var(--color-text-inverse);border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-size:var(--font-size-sm);white-space:nowrap}.spotify-back-btn:hover{background:var(--gradient-accent);filter:brightness(1.1);transform:translateY(-2px)}.spotify-search-input{flex:1;padding:var(--spacing-sm) var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);transition:var(--transition-fast)}.spotify-search-input:focus{outline:none;border-color:var(--brand-spotify)}.spotify-search-btn{background:var(--brand-spotify);color:var(--color-text-inverse);border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-size:var(--font-size-sm)}.spotify-search-btn:hover{background:var(--brand-spotify-hover)}.spotify-search-btn:disabled{background:var(--color-disabled);cursor:not-allowed}.spotify-search-results{flex:1;overflow-y:auto;max-height:50vh}.spotify-track-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:var(--transition-fast);cursor:pointer;border:1px solid var(--color-border-light);margin-bottom:var(--spacing-sm)}.spotify-track-item:hover{background:var(--color-hover)}.spotify-track-image{width:50px;height:50px;border-radius:var(--radius-sm);object-fit:cover;background:var(--color-border)}.spotify-track-info{flex:1}.spotify-track-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:2px;font-size:var(--font-size-base)}.spotify-track-artist{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.spotify-track-duration{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-variant-numeric:tabular-nums}.spotify-track-actions{display:flex;gap:var(--spacing-xs);align-items:center;margin-left:auto}.spotify-track-nav-btn{background:var(--gradient-accent);color:var(--color-text-inverse);border:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);opacity:0;white-space:nowrap}.spotify-track-item:hover .spotify-track-nav-btn{opacity:1}.spotify-track-nav-btn:hover{background:var(--gradient-accent);filter:brightness(1.1);transform:translateY(-1px)}.spotify-track-add-btn{background:var(--brand-spotify);color:var(--color-text-inverse);border:none;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-normal);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.spotify-track-add-btn:hover{background:var(--brand-spotify-hover)}.spotify-search-empty{text-align:center;padding:var(--spacing-4xl);color:var(--color-text-tertiary)}.spotify-track-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:var(--brand-spotify);color:var(--color-text-inverse);border-radius:var(--radius-xs);margin-left:var(--spacing-sm)}.spotify-track-badge svg{width:12px;height:12px}.local-track-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:var(--brand-accent);color:var(--color-text-inverse);border-radius:var(--radius-xs);font-size:var(--font-size-sm);margin-left:var(--spacing-sm)}.add-song-button-compact{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);box-shadow:var(--shadow-xs)}.add-song-button-compact .icon{font-size:var(--font-size-base)}.add-song-button-compact .label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide)}.add-song-button-compact .dropdown-arrow{font-size:var(--font-size-xs)}.add-song-button-compact:hover{transform:translateY(-2px);box-shadow:var(--shadow-button-hover)}.add-song-button-compact:active{transform:translateY(0)}.add-song-button-compact:disabled{opacity:var(--opacity-disabled);cursor:not-allowed;filter:grayscale(100%);box-shadow:none}.add-song-button-compact:disabled:hover{transform:none;box-shadow:none}.add-song-container-inline{display:inline-flex;position:relative}.add-song-container-inline .add-song-dropdown{top:100%;left:0;transform:none;margin-top:var(--spacing-xs)}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:var(--spacing-4xl);text-align:center}.auth-loading h2{color:var(--brand-accent);font-size:var(--font-size-2xl);margin:0}.auth-buttons{display:flex;gap:var(--spacing-lg);flex-direction:column;width:100%;max-width:300px}.header-controls{display:flex;align-items:center;gap:var(--spacing-xl)}.user-info{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding-left:var(--spacing-lg);border-left:2px solid var(--color-border-inverse)}.user-buttons{display:flex;align-items:center;gap:var(--spacing-md)}.user-info .user-email{font-weight:var(--font-weight-semibold);color:var(--color-text-inverse);font-size:var(--font-size-xs)}.logout-button,.entitlement-button{background:transparent;border:2px solid var(--color-border-inverse);color:var(--color-text-inverse);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-normal);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.entitlement-button{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);text-transform:none;letter-spacing:0}.logout-button:hover,.entitlement-button:hover{background:var(--color-hover-inverse);border-color:var(--color-text-inverse);transform:translateY(-2px);box-shadow:var(--shadow-md)}.auth-buttons-header{display:flex;gap:var(--spacing-md)}.login-button-header{padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-normal);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);background:var(--color-card-bg);color:var(--brand-header);border:2px solid var(--color-card-bg)}.login-button-header:hover{background:var(--color-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.copyright-footer{position:fixed;bottom:0;left:0;right:0;padding:var(--spacing-md) var(--spacing-xl);text-align:center;background:var(--color-footer-bg);border-top:1px solid var(--color-border-light);backdrop-filter:blur(8px);z-index:var(--z-footer)}.copyright-footer span{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:var(--font-weight-normal);letter-spacing:var(--letter-spacing-normal)}
