*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #3498db;--color-primary-dark: #2980b9;--color-primary-light: #ebf3fd;--color-success: #4caf50;--color-success-bg: #e8f5e8;--color-success-text: #2e7d32;--color-error: #f44336;--color-error-bg: #ffebee;--color-error-text: #c62828;--color-warning: #ff9800;--color-warning-bg: #fff8e1;--color-warning-text: #ef6c00;--color-info: #00ddff;--color-info-bg: #e3f2fd;--color-info-text: #1976d2;--color-gray-50: #f8f9fa;--color-gray-100: #f5f5f5;--color-gray-200: #e0e0e0;--color-gray-300: #bdc3c7;--color-gray-400: #95a5a6;--color-gray-500: #7f8c8d;--color-gray-600: #6c757d;--color-gray-700: #495057;--color-gray-800: #343a40;--color-gray-900: #2c3e50;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-mono: "Consolas", "Monaco", "Courier New", monospace;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 24px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 30px;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-full: 50%;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--header-height: 45px;--footer-height: 45px}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:1.5;color:var(--color-gray-700);background:var(--color-gray-800);overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.title-xs{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.title-sm{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.title-md{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.title-lg{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.title-xl{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-muted{color:var(--color-gray-500)}.text-light{color:var(--color-gray-400)}.text-dark{color:var(--color-gray-800)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);border:1px solid transparent;border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-decoration:none;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:#fff;color:var(--color-gray-700);border-color:var(--color-gray-300)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-lg)}.card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-md);padding:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.card.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.card-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs);color:var(--color-gray-800)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500)}.status-ok{background:var(--color-success-bg);color:var(--color-success-text);border-color:var(--color-success)}.status-error{background:var(--color-error-bg);color:var(--color-error-text);border-color:var(--color-error)}.status-warning{background:var(--color-warning-bg);color:var(--color-warning-text);border-color:var(--color-warning)}.status-info{background:var(--color-info-bg);color:var(--color-info-text);border-color:var(--color-info)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fade-in{animation:fadeIn var(--transition-base)}.slide-up{animation:slideUp var(--transition-base)}.pulse{animation:pulse 2s infinite}.grid{display:grid}.grid-cols-auto{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width: 768px){:root{--font-size-base: 13px}}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.header{height:var(--header-height);background:linear-gradient(135deg,var(--color-primary) 0%,#764ba2 100%);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);box-shadow:var(--shadow-md);position:relative;z-index:100;flex-shrink:0}.header__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0;display:flex;align-items:center;gap:var(--spacing-md)}.header__actions{display:flex;align-items:center;gap:var(--spacing-md)}.btn-settings,.btn-history{width:36px;height:36px;border:none;background:#ffffff1a;color:#fff;border-radius:var(--border-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);backdrop-filter:blur(10px);font-size:18px}.btn-settings:hover,.btn-history:hover{background:#fff3;transform:translateY(-1px)}.btn-settings:active,.btn-history:active{transform:scale(.95)}#settings-dropdown-mount{position:relative;z-index:9998}@media (max-width: 768px){.header{padding:0 var(--spacing-md)}.header__title{font-size:var(--font-size-lg)}}@media (max-width: 480px){.header__title{font-size:var(--font-size-base)}}.settings-dropdown-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;animation:fadeIn var(--transition-base)}.settings-dropdown-container.closing{animation:fadeOut var(--transition-base)}.settings-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:transparent;cursor:default}.settings-panel{position:absolute;top:60px;right:24px;width:320px;background:#fff;border-radius:var(--border-radius-lg);box-shadow:0 4px 20px #0000001f;overflow:hidden;animation:slideDown var(--transition-base)}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.settings-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin:0}.settings-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary);background:var(--color-primary-light);padding:3px 6px;border-radius:var(--border-radius-sm)}.settings-body{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-label{display:flex;flex-direction:column;gap:3px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-800)}.settings-sublabel{font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);color:var(--color-gray-500);line-height:1.3}.settings-input{width:100%;height:36px;padding:0 var(--spacing-sm);border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--color-gray-800);background:#fff;transition:all var(--transition-base);font-family:var(--font-family-base)}.settings-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3498db1a}.settings-input:hover:not(:focus){border-color:var(--color-gray-400)}.settings-input.input-error{border-color:var(--color-error);background:var(--color-error-bg)}.settings-input.input-error:focus{box-shadow:0 0 0 3px #f443361a}.settings-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-gray-200);background:var(--color-gray-50)}.settings-icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);background:#fff;font-size:18px;cursor:pointer;transition:all var(--transition-base)}.settings-icon-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.settings-icon-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.settings-panel{right:12px;left:12px;width:auto}}.footer{height:var(--footer-height);background:var(--color-gray-100);border-top:1px solid var(--color-gray-300);display:flex;align-items:center;justify-content:flex-start;padding:0 var(--spacing-xl);font-size:var(--font-size-sm);color:var(--color-gray-500)}@media (max-width: 768px){.footer-content{padding:0 var(--spacing-md)}.footer-description{font-size:var(--font-size-xs)}}.home-page{height:100%;overflow-y:auto;background:#fff}.page-content{max-width:1200px;margin:0 auto;padding:var(--spacing-2xl);background:#fff;border-radius:var(--border-radius-md);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding-bottom:calc(var(--spacing-2xl) + var(--footer-height))}.page-header{text-align:center;margin-bottom:var(--spacing-xl)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-800);margin-bottom:var(--spacing-md)}.page-description{font-size:var(--font-size-lg);color:var(--color-gray-600);line-height:1.6;max-width:600px;margin:0 auto}.dropzone-container{flex:1;min-height:200px;display:flex;flex-direction:column}.results-container{margin-top:var(--spacing-2xl)}#home-mount{flex:1;min-height:0;display:flex;flex-direction:column}.file-dropzone{width:100%;height:100%;min-height:200px}.upload-area{flex:1;transition:all var(--transition-base);position:relative;overflow:hidden}.upload-area:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#3498db1a;border-radius:50%;transform:translate(-50%,-50%);transition:all var(--transition-slow);z-index:0}.upload-area.drag-over:before{width:200px;height:200px}.upload-area.loading:before{width:150px;height:150px;background:#00ddff1a;animation:pulse 1.5s infinite}.upload-info{text-align:center;position:relative;z-index:1}.upload-icon{margin-bottom:var(--spacing-lg);color:var(--color-gray-400);transition:all var(--transition-base)}.upload-area:hover .upload-icon,.upload-area.drag-over .upload-icon{color:var(--color-primary);transform:translateY(-4px)}.upload-area.loading .upload-icon{color:var(--color-info);animation:bounce 1s infinite}.upload-area.error .upload-icon{color:var(--color-error)}.upload-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:var(--spacing-sm);transition:all var(--transition-base)}.upload-area:hover .upload-title,.upload-area.drag-over .upload-title{color:var(--color-primary)}.upload-area.loading .upload-title{color:var(--color-info)}.upload-area.error .upload-title{color:var(--color-error)}.upload-description{font-size:var(--font-size-base);color:var(--color-gray-500);margin-bottom:var(--spacing-lg)}.upload-requirements{display:flex;flex-direction:column;gap:var(--spacing-xs)}.upload-area.hidden,.file-info.hidden{display:none}.file-info.visible{display:block}.file-info{padding:var(--spacing-xl);background:var(--color-success-bg);border:2px solid var(--color-success);border-radius:var(--border-radius-lg);margin-top:var(--spacing-lg)}.file-details{display:flex;align-items:center;gap:var(--spacing-lg)}.file-icon{flex-shrink:0;color:var(--color-success);background:#fff;padding:var(--spacing-md);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm)}.file-meta{flex:1;min-width:0}.file-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--spacing-xs);word-break:break-word}.file-size{font-size:var(--font-size-sm);color:var(--color-gray-600)}.btn-remove{flex-shrink:0;width:32px;height:32px;border:none;background:#f443361a;color:var(--color-error);border-radius:var(--border-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.btn-remove:hover{background:var(--color-error);color:#fff;transform:scale(1.1)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.upload-area.loading .upload-icon svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.file-dropzone{min-height:250px}.upload-icon{margin-bottom:var(--spacing-md)}.upload-title{font-size:var(--font-size-lg)}.file-details{gap:var(--spacing-md)}.file-name{font-size:var(--font-size-base)}}.results-container{display:flex;flex-direction:column;gap:var(--spacing-xl)}.warnings-section{background:var(--color-warning-bg);border:1px solid var(--color-warning);border-radius:var(--border-radius-lg);padding:var(--spacing-lg)}.warnings-header{margin-bottom:var(--spacing-lg)}.warnings-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-warning-text);margin-bottom:var(--spacing-sm)}.warnings-title svg{color:var(--color-warning)}.warnings-description{color:var(--color-gray-700);font-size:var(--font-size-sm);margin:0}.warnings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.clusters-section{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);padding:var(--spacing-lg)}.clusters-header{margin-bottom:var(--spacing-lg)}.clusters-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-800);margin-bottom:var(--spacing-lg)}.clusters-title svg{color:var(--color-error)}.clusters-summary{margin-bottom:var(--spacing-lg)}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.stat-card{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-md);padding:var(--spacing-md);text-align:center;transition:all var(--transition-base)}.stat-card:hover{background:var(--color-gray-100);border-color:var(--color-primary)}.stat-number{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.stat-label{display:block;font-size:var(--font-size-xs);color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em}.clusters-grid{display:flex;flex-direction:column;gap:var(--spacing-lg)}.results-empty,.results-success{text-align:center;padding:var(--spacing-2xl)}.empty-icon,.success-icon{display:flex;justify-content:center;margin-bottom:var(--spacing-lg)}.empty-icon svg{color:var(--color-gray-400)}.success-icon svg{color:var(--color-success)}.results-empty h3,.results-success h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-800);margin-bottom:var(--spacing-sm)}.results-empty p{color:var(--color-gray-600);font-size:var(--font-size-sm)}.success-stats{display:flex;justify-content:center;gap:var(--spacing-2xl);margin:var(--spacing-xl) 0}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-item .stat-number{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-success)}.stat-item .stat-label{font-size:var(--font-size-sm);color:var(--color-gray-600)}.wavelength-breakdown{max-width:400px;margin:var(--spacing-xl) auto 0;padding:var(--spacing-lg);background:var(--color-gray-50);border-radius:var(--border-radius-md)}.wavelength-breakdown h4{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--spacing-md)}.wavelength-stat{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-gray-200)}.wavelength-stat:last-child{border-bottom:none}.wavelength-label{font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.wavelength-count{color:var(--color-gray-600)}@media (max-width: 768px){.warnings-grid,.summary-stats{grid-template-columns:1fr}.success-stats{flex-direction:column;gap:var(--spacing-lg)}.clusters-filter{flex-direction:column;align-items:flex-start}.config-display{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-gray-100);border-radius:var(--border-radius-sm);display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xs)}.config-label{font-weight:var(--font-weight-semibold);color:var(--color-gray-700)}.config-value{color:var(--color-primary);font-family:var(--font-family-mono)}.config-separator{color:var(--color-gray-400)}}.cluster-card{background:#fff;border:2px solid var(--color-warning);border-radius:var(--border-radius-md);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.cluster-card:hover{border-color:var(--color-error);box-shadow:var(--shadow-md)}.cluster-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm);background:var(--color-warning-bg);border-bottom:1px solid var(--color-warning)}.cluster-info{flex:1}.cluster-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--spacing-xs)}.cluster-meta{display:flex;gap:var(--spacing-lg);align-items:center}.cluster-lambda,.cluster-events,.cluster-similarity{font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-weight:var(--font-weight-medium)}.cluster-lambda{background:var(--color-info-bg);color:var(--color-info-text)}.cluster-events{background:var(--color-gray-100);color:var(--color-gray-700)}.cluster-similarity{background:var(--color-error-bg);color:var(--color-error-text)}.btn-toggle{width:40px;height:40px;border:none;background:#fff;border-radius:var(--border-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);color:var(--color-gray-600)}.btn-toggle:hover{background:var(--color-gray-100);color:var(--color-primary)}.toggle-icon{transition:transform var(--transition-base)}.cluster-content{overflow:hidden;transition:all var(--transition-base)}.cluster-content.collapsed{max-height:0;opacity:0}.deviation-value{font-size:.9em}.deviation-positive{color:#006400}.deviation-negative{color:#8b0000}.fiber-id{width:290px;min-width:290px;max-width:290px;overflow:visible;white-space:normal;word-break:break-word}.fiber-num{width:100px;min-width:100px;max-width:100px;text-align:center}.fiber-event{width:150px;min-width:150px;max-width:150px;text-align:right}.fibers-table-container{overflow-x:auto;margin-bottom:var(--spacing-xs);border-radius:var(--border-radius-md);border:1px solid var(--color-gray-200)}.fibers-table{width:auto;table-layout:fixed;border-collapse:collapse;font-size:var(--font-size-sm)}.fibers-table th,.fibers-table td{padding:var(--spacing-sm) var(--spacing-xs);text-align:left;border-bottom:1px solid var(--color-gray-200)}.fibers-table th{background:var(--color-gray-100);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);white-space:nowrap;position:sticky;top:0;z-index:1}.fiber-row{transition:background-color var(--transition-base)}.fiber-row:hover{background:var(--color-gray-50)}.fiber-row:nth-child(2n){background:#00000005}.fiber-row:nth-child(2n):hover{background:var(--color-gray-50)}.fiber-id,.fiber-num{font-weight:var(--font-weight-semibold);color:var(--color-primary)}.fiber-lambda{font-family:var(--font-family-mono);background:var(--color-info-bg);color:var(--color-info-text);border-radius:var(--border-radius-sm);padding:var(--spacing-xs)}.fiber-event{font-family:var(--font-family-mono);color:var(--color-gray-700);text-align:right}.fiber-row-num{color:var(--color-gray-500);font-size:var(--font-size-xs);text-align:center}.similarities-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.similarity-item{padding:var(--spacing-md);background:var(--color-gray-50);border-radius:var(--border-radius-md);border-left:3px solid var(--color-primary)}.similarity-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.similarity-score{margin-left:auto;background:var(--color-success-bg);color:var(--color-success-text);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-weight:var(--font-weight-semibold)}.similarity-details{font-size:var(--font-size-xs);color:var(--color-gray-600);font-family:var(--font-family-mono)}@media (max-width: 768px){.cluster-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.cluster-meta{flex-wrap:wrap;gap:var(--spacing-sm)}.fibers-table-container{font-size:var(--font-size-xs)}.fibers-table th,.fibers-table td{padding:var(--spacing-xs) var(--spacing-sm)}.similarity-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.similarity-score{margin-left:0;align-self:flex-end}}.threshold-match{background-color:#b9e7b9!important}.threshold-exceed{background-color:#e6a4a4!important}.warning-card{background:#fff;border:2px solid var(--color-warning);border-radius:var(--border-radius-md);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-md)}.warning-card:hover{border-color:#e6a700;box-shadow:var(--shadow-md)}.warning-header{display:flex;align-items:center;padding:var(--spacing-md);background:var(--color-warning-bg);gap:var(--spacing-md)}.warning-icon{flex-shrink:0;color:var(--color-warning);display:flex;align-items:center;justify-content:center}.warning-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.warning-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-800)}.warning-details{display:flex;flex-direction:column;gap:var(--spacing-xs)}.fiber-info{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary)}.missing-lambda{font-size:var(--font-size-sm);color:#b45309;font-family:var(--font-family-mono);background:#fef3c7;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);width:fit-content}@media (max-width: 768px){.warning-header{padding:var(--spacing-sm);gap:var(--spacing-sm)}.warning-details{gap:var(--spacing-xs)}.warning-title{font-size:var(--font-size-sm)}}.toaster{position:fixed;top:20px;right:20px;z-index:9999;max-width:400px;width:100%;max-height:80vh;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toaster__container{display:flex;flex-direction:column;gap:8px;max-height:calc(80vh - 20px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.toaster__container::-webkit-scrollbar{width:4px}.toaster__container::-webkit-scrollbar-track{background:transparent}.toaster__container::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}.toaster-history-modal{position:fixed;inset:0;background:#0000004d;z-index:10000;display:flex;align-items:flex-start;justify-content:flex-end;padding:0;pointer-events:none}.toaster-history-content{background:#fff;border-radius:12px;width:420px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;box-shadow:0 10px 30px #0000004d;border:1px solid rgba(0,0,0,.1);pointer-events:auto;overflow:hidden;margin-top:60px;margin-right:20px}.toaster-history-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.toaster-history-header h2{margin:0;font-size:18px;font-weight:600;color:#333;font-family:system-ui,-apple-system,sans-serif}.toaster-history-close{background:transparent;border:none;font-size:24px;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;line-height:1}.toaster-history-close:hover{background:#f0f0f0;color:#333}.toaster-history-list{flex:1;overflow-y:auto;padding:0;min-height:200px;max-height:calc(100vh - 220px)}.toaster-history-list::-webkit-scrollbar{width:6px}.toaster-history-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.toaster-history-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.toaster-history-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.toaster-history-empty{padding:40px 20px;text-align:center;color:#666;font-style:italic;font-family:system-ui,-apple-system,sans-serif}.toaster-history-item{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.toaster-history-item:hover{background:#f8f9fa}.toaster-history-item:last-child{border-bottom:none}.toaster-history-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;margin-top:2px}.toaster-history-content-text{flex:1;min-width:0}.toaster-history-message{font-size:14px;line-height:1.4;color:#333;margin-bottom:4px;word-wrap:break-word;font-family:system-ui,-apple-system,sans-serif}.toaster-history-timestamp{font-size:12px;color:#666;font-family:system-ui,-apple-system,sans-serif}.toaster-history-actions{padding:20px;border-top:1px solid #eee;display:flex;justify-content:flex-end}.btn-clear-history{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s ease;font-family:system-ui,-apple-system,sans-serif}.btn-clear-history:hover{background:#c82333}.toaster-history-item--info .toaster-history-icon{color:#3b82f6}.toaster-history-item--success .toaster-history-icon{color:#10b981}.toaster-history-item--warning .toaster-history-icon{color:#f59e0b}.toaster-history-item--error .toaster-history-icon{color:#ef4444}.toast{position:relative;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;border-left:4px solid;overflow:hidden;transform:translate(100%);opacity:0;transition:all .3s ease;pointer-events:auto}.toast--visible{transform:translate(0);opacity:1}.toast--removing{transform:translate(100%);opacity:0}.toast:hover{transform:translate(-4px);box-shadow:0 6px 20px #00000026}.toast--removing:hover{transform:translate(100%)}.toast__content{display:flex;align-items:flex-start;gap:12px;padding:16px;position:relative}.toast__icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;margin-top:2px}.toast__body{flex:1;min-width:0}.toast__message{font-size:14px;line-height:1.4;color:#333;margin-bottom:4px;word-wrap:break-word;font-family:system-ui,-apple-system,sans-serif}.toast__timestamp{font-size:11px;color:#666;opacity:.8;font-family:system-ui,-apple-system,sans-serif}.toast__close{flex-shrink:0;background:transparent;border:none;font-size:18px;cursor:pointer;color:#666;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1}.toast__close:hover{background:#0000001a;color:#333}.toast__progress{position:absolute;bottom:0;left:0;height:3px;background:currentColor;animation:progress var(--duration) linear forwards;opacity:.6}@keyframes progress{0%{width:100%}to{width:0%}}.toast--info{border-left-color:#3b82f6}.toast--info .toast__icon,.toast--info .toast__progress{color:#3b82f6}.toast--success{border-left-color:#10b981}.toast--success .toast__icon,.toast--success .toast__progress{color:#10b981}.toast--warning{border-left-color:#f59e0b}.toast--warning .toast__icon,.toast--warning .toast__progress{color:#f59e0b}.toast--error{border-left-color:#ef4444}.toast--error .toast__icon,.toast--error .toast__progress{color:#ef4444}@media (max-width: 480px){.toaster{top:10px;right:10px;left:10px;max-width:none}.toast__content{padding:12px}.toast__message{font-size:13px}.toaster-history-modal{padding:10px;align-items:flex-start;justify-content:flex-end}.toaster-history-content{width:calc(100vw - 20px);max-width:380px;max-height:calc(100vh - 80px);margin-top:50px;margin-right:10px}.toaster-history-list{max-height:calc(100vh - 180px)}}.export-button-container{position:fixed;bottom:24px;right:24px;z-index:1000;opacity:0;transform:translateY(20px);pointer-events:none;transition:all var(--transition-base)}.export-button-container.visible{opacity:1;transform:translateY(0);pointer-events:auto}.export-button-container.hidden{opacity:0;transform:translateY(20px);pointer-events:none}.export-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;box-shadow:var(--shadow-lg);transition:all var(--transition-base);font-family:var(--font-family-base)}.export-button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-xl)}.export-button:active:not(:disabled){transform:translateY(0)}.export-button:disabled{opacity:.6;cursor:not-allowed}.export-button.exporting{background:var(--color-gray-500);cursor:wait}.export-button.exporting svg{animation:pulse 1.5s ease-in-out infinite}.pdf-export-header{padding:var(--spacing-2xl);margin-bottom:var(--spacing-2xl);background:linear-gradient(135deg,var(--color-primary) 0%,#764ba2 100%);color:#fff;text-align:center;border-radius:var(--border-radius-md);page-break-inside:avoid}.pdf-export-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm)}.pdf-export-header p{font-size:var(--font-size-base);opacity:.9}@media print{.export-button-container{display:none!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.cluster-card,.warning-card{page-break-inside:avoid;break-inside:avoid}@page{margin:15mm}.pdf-export-header{background:#3498db!important}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.export-button-container{bottom:16px;right:16px}.export-button{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}}
