body.dark{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--shadow: rgba(0, 0, 0, .3);--accent: #3b82f6;--accent-hover: #2563eb;--success: #4ade80;--error: #f87171;--warning: #fbbf24}body.light{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--border-color: #e2e8f0;--shadow: rgba(0, 0, 0, .1);--accent: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--error: #ef4444;--warning: #f59e0b}.app{min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1.5rem 2rem;box-shadow:0 2px 8px var(--shadow)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1rem}.header-icon{color:#f87171}.header h1{font-size:1.75rem;font-weight:700}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all .2s}.theme-toggle:hover{background:var(--accent);color:#fff}.main-content{max-width:1400px;margin:0 auto;padding:2rem}.status-bar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border:2px solid;border-radius:8px;font-size:.875rem;font-weight:500}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color)}.tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:1rem;cursor:pointer;transition:all .2s}.tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media (max-width: 768px){.content-grid{grid-template-columns:1fr}}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--shadow);overflow:visible;transition:all .3s ease}.card:hover{box-shadow:0 4px 16px var(--shadow);transform:translateY(-2px)}.card-content{padding:1.5rem;overflow:visible}.card-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);border-radius:12px 12px 0 0}.unified-card{grid-column:1 / -1}.unified-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media (max-width: 1200px){.unified-content{grid-template-columns:1fr}}.unified-section{display:flex;flex-direction:column;gap:1rem}.section-header{display:flex;align-items:center;gap:.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--border-color);margin-bottom:.5rem}.section-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.section-header svg{color:var(--accent)}.step-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:50%;font-weight:700;font-size:.9rem;box-shadow:0 2px 8px #3b82f64d;flex-shrink:0;transition:all .3s ease;animation:fadeIn .5s ease}.step-number:hover{transform:scale(1.1);box-shadow:0 4px 12px #3b82f680}.card-header .step-number{width:32px;height:32px;font-size:1rem}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.card-header h2{font-size:1.125rem;font-weight:600;flex:1}.card-content{padding:1.5rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}input[type=text],input[type=number],textarea,select,.select{width:100%;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.875rem;transition:all .3s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a;transform:translateY(-1px)}textarea{resize:vertical;font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-primary);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-upload{width:100%;padding:1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:1rem;font-weight:600}.btn-upload:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}.btn-icon{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon:hover{background:var(--bg-primary);color:var(--text-primary)}.btn-close{background:transparent;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.btn-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.file-input{display:flex;flex-direction:column;gap:.75rem}.file-input label{display:block;padding:.75rem;background:var(--bg-primary);border:2px dashed var(--border-color);border-radius:8px;text-align:center;cursor:pointer;transition:all .2s}.file-input label:hover{border-color:var(--accent);background:var(--bg-tertiary)}.file-input input[type=file]{display:none}.file-placeholder{color:var(--text-muted);font-size:.875rem}.file-selected{color:var(--success);font-size:.875rem;font-weight:500}.sheets-section{display:flex;flex-direction:column;gap:1rem}.searchable-select{position:relative;z-index:10}.dropdown-list{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px var(--shadow);z-index:1000;margin-top:.5rem;animation:fadeIn .2s ease-out}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:all .2s ease;border-bottom:1px solid var(--border-color)}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover:not(.disabled){background:var(--bg-tertiary);padding-left:1.25rem}.dropdown-item.selected{background:#3b82f61a;border-left:3px solid var(--accent);font-weight:500}.dropdown-item.disabled{color:var(--text-muted);cursor:not-allowed;opacity:.6}.dropdown-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-item .check-icon{color:var(--accent);flex-shrink:0}.search-box{position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:.75rem;color:var(--text-muted);pointer-events:none}.search-box input{padding-left:2.5rem}.upload-section{margin:1.5rem 0}.progress-bar-container{width:100%;height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-bar-animated{height:100%;background:linear-gradient(90deg,var(--accent) 0%,#60a5fa 50%,var(--accent) 100%);background-size:200% 100%;animation:progressAnimation 1.5s ease-in-out infinite}@keyframes progressAnimation{0%{background-position:200% 0}to{background-position:-200% 0}}.status-message{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;text-align:center}.status-message.info{background:#3b82f61a;color:var(--accent);border:1px solid rgba(59,130,246,.3)}.status-message.success{background:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.3)}.status-message.error{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.3)}.wasabi-download-status{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.wasabi-download-status .progress-bar-container,.wasabi-download-status .status-message{margin:0}.logs-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;height:250px;overflow-y:auto;font-family:Courier New,monospace;font-size:.8125rem}.log-entry{padding:.25rem 0;line-height:1.5}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease-out}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:1200px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:scaleIn .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.modal-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600}.modal-content{padding:1.5rem;overflow:auto;flex:1}.modal-info{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color);background:var(--bg-tertiary)}.table-wrapper{overflow:auto;border:1px solid var(--border-color);border-radius:8px}.data-table{width:100%;border-collapse:collapse;font-size:.8125rem}.data-table th,.data-table td{padding:.75rem;text-align:left;border:1px solid var(--border-color)}.data-table th{background:var(--bg-tertiary);font-weight:600;position:sticky;top:0;z-index:10}.data-table tbody tr{transition:all .2s ease}.data-table tbody tr:hover{background:var(--bg-tertiary);transform:scale(1.01);box-shadow:0 2px 8px var(--shadow)}.data-table tbody tr.selected{background:#3b82f626;border-left:3px solid var(--accent)}.data-table input[type=checkbox]{cursor:pointer;width:1rem;height:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.slide-in{animation:slideIn .4s ease-out}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.pulse{animation:pulse 2s ease-in-out infinite}.scale-in{animation:scaleIn .2s ease-out}.success-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:8px;color:var(--success);font-size:.875rem;font-weight:500;animation:fadeIn .3s ease-out,pulse 2s ease-in-out 3}@media (max-width: 768px){.main-content,.header{padding:1rem}.header h1{font-size:1.25rem}.form-grid{grid-template-columns:1fr}.modal{margin:1rem}.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.5rem}}.thumbnail-generator{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;margin-top:1rem}.generator-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.generator-header h3{font-size:1rem;font-weight:600;margin:0}.generator-content{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.colors-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.color-picker{display:flex;flex-direction:column;gap:.5rem}.color-picker label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.color-input-wrapper{display:flex;align-items:center;gap:.75rem;background:var(--bg-tertiary);padding:.5rem;border-radius:8px;border:1px solid var(--border-color);transition:all .2s}.color-input-wrapper:hover{border-color:var(--accent);background:var(--bg-secondary)}.color-picker input[type=color]{width:60px;height:36px;border:2px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s;padding:2px;flex-shrink:0}.color-picker input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.color-picker input[type=color]::-moz-color-swatch{border:none;border-radius:4px}.color-picker input[type=color]:hover{border-color:var(--accent);transform:scale(1.05)}.color-value{font-size:.8rem;color:var(--text-primary);font-family:Courier New,monospace;font-weight:600;letter-spacing:.5px;flex:1;text-align:center;background:var(--bg-primary);padding:.25rem .5rem;border-radius:4px}.generation-progress{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#3b82f60d;border:1px solid rgba(59,130,246,.2);border-radius:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,#60a5fa 100%);border-radius:4px;transition:width .3s ease}.progress-text{text-align:center;font-size:.875rem;color:var(--accent);font-weight:500}.error-message{padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:var(--error);font-size:.875rem}.generated-preview{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-primary);border:2px solid var(--accent);border-radius:12px}.preview-header{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--accent)}.preview-image{width:100%;border-radius:8px;overflow:hidden;background:var(--bg-tertiary)}.preview-image img{width:100%;height:auto;display:block}.preview-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#22c55e;transform:translateY(-2px);box-shadow:0 6px 16px #22c55e66}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.profile-selector{display:flex;flex-direction:column;gap:.75rem}.profile-controls{display:flex;gap:.5rem;align-items:center}.profile-select{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;transition:all .2s}.profile-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a}.btn-icon{padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.add-profile-form{padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-row input{padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem}.form-row input:focus{outline:none;border-color:var(--accent)}.form-actions{display:flex;gap:.5rem}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.saved-profiles{display:flex;flex-direction:column;gap:.5rem;max-height:150px;overflow-y:auto}.profile-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;transition:all .2s}.profile-item.active{background:#3b82f61a;border-color:var(--accent)}.profile-item span{flex:1}.btn-delete{padding:.25rem;background:transparent;border:none;color:var(--error);cursor:pointer;border-radius:4px;transition:all .2s;display:flex;align-items:center}.btn-delete:hover{background:#ef44441a}.schedule-card{margin-bottom:1.5rem;border-left:4px solid var(--warning)}.datetime-wrapper{display:flex;gap:.75rem;align-items:center}.datetime-input{flex:1;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:.95rem}.datetime-input:focus{border-color:var(--warning);box-shadow:0 0 0 3px #fbbf241a}.field-hint{margin-top:.5rem;font-size:.8125rem;color:var(--text-muted);font-style:italic}.btn-sm{padding:.5rem .75rem;font-size:.75rem}.textarea-wrapper{position:relative;width:100%}.ai-loader-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0f172ab3;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;gap:.75rem;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .3s ease}.ai-loader-icon{font-size:2rem;animation:float 2s ease-in-out infinite,rotate 4s linear infinite}.ai-loader-overlay span{font-size:.9rem;font-weight:500;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes rotate{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#888;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#555}body.light ::-webkit-scrollbar-thumb{background:#ccc}body.light ::-webkit-scrollbar-thumb:hover{background:#999}
