.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;min-width:300px;max-width:500px;padding:16px 20px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;pointer-events:auto;cursor:pointer;animation:slideIn .3s ease-out;transition:all .3s ease}.toast:hover{transform:translate(-4px);box-shadow:0 6px 16px #0003}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}.toast-message{flex:1;font-size:14px;line-height:1.5;color:#333;font-weight:500}.toast-close{flex-shrink:0;width:20px;height:20px;border:none;background:transparent;color:#999;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;padding:0}.toast-close:hover{background:#0000000d;color:#333}.toast-success{border-left:4px solid #28a745}.toast-success .toast-icon{background:#28a745}.toast-error{border-left:4px solid #dc3545}.toast-error .toast-icon{background:#dc3545}.toast-warning{border-left:4px solid #ffc107}.toast-warning .toast-icon{background:#ffc107;color:#333}.toast-info{border-left:4px solid #17a2b8}.toast-info .toast-icon{background:#17a2b8}@media(max-width:768px){.toast-container{top:10px;right:10px;left:10px}.toast{min-width:unset;width:100%}}.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--input-padding-x) center;background-size:16px;padding-right:calc(var(--input-padding-x) * 2 + 16px);cursor:pointer}.alert{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);border-left:4px solid transparent;font-size:var(--font-md);line-height:var(--line-height-normal);margin-bottom:var(--spacing-md)}.alert-icon{font-size:var(--font-lg);font-weight:var(--font-weight-bold);line-height:1;flex-shrink:0;margin-top:2px}.alert-content{flex:1;color:inherit}.alert-dismiss{background:none;border:none;font-size:var(--font-lg);font-weight:var(--font-weight-bold);cursor:pointer;padding:0;line-height:1;color:inherit;opacity:.7;transition:opacity var(--transition-base);flex-shrink:0}.alert-dismiss:hover{opacity:1}.alert-dismiss:focus{outline:none;opacity:1}.alert-error{background-color:var(--color-danger-light);border-left-color:var(--color-danger);color:var(--color-danger-active)}.alert-error .alert-icon{color:var(--color-danger)}.alert-warning{background-color:var(--color-warning-light);border-left-color:var(--color-warning);color:#856404}.alert-warning .alert-icon{color:var(--color-warning-active)}.alert-success{background-color:var(--color-success-light);border-left-color:var(--color-success);color:var(--color-success-active)}.alert-success .alert-icon{color:var(--color-success)}.alert-info{background-color:var(--color-info-light);border-left-color:var(--color-info);color:var(--color-info-active)}.alert-info .alert-icon{color:var(--color-info)}.alert-dismissible{padding-right:var(--spacing-xl)}@media(max-width:768px){.alert{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm)}.alert-dismissible{padding-right:var(--spacing-lg)}.alert-icon{font-size:var(--font-base)}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2.5rem;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{font-size:1.8rem;color:#333;margin-bottom:.5rem;text-align:center}.login-box h2{font-size:1.2rem;color:#666;margin-bottom:2rem;text-align:center;font-weight:400}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.login-button{width:100%}.card{background-color:var(--color-bg);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.card-default{border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.card-tool{border:1px solid var(--color-border);padding:var(--spacing-xl);box-shadow:var(--shadow-md);cursor:pointer;display:flex;flex-direction:column;align-items:center;text-align:center;min-height:200px}.card-tool:not(.card-disabled):hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.card-tool .tool-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.card-tool .tool-name{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-sm)}.card-tool .tool-description{font-size:var(--font-md);color:var(--color-text-light);line-height:var(--line-height-relaxed)}.card-tool .tool-coming-soon{margin-top:auto;padding-top:var(--spacing-md);font-size:var(--font-sm);color:var(--color-text-muted);font-style:italic}.card-section{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.card-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.card-clickable:focus{outline:none;box-shadow:var(--shadow-focus)}.card-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.card-tool.card-disabled{transform:none!important}.card-title{font-size:var(--font-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-light)}.card-section .card-title{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);padding:0;margin-bottom:var(--spacing-md);border-bottom:none;background-color:transparent}.card-content{padding:var(--spacing-lg)}.card-tool .card-content,.card-section .card-content{padding:0}.card:not(:has(.card-title)) .card-content{padding:var(--spacing-lg)}@media(max-width:768px){.card-tool{min-height:150px;padding:var(--spacing-lg)}.card-tool .tool-icon{font-size:2.5rem}.card-tool .tool-name{font-size:var(--font-lg)}.card-section,.card-content{padding:var(--spacing-md)}}.section{margin-bottom:var(--spacing-lg)}.section-bordered{padding:var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg)}.section-elevated{padding:var(--spacing-lg);border-radius:var(--radius-lg);background-color:var(--color-bg);box-shadow:var(--shadow-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.section-bordered .section-header,.section-elevated .section-header{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.section-header-text{display:flex;flex-direction:column;gap:var(--spacing-xs)}.section-title{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0;line-height:var(--line-height-tight)}.section-subtitle{font-size:var(--font-sm);font-weight:var(--font-weight-normal);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-normal)}.section-actions{display:flex;gap:var(--spacing-sm);align-items:center}@media(max-width:768px){.section-header{flex-direction:column;align-items:flex-start}.section-actions{width:100%}.section-actions>*{flex:1}.section-bordered,.section-elevated{padding:var(--spacing-md)}.section-title{font-size:var(--font-lg)}}.subsection{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid #e0e0e0}.subsection:last-child{border-bottom:none;padding-bottom:0}.subsection-title{font-size:1.1rem;font-weight:var(--font-weight-semibold);color:#1a365d;margin:0 0 var(--spacing-md) 0;line-height:var(--line-height-tight)}@media(max-width:768px){.subsection-title{font-size:1rem}}.step-section{background-color:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a;border-left:4px solid var(--color-border);transition:border-color .3s ease}.step-section-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.step-number{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;border-radius:50%;background-color:var(--color-border);color:#fff;font-weight:600;font-size:1rem;flex-shrink:0;transition:background-color .3s ease}.step-header-content{flex:1}.step-title{font-size:1.2rem;font-weight:600;color:var(--color-text);margin:0 0 .25rem}.step-description{font-size:.9rem;color:var(--color-text-muted);margin:0}.step-status-pending{opacity:.7;border-left-color:var(--color-border)}.step-status-pending .step-number{background-color:var(--color-border)}.step-status-active{border-left-color:var(--color-primary)}.step-status-active .step-number{background-color:var(--color-primary)}.step-status-completed{border-left-color:var(--color-success)}.step-status-completed .step-number{background-color:var(--color-success)}@media(max-width:768px){.step-section{padding:1rem}.step-section-header{gap:.75rem;margin-bottom:1rem}.step-number{min-width:28px;height:28px;font-size:.9rem}.step-title{font-size:1.1rem}.step-description{font-size:.85rem}}.accordion{display:flex;flex-direction:column;gap:1rem}.accordion-item{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .2s}.accordion-item-expanded{box-shadow:0 2px 6px #00000026}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:all .2s;min-height:60px;background-color:#fff}.accordion-header:hover{background-color:#f9f9f9}.accordion-item-expanded .accordion-header{border-bottom:1px solid #e0e0e0}.accordion-title-wrapper{display:flex;align-items:center;gap:.8rem;flex:1}.accordion-icon{font-size:1.5rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;margin:0}.accordion-title{font-weight:600;font-size:1.1rem;color:#333;line-height:1.3;display:flex;align-items:center;margin:0}.accordion-badge{color:#666;font-size:.95rem;font-weight:500;margin-left:.3rem}.accordion-expand-icon{font-size:.9rem;color:#999;transition:transform .2s;flex-shrink:0}.accordion-content{padding:1.5rem;background-color:#fff;animation:accordion-slide-down .3s ease-out}@keyframes accordion-slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.accordion-header{padding:.75rem 1rem}.accordion-content{padding:1rem}.accordion-title{font-size:1rem}.accordion-icon{font-size:1.25rem}}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-full);white-space:nowrap;vertical-align:middle}.badge-sm{padding:2px var(--spacing-xs);font-size:var(--font-xs)}.badge-md{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-sm)}.badge-default{background-color:var(--color-secondary);color:var(--color-text);border:1px solid var(--color-border)}.badge-success{background-color:var(--color-success-light);color:var(--color-success-active);border:1px solid var(--color-success)}.badge-warning{background-color:var(--color-warning-light);color:#856404;border:1px solid var(--color-warning)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger-active);border:1px solid var(--color-danger)}.badge-info{background-color:var(--color-info-light);color:var(--color-info-active);border:1px solid var(--color-info)}.badge-primary{background-color:var(--color-primary);color:var(--color-text-inverse);border:1px solid var(--color-primary)}@media(max-width:768px){.badge-md{font-size:var(--font-xs);padding:2px var(--spacing-xs)}}.loading-spinner-inline{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.loading-spinner-block{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl)}.loading-spinner-fullscreen{position:fixed;inset:0;background-color:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.loading-spinner-fullscreen .loading-spinner-content{background-color:var(--color-bg);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.loading-spinner{border-radius:50%;border-style:solid;border-color:var(--color-border);border-top-color:var(--color-primary);animation:spinner-rotate .8s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.loading-spinner-sm{width:16px;height:16px;border-width:2px}.loading-spinner-md{width:32px;height:32px;border-width:3px}.loading-spinner-lg{width:48px;height:48px;border-width:4px}.loading-message{font-size:var(--font-md);color:var(--color-text-light);margin:0}.loading-spinner-inline .loading-message{font-size:var(--font-sm)}.loading-spinner-fullscreen .loading-message{font-size:var(--font-lg);color:var(--color-text)}@media(max-width:768px){.loading-spinner-block{padding:var(--spacing-md)}.loading-spinner-fullscreen .loading-spinner-content{padding:var(--spacing-lg)}}.progress-bar-container{width:100%;margin:1rem 0}.progress-message{font-size:.9rem;color:#495057;margin-bottom:.5rem;font-weight:500}.progress-bar{width:100%;height:30px;background-color:#e9ecef;border-radius:4px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease;display:flex;align-items:center;justify-content:center;position:relative}.progress-bar-text{color:#fff;font-weight:600;font-size:.85rem;position:absolute;left:50%;transform:translate(-50%);z-index:1}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:1rem}.header-logo{height:40px}.app-header h1{font-size:1.5rem;font-weight:600;color:#333;margin:0}.header-actions{display:flex;align-items:center;gap:1rem}.user-info{color:#666;font-size:.9rem}@media(max-width:768px){.app-header{padding:1rem}}.modal-overlay{position:fixed;inset:0;background-color:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-md);animation:modal-fade-in var(--transition-base)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:calc(100vh - 2 * var(--spacing-md));width:100%;animation:modal-slide-up var(--transition-base)}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1200px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0;line-height:var(--line-height-tight)}.modal-close{background:none;border:none;font-size:var(--font-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-light);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base);flex-shrink:0;margin-left:var(--spacing-md)}.modal-close:hover{background-color:var(--color-bg-light);color:var(--color-text)}.modal-close:focus{outline:none;box-shadow:var(--shadow-focus)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border);flex-shrink:0}@media(max-width:768px){.modal-overlay{padding:0}.modal-content{max-height:100vh;border-radius:0;width:100%;max-width:100%}.modal-header,.modal-body{padding:var(--spacing-md)}.modal-footer{padding:var(--spacing-md);flex-direction:column}.modal-footer>*{width:100%}.modal-title{font-size:var(--font-lg)}}.tooltip-container{position:relative;display:inline-flex}.tooltip-content{position:absolute;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-dark);color:var(--color-text-inverse);font-size:var(--font-sm);line-height:var(--line-height-normal);border-radius:var(--radius-sm);white-space:nowrap;z-index:var(--z-tooltip);opacity:0;pointer-events:none;transition:opacity var(--transition-base);box-shadow:var(--shadow-md)}.tooltip-visible{opacity:1}.tooltip-arrow{position:absolute;width:0;height:0;border-style:solid}.tooltip-top{bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);margin-bottom:8px}.tooltip-top .tooltip-arrow{top:100%;left:50%;transform:translate(-50%);border-width:6px 6px 0 6px;border-color:var(--color-bg-dark) transparent transparent transparent}.tooltip-bottom{top:100%;left:50%;transform:translate(-50%) translateY(8px);margin-top:8px}.tooltip-bottom .tooltip-arrow{bottom:100%;left:50%;transform:translate(-50%);border-width:0 6px 6px 6px;border-color:transparent transparent var(--color-bg-dark) transparent}.tooltip-left{right:100%;top:50%;transform:translateY(-50%) translate(-8px);margin-right:8px}.tooltip-left .tooltip-arrow{left:100%;top:50%;transform:translateY(-50%);border-width:6px 0 6px 6px;border-color:transparent transparent transparent var(--color-bg-dark)}.tooltip-right{left:100%;top:50%;transform:translateY(-50%) translate(8px);margin-left:8px}.tooltip-right .tooltip-arrow{right:100%;top:50%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:transparent var(--color-bg-dark) transparent transparent}.tooltip-content.tooltip-multiline{white-space:normal;max-width:250px}@media(max-width:768px){.tooltip-content{font-size:var(--font-xs);padding:4px var(--spacing-xs)}.tooltip-content.tooltip-multiline{max-width:200px}}.tab-navigation-wrapper{display:flex;align-items:stretch;background-color:var(--color-bg);border-bottom:2px solid var(--color-border);position:relative}.tab-navigation{display:flex;flex:1;padding:0;margin:0;list-style:none;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;-ms-overflow-style:none;scrollbar-width:none}.tab-navigation::-webkit-scrollbar{display:none}.tab-scroll-button{display:flex;align-items:center;justify-content:center;padding:0;background-color:var(--color-bg);border:none;border-bottom:2px solid var(--color-border);color:var(--color-text);font-size:1.2rem;cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base);width:50px;flex-shrink:0;-webkit-user-select:none;user-select:none}.tab-scroll-button:hover:not(:disabled){background-color:var(--color-bg-light);color:var(--color-primary)}.tab-scroll-button:active:not(:disabled){background-color:var(--color-bg-hover)}.tab-scroll-button:disabled{color:var(--color-text-muted);cursor:not-allowed;opacity:.5}.tab-scroll-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px;z-index:1}.tab-scroll-left{border-left:none;border-right:1px solid var(--color-border)}.tab-scroll-right{border-right:none;border-left:1px solid var(--color-border)}.tab-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:1rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);font-size:var(--font-md);cursor:pointer;transition:color var(--transition-base),border-color var(--transition-base),background-color var(--transition-base);white-space:nowrap;flex-shrink:0;font-weight:var(--font-weight-medium);-webkit-user-select:none;user-select:none}.tab-button:hover{color:var(--color-text);background-color:var(--color-bg-light)}.tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-medium)}.tab-button.disabled{color:var(--color-text-muted);opacity:.5;cursor:not-allowed;pointer-events:none}.tab-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px;z-index:1}.tab-icon{font-size:1.1rem;line-height:1}.tab-label{line-height:1}@media(max-width:768px){.tab-button{padding:.8rem 1rem;font-size:var(--font-sm)}.tab-scroll-button{width:40px;font-size:1.1rem}.tab-icon{font-size:1rem}}@media(max-width:480px){.tab-button{padding:.6rem .8rem}.tab-scroll-button{width:35px;font-size:1rem}}@media(prefers-contrast:high){.tab-button.active{border-bottom-width:4px}}@media(prefers-reduced-motion:reduce){.tab-navigation{scroll-behavior:auto}.tab-button,.tab-scroll-button{transition:none}}.datatable-container{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;background-color:#fff;max-height:calc(100vh - 300px)}.datatable-scroll{overflow-x:auto;overflow-y:auto;flex:1}.datatable{width:100%;border-collapse:collapse;font-size:.9rem}.datatable-header{padding:.75rem 1rem;text-align:left;font-weight:600;color:#333;background-color:#f8f9fa;border-bottom:none;white-space:nowrap;-webkit-user-select:none;user-select:none;position:sticky;top:0;z-index:10}.datatable-header.sortable{cursor:pointer;transition:background-color .2s}.datatable-header.sortable:hover{background-color:#e9ecef}.datatable-header.right{text-align:right}.datatable-header.center{text-align:center}.datatable-header-content{display:flex;align-items:center;gap:.5rem;justify-content:flex-start}.datatable-header.right .datatable-header-content{justify-content:flex-end}.datatable-header.center .datatable-header-content{justify-content:center}.sort-indicator{font-size:.75rem;color:#667eea;font-weight:700}.datatable-filter-row{background-color:#f8f9fa}.datatable-filter-cell{padding:.4rem 1rem .5rem;border-bottom:2px solid #e0e0e0;background-color:#f8f9fa;position:sticky;top:43px;z-index:9}.datatable-filter-input{width:100%;padding:.35rem .5rem;font-size:.85rem;border:1px solid #d0d0d0;border-radius:4px;outline:none;transition:border-color .2s;background-color:#fff}.datatable-filter-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.datatable-filter-input::placeholder{color:#999;font-size:.8rem}.datatable-cell{padding:.75rem 1rem;border-bottom:1px solid #f0f0f0;color:#555;vertical-align:middle}.datatable tbody tr:hover{background-color:#f8f9fa}.datatable tbody tr:last-child .datatable-cell{border-bottom:none}.datatable-cell.right{text-align:right}.datatable-cell.center{text-align:center}.datatable-cell.left{text-align:left}.datatable-footer{padding:.75rem 1rem;background-color:#f8f9fa;border-top:1px solid #e0e0e0;font-size:.85rem;color:#666;text-align:right}.datatable-empty{padding:3rem 2rem;text-align:center;color:#999;font-size:.95rem;border:1px solid #e0e0e0;border-radius:6px;background-color:#f8f9fa}@media(max-width:768px){.datatable-header,.datatable-filter-cell,.datatable-cell{padding:.5rem .75rem;font-size:.85rem}.datatable-filter-input{font-size:.8rem;padding:.3rem .5rem}}.virtualized-datatable-container{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;background-color:#fff}.virtual-scroll-container{position:relative;overflow:auto}.virtual-header{background-color:#f8f9fa;border-bottom:2px solid #e0e0e0}.virtual-header::-webkit-scrollbar{display:none}.virtual-header{-ms-overflow-style:none;scrollbar-width:none}.virtual-header-row,.virtual-filter-row{display:flex;width:fit-content;min-width:100%}.virtual-header-cell{flex-shrink:0;padding:.75rem 1rem;border-right:1px solid #e0e0e0;font-weight:600;color:#333;white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative}.column-resize-handle{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.column-resize-handle:hover{background-color:#667eea!important}body.resizing{-webkit-user-select:none;user-select:none;cursor:col-resize}.virtual-header-cell:last-child{border-right:none}.virtual-header-cell.sortable{cursor:pointer;transition:background-color .2s}.virtual-header-cell.sortable:hover{background-color:#e9ecef}.virtual-header-content{display:flex;align-items:center;gap:.5rem;justify-content:flex-start}.virtual-header-cell.right .virtual-header-content{justify-content:flex-end}.virtual-header-cell.center .virtual-header-content{justify-content:center}.virtual-filter-row{background-color:#f8f9fa}.virtual-filter-cell{flex-shrink:0;padding:.4rem 1rem .5rem;border-right:1px solid #e0e0e0;border-bottom:2px solid #e0e0e0}.virtual-filter-cell:last-child{border-right:none}.virtual-body{overflow:hidden}.virtual-row{display:flex;width:fit-content;min-width:100%;border-bottom:1px solid #f0f0f0;transition:background-color .15s}.virtual-row:hover{background-color:#f8f9fa}.virtual-cell{flex-shrink:0;padding:.75rem 1rem;border-right:1px solid #f0f0f0;color:#555;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center}.virtual-cell:last-child{border-right:none}.virtual-cell.right{justify-content:flex-end;text-align:right}.virtual-cell.center{justify-content:center;text-align:center}.virtual-cell.left{justify-content:flex-start;text-align:left}.virtual-cell .url-link{color:#667eea;text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.virtual-cell .url-link:hover{text-decoration:underline}@media(max-width:768px){.virtual-header-cell,.virtual-filter-cell,.virtual-cell{padding:.5rem .75rem;font-size:.85rem}}.file-upload-container{margin-bottom:1.5rem}.file-upload-label{display:block;font-weight:500;margin-bottom:.5rem;color:#333;font-size:.95rem}.file-upload-description{font-size:.85rem;color:#666;margin:0 0 .75rem;line-height:1.4}.file-upload-dropzone{border:2px dashed #d0d0d0;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s ease;background:#fafafa}.file-upload-dropzone:hover:not(.disabled){border-color:#667eea;background:#f8f9ff}.file-upload-dropzone.dragging{border-color:#667eea;background:#e7f3ff;border-style:solid}.file-upload-dropzone.disabled{opacity:.6;cursor:not-allowed;background:#f5f5f5}.dropzone-content{pointer-events:none}.dropzone-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.dropzone-text{font-size:1rem;color:#333;font-weight:500;margin:0 0 .5rem}.dropzone-hint{font-size:.85rem;color:#999;margin:0}.file-list{margin-top:1rem;border-top:1px solid #e0e0e0;padding-top:1rem}.file-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:.5rem;background:#fff;transition:all .2s ease}.file-item:hover{border-color:#667eea;background:#f8f9ff}.file-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.file-icon{font-size:1.5rem;flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{font-size:.9rem;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:.8rem;color:#999;margin-top:.25rem}.file-remove{background:none;border:none;color:#999;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:color .2s ease;flex-shrink:0}.file-remove:hover:not(:disabled){color:#e53e3e}.file-remove:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.file-upload-dropzone{padding:1.5rem}.dropzone-icon{font-size:2.5rem}.dropzone-text{font-size:.9rem}.file-item{padding:.6rem}.file-icon{font-size:1.25rem}}.autocomplete-wrapper{position:relative;width:100%}.autocomplete-wrapper.autocomplete-disabled{opacity:.6;cursor:not-allowed}.autocomplete-input{width:100%;padding:var(--input-padding-y) var(--input-padding-x);font-family:var(--font-family-base);font-size:var(--font-md);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-base),box-shadow var(--transition-base);box-sizing:border-box;height:38px}.autocomplete-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-focus)}.autocomplete-input::placeholder{color:var(--color-text-muted);opacity:.7}.autocomplete-input:disabled,.autocomplete-input-disabled{background-color:var(--color-bg-light);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.autocomplete-input-error{border-color:var(--color-border-error)}.autocomplete-input-error:focus{border-color:var(--color-border-error);box-shadow:0 0 0 3px var(--color-danger-light)}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;max-height:250px;overflow-y:auto;background-color:var(--color-bg);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:var(--shadow-md);z-index:1000;margin:-1px 0 0;padding:0;list-style:none}.autocomplete-item{padding:.6rem .8rem;cursor:pointer;transition:background-color var(--transition-base);border-bottom:1px solid var(--color-bg-light);font-size:var(--font-md);color:var(--color-text)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item-highlighted{background-color:var(--color-bg-light)}.autocomplete-item-selected{background-color:#e3f2fd;color:var(--color-primary);font-weight:var(--font-weight-medium)}.autocomplete-item-selected:hover{background-color:#d1e7fd}.autocomplete-loading,.autocomplete-empty{padding:.8rem;text-align:center;color:var(--color-text-muted);font-size:var(--font-sm);font-style:italic}@media(max-width:768px){.autocomplete-dropdown{max-height:200px}}.editable-product-list{display:flex;flex-direction:column;gap:1.5rem}.product-card-content{display:flex;gap:1.5rem;align-items:flex-start}.product-images{display:flex;gap:.5rem;flex-wrap:wrap;min-width:120px}.product-image-thumb{width:60px;height:60px;border:1px solid #e0e0e0;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:#f8f9fa}.product-image-count{font-size:.85rem;color:#666;align-self:center}.product-data{flex:1;min-width:0}.product-id{margin-bottom:.5rem;font-weight:600;color:#666;font-size:.9rem}.product-edit-form{display:flex;flex-direction:column;gap:1rem}.product-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.product-display{display:flex;flex-direction:column;gap:.5rem}.product-display-field{font-size:.9rem;color:#666}.product-display-field.product-name{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:.25rem}@media(max-width:768px){.product-card-content{flex-direction:column}.product-images{min-width:auto}}.editable-datatable-container{width:100%;display:flex;flex-direction:column;overflow:hidden;border:1px solid #e0e6ed;border-radius:8px;background:#fff;max-height:calc(100vh - 300px)}.editable-datatable-scroll{overflow-x:auto;overflow-y:auto;flex:1}.editable-datatable{width:100%;border-collapse:collapse;font-size:.9rem}.editable-datatable thead{background:#f8f9fa}.editable-datatable th{padding:.75rem .5rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e6ed;white-space:nowrap;background:#f8f9fa;position:sticky;top:0;z-index:10}.editable-datatable th.center{text-align:center}.editable-datatable th.right{text-align:right}.editable-datatable td{padding:.5rem;border-bottom:1px solid #f0f0f0;vertical-align:middle}.editable-datatable tbody tr:hover{background:#f8f9ff}.editable-datatable td.editable{cursor:pointer;transition:background .15s ease}.editable-datatable td.editable:hover{background:#e7f3ff}.editable-datatable td.editing{padding:.25rem;background:#fff}.editable-datatable .cell-input{width:100%;padding:.4rem;border:1px solid #667eea;border-radius:4px;font-size:.9rem;font-family:inherit;outline:none;box-shadow:0 0 0 3px #667eea1a}.editable-datatable-empty{padding:2rem;text-align:center;color:#999;background:#f8f9fa;border:1px solid #e0e6ed;border-radius:8px}@media(max-width:768px){.editable-datatable{font-size:.85rem}.editable-datatable th,.editable-datatable td{padding:.5rem .4rem}}.image-comparison-slider{position:relative;width:100%;height:100%;overflow:hidden;border-radius:8px;background:#1a1a1a;cursor:ew-resize;user-select:none;-webkit-user-select:none}.image-comparison-slider:focus{outline:2px solid #3b82f6;outline-offset:2px}.image-container{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.image-container.after{z-index:1}.image-container.before{z-index:2}.image-container img{width:100%;height:100%;object-fit:contain;pointer-events:none;display:block}.image-label{position:absolute;top:16px;padding:8px 16px;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:14px;font-weight:600;border-radius:6px;z-index:30;pointer-events:none;white-space:nowrap}.before-label{left:16px}.after-label{right:16px}.slider-handle{position:absolute;top:0;bottom:0;width:4px;margin-left:-2px;z-index:20;cursor:ew-resize;transition:opacity .2s}.slider-handle:hover,.slider-handle.dragging{opacity:1}.slider-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 10px #00000080;transform:translate(-50%)}.slider-button{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;display:flex;align-items:center;justify-content:center;gap:2px;cursor:grab;transition:transform .2s,box-shadow .2s}.slider-button:hover{transform:translate(-50%,-50%) scale(1.1);box-shadow:0 4px 12px #0006}.slider-handle.dragging .slider-button{cursor:grabbing;transform:translate(-50%,-50%) scale(1.15);box-shadow:0 6px 16px #00000080}.slider-button svg{color:#333;width:16px;height:16px}.slider-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);padding:6px 12px;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:12px;border-radius:4px;pointer-events:none;z-index:10;opacity:0;animation:fadeInHint .3s ease-in-out .5s forwards}@keyframes fadeInHint{to{opacity:1}}.slider-hint{animation:fadeInHint .3s ease-in-out .5s forwards,fadeOutHint .3s ease-in-out 3s forwards}@keyframes fadeOutHint{to{opacity:0}}@media(max-width:768px){.image-comparison-slider{min-height:300px}.slider-button{width:40px;height:40px}.image-label{font-size:12px;padding:4px 8px;top:12px}.before-label{left:12px}.after-label{right:12px}}.relogin-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.relogin-modal{max-width:400px;width:90%;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.relogin-modal-content{padding:1rem}.relogin-modal-content h2{margin-top:0;margin-bottom:.5rem;color:#d32f2f}.relogin-modal-content>p{margin-bottom:1.5rem;color:#666}.relogin-modal-content form{display:flex;flex-direction:column;gap:1rem}.relogin-modal-content .form-group{display:flex;flex-direction:column;gap:.5rem}.relogin-modal-content .form-group label{font-weight:500;color:#333}.relogin-btn{width:100%;margin-top:.5rem}.relogin-note{margin-top:1rem;margin-bottom:0;font-size:.875rem;color:#666;text-align:center}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow-y:auto}.dashboard-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}.dashboard-content h2{color:#fff;font-size:2.5rem;margin:0 0 .5rem;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.1)}.dashboard-subtitle{color:#ffffffe6;font-size:1.1rem;text-align:center;margin:0 0 2rem}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,300px);gap:1.5rem;margin-top:2rem;justify-content:center}.tool-card{background:#fff;border-radius:12px;padding:1.5rem 1.25rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #0000001a;position:relative;overflow:hidden;width:300px;min-height:200px;display:flex;flex-direction:column;justify-content:flex-start;gap:.75rem}.tool-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.tool-card-disabled{opacity:.6;cursor:not-allowed}.tool-card-disabled:hover{transform:none;box-shadow:0 4px 6px #0000001a}.tool-icon{font-size:3.5rem;text-align:center;line-height:1;height:3.5rem;max-height:3.5rem;flex-shrink:0}.tool-name{font-size:1.25rem;color:#2d3748;margin:0;text-align:center;font-weight:600;line-height:1.3;flex-shrink:0}.tool-description{color:#4a5568;font-size:.85rem;line-height:1.4;text-align:center;margin:0;flex:1;display:block}.tool-coming-soon{position:absolute;top:1rem;right:1rem;background:#f56565;color:#fff;padding:.35rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}@media(max-width:900px){.tools-grid{grid-template-columns:repeat(auto-fit,280px)}.tool-card{width:280px;min-height:190px}.tool-icon{font-size:3rem;height:3rem;max-height:3rem}}@media(max-width:768px){.dashboard-content{padding:2rem 1rem}.dashboard-content h2{font-size:2rem}.tools-grid{grid-template-columns:repeat(auto-fit,280px);gap:1.5rem}.tool-card{width:280px;min-height:190px;padding:1.25rem 1rem}.tool-icon{font-size:3rem;height:3rem;max-height:3rem}.tool-name{font-size:1.15rem}.tool-description{font-size:.8rem}}.sidebar,.gtm-sidebar{width:300px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}.sidebar-section{border-bottom:1px solid #f0f0f0}.sidebar-header{position:relative;padding:1rem 1.5rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.sidebar-header h2,.sidebar-title{font-size:1rem;font-weight:600;color:#333;margin:0;line-height:1.2}.sidebar-title{padding:1rem 1.5rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.sidebar-actions{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem}.sidebar-button{width:100%}.new-audit-button{position:absolute;top:50%;right:1.5rem;transform:translateY(-50%)}.sidebar-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;color:#999}.sidebar-spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:sidebar-spin .8s linear infinite;margin-bottom:1rem}@keyframes sidebar-spin{to{transform:rotate(360deg)}}.sidebar-info{padding:1rem;background-color:#f8f9fa;border-radius:6px;margin:1rem 1.5rem 1.5rem}.info-item{display:flex;flex-direction:column;margin-bottom:.75rem}.info-item:last-child{margin-bottom:0}.info-value{font-size:.9rem;color:#333;font-weight:500;word-break:break-word}.audit-list{flex:1;overflow-y:auto;padding:.5rem 0}.no-audits{padding:2rem 1rem;text-align:center;color:#6c757d}.no-audits .hint{font-size:.85rem;margin-top:.5rem;color:#6c757d}.audit-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;margin:.25rem .5rem;border-radius:6px;cursor:pointer;transition:all .2s;border:1px solid transparent}.audit-item:hover{background-color:#f8f9fa;border-color:#e0e0e0}.audit-item.active{background-color:#e7f3ff;border-color:#007bff;border-left-width:3px}.audit-item.active:hover{background-color:#e7f3ff}.audit-info{flex:1;min-width:0}.audit-name{font-weight:500;color:#333;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audit-domain{font-size:.8rem;color:#6c757d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.delete-button{width:24px;height:24px;background-color:transparent;color:#dc3545;border:none;border-radius:4px;font-size:1.2rem;line-height:1;cursor:pointer;transition:all .2s;flex-shrink:0}.delete-button:hover{background-color:#dc3545;color:#fff}@media(max-width:768px){.sidebar,.gtm-sidebar{width:250px}.sidebar-header,.sidebar-title,.sidebar-actions,.domain-selector{padding:1rem}.sidebar-info{margin:1rem}.new-audit-button{right:1rem}}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--min-item-width, 300px),1fr));gap:.75rem}.checkbox-grid-item{border:1px solid #e0e0e0;border-radius:6px;padding:.75rem 1rem;transition:background-color .2s,border-color .2s;display:flex;align-items:center}.checkbox-grid-item .checkbox-label.checkbox-inline{margin-right:0;margin-bottom:0}.checkbox-grid-item:hover{background-color:#f8f9fa;border-color:#667eea}.checkbox-grid-item-content{display:flex;flex-direction:column;flex:1}.checkbox-grid-item-name{font-weight:500;color:#2c3e50}.checkbox-grid-item-description{font-size:.9rem;color:#7f8c8d;margin-top:.25rem}.checkbox-grid-empty{padding:2rem;text-align:center;color:#7f8c8d;font-style:italic}@media(max-width:768px){.checkbox-grid{grid-template-columns:1fr}}.multiselect-dropdown{position:relative;width:100%}.multiselect-button{width:100%;padding:var(--input-padding-y) var(--input-padding-x);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:var(--font-md);font-family:var(--font-family-base);transition:border-color var(--transition-base),box-shadow var(--transition-base);text-align:left}.multiselect-button:hover:not(:disabled){border-color:var(--color-border-hover)}.multiselect-button:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-focus)}.multiselect-button-open{border-color:var(--color-border-focus)}.multiselect-button:disabled,.multiselect-button-disabled{background-color:var(--color-bg-light);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.multiselect-text{color:var(--color-text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multiselect-button:disabled .multiselect-text,.multiselect-button-disabled .multiselect-text{color:var(--color-text-muted)}.multiselect-arrow{color:var(--color-text-light);font-size:var(--font-xs);margin-left:var(--spacing-sm);flex-shrink:0}.multiselect-menu{position:absolute;top:100%;left:0;right:0;margin-top:var(--spacing-xs);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);max-height:300px;overflow:hidden;display:flex;flex-direction:column}.multiselect-options{overflow-y:auto;max-height:250px}.multiselect-option{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:background-color var(--transition-fast);-webkit-user-select:none;user-select:none}.multiselect-option:hover{background-color:var(--color-bg-light)}.multiselect-option input[type=checkbox]{margin-right:var(--spacing-sm);width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary);flex-shrink:0}.multiselect-label{font-size:var(--font-md);color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;flex:1}.select-all-option{font-weight:var(--font-weight-medium);color:var(--color-primary);background-color:var(--color-bg-light)}.select-all-option:hover{background-color:var(--color-secondary-hover)}.select-all-option .multiselect-label{color:var(--color-primary)}.multiselect-divider{height:1px;background-color:var(--color-border);margin:0}.multiselect-error .multiselect-button{border-color:var(--color-border-error)}.multiselect-error .multiselect-button:focus{border-color:var(--color-border-error);box-shadow:0 0 0 3px var(--color-danger-light)}.multiselect-disabled{opacity:.6;cursor:not-allowed}.multiselect-options::-webkit-scrollbar{width:6px}.multiselect-options::-webkit-scrollbar-track{background:var(--color-bg-light);border-radius:var(--radius-sm)}.multiselect-options::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:var(--radius-sm)}.multiselect-options::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}@media(max-width:768px){.multiselect-menu{max-height:250px}.multiselect-options{max-height:200px}}.audit-editor{display:flex;flex-direction:column;height:100%;overflow:hidden}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 2rem;border-bottom:1px solid #e0e0e0;background-color:#fff}.editor-header h2{font-size:1.5rem;font-weight:600;color:#2c3e50}.header-buttons{display:flex;gap:1rem;align-items:center}.error-banner{padding:1rem 2rem;background-color:#fee;border-left:4px solid #e74c3c;color:#c0392b;font-weight:500}.editor-loading{display:flex;justify-content:center;align-items:center;height:100%;color:#999;font-size:1.1rem}.required{color:#e74c3c;margin-left:.25rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.form-field{display:flex;flex-direction:column}.form-field label{font-weight:500;margin-bottom:.5rem;color:#34495e}.error-message{color:#e74c3c;font-size:.85rem;margin-top:.25rem}.help-text{color:#7f8c8d;font-size:.85rem;margin-top:.25rem;font-style:italic}.bundle-settings-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.bundle-settings-section:first-child{margin-top:0;padding-top:0;border-top:none}.bundle-settings-section h4{font-size:1rem;font-weight:600;color:#34495e;margin-bottom:1rem}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.setting-field{display:flex;flex-direction:column}.setting-field label{font-weight:500;margin-bottom:.5rem;color:#34495e;font-size:.9rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin-bottom:0}@media(max-width:768px){.form-grid,.settings-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.editor-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-buttons{width:100%;flex-direction:column}}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.progress-modal{background-color:#fff;border-radius:8px;box-shadow:0 10px 40px #0000004d;width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px 8px 0 0}.modal-header h2{font-size:1.3rem;font-weight:600;margin:0}.connection-status{display:flex;align-items:center;gap:.5rem}.status-indicator{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-indicator.connected{background-color:#2ecc71}.status-indicator.disconnected{background-color:#e74c3c}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:.9rem;font-weight:500}.modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;background-color:#f8f9fa}.no-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#7f8c8d}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.message-wrapper{margin-bottom:1rem}.progress-message{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background-color:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;animation:messageSlide .3s ease-out}@keyframes messageSlide{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.progress-message .icon{font-size:1.5rem;flex-shrink:0}.message-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.message-text{font-weight:500;color:#2c3e50}.message-status{font-size:.85rem;color:#7f8c8d;font-style:italic}.progress-bar{position:relative;width:100%;height:24px;background-color:#ecf0f1;border-radius:12px;overflow:hidden;margin-top:.25rem}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:12px;transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.8rem;font-weight:600;color:#2c3e50}.complete-message{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-left:4px solid #28a745}.error-message{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border-left:4px solid #dc3545}.info-message{background:linear-gradient(135deg,#d1ecf1,#bee5eb);border-left:4px solid #17a2b8}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e0e0e0;background-color:#fff;border-radius:0 0 8px 8px}.modal-footer button{padding:.75rem 1.5rem;border:none;border-radius:5px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.button-icon{font-size:1.1rem}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.messages-container::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.messages-container::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:768px){.progress-modal{width:95%;max-height:90vh}.modal-header,.modal-footer,.messages-container{padding:1rem}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.main-layout{display:flex;flex-direction:column;height:100vh;width:100%;background-color:#f5f5f5}.main-content{display:flex;flex:1;overflow:hidden}.editor-area{flex:1;display:flex;flex-direction:column;overflow-y:auto;background-color:#fff}.no-audit-selected{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#999}.no-audit-selected p{font-size:1.2rem;margin-bottom:2rem}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.code-editor-wrapper{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;background-color:#1e1e1e}.code-editor-wrapper.light{background-color:#fff}.editor-placeholder{color:#6c757d;font-style:italic;pointer-events:none;-webkit-user-select:none;user-select:none}.code-editor-wrapper .monaco-editor{width:100%!important}.form-group .code-editor-wrapper{margin-top:.5rem}@media(max-width:768px){.code-editor-wrapper{min-height:300px}}.tool-icon{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%}.tool-icon img,.tool-icon svg{display:block;width:100%;height:100%;object-fit:contain}.filter-editor{display:flex;flex-direction:column;gap:var(--spacing-sm)}.filters-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.filter-item{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.filter-item:hover{border-color:var(--color-border-hover)}.filter-item:focus-within{border-color:var(--color-border-focus);box-shadow:var(--shadow-focus)}.filter-row{display:grid;grid-template-columns:1.5fr 1fr 1.5fr auto;gap:var(--spacing-sm);align-items:center}.filter-field{position:relative}.filter-row .btn{flex-shrink:0}.filter-editor .empty-state{margin-bottom:var(--spacing-sm)}.filter-editor>.btn{align-self:flex-start}@media(max-width:992px){.filter-row{grid-template-columns:1fr 1fr 1fr auto}}@media(max-width:768px){.filter-row{grid-template-columns:1fr;gap:var(--spacing-xs)}.filter-row .btn{justify-self:flex-start}}datalist{display:none}.keyvalue-editor{display:flex;flex-direction:column;gap:var(--spacing-sm)}.keyvalue-empty{padding:var(--spacing-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-sm);font-style:italic;border:1px dashed var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-light)}.keyvalue-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.keyvalue-header{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--spacing-sm);padding:0 var(--spacing-xs) var(--spacing-xs);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-xs)}.keyvalue-header-label{font-size:var(--font-xs);font-weight:var(--font-weight-medium);color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px}.keyvalue-header-spacer{width:32px}.keyvalue-row{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--spacing-sm);align-items:center}.keyvalue-input{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-sm);font-family:var(--font-family-base);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.keyvalue-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 2px #007bff1a}.keyvalue-input::placeholder{color:var(--color-text-muted);opacity:.7}.keyvalue-remove{width:32px;height:32px;padding:0;background-color:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-danger);font-size:var(--font-md);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;flex-shrink:0}.keyvalue-remove:hover{background-color:var(--color-danger);color:var(--color-text-inverse);border-color:var(--color-danger)}.keyvalue-remove:focus{outline:none;box-shadow:0 0 0 2px var(--color-danger-light)}.keyvalue-add{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-light);border:1px dashed var(--color-border);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);align-self:flex-start}.keyvalue-add:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary);border-style:solid}.keyvalue-add:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary-light)}.keyvalue-add:disabled{opacity:.5;cursor:not-allowed;color:var(--color-text-muted)}@media(max-width:768px){.keyvalue-row{grid-template-columns:1fr;gap:var(--spacing-xs);padding:var(--spacing-sm);background-color:var(--color-bg-light);border-radius:var(--radius-sm);position:relative}.keyvalue-remove{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);width:24px;height:24px;font-size:var(--font-sm)}.keyvalue-header{display:none}.keyvalue-input{width:100%}.keyvalue-add{width:100%;text-align:center}}:root{--color-primary: #007bff;--color-primary-hover: #0056b3;--color-primary-active: #004085;--color-primary-light: rgba(0, 123, 255, .1);--color-secondary: #f8f9fa;--color-secondary-hover: #e9ecef;--color-secondary-active: #dee2e6;--color-success: #28a745;--color-success-hover: #218838;--color-success-active: #1e7e34;--color-success-light: rgba(40, 167, 69, .1);--color-danger: #dc3545;--color-danger-hover: #c82333;--color-danger-active: #bd2130;--color-danger-light: rgba(220, 53, 69, .1);--color-warning: #ffc107;--color-warning-hover: #e0a800;--color-warning-active: #d39e00;--color-warning-light: rgba(255, 193, 7, .1);--color-info: #17a2b8;--color-info-hover: #138496;--color-info-active: #117a8b;--color-info-light: rgba(23, 162, 184, .1);--color-text: #333;--color-text-light: #666;--color-text-muted: #999;--color-text-inverse: #ffffff;--color-bg: #ffffff;--color-bg-light: #f8f9fa;--color-bg-dark: #343a40;--color-bg-overlay: rgba(0, 0, 0, .5);--color-border: #e0e0e0;--color-border-hover: #d0d0d0;--color-border-focus: #80bdff;--color-border-error: #dc3545;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 2px 4px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 8px rgba(0, 0, 0, .15);--shadow-xl: 0 8px 16px rgba(0, 0, 0, .2);--shadow-focus: 0 0 0 3px rgba(0, 123, 255, .25);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace;--font-xs: .75rem;--font-sm: .875rem;--font-md: .9rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--breakpoint-sm: 576px;--breakpoint-md: 768px;--breakpoint-lg: 992px;--breakpoint-xl: 1200px;--max-width-container: 1200px;--header-height: 60px;--sidebar-width: 250px;--input-height-sm: 32px;--input-height-md: 38px;--input-height-lg: 44px;--input-padding-x: .75rem;--input-padding-y: .5rem}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.form-field.full-width{grid-column:1 / -1}.form-field label{font-size:var(--font-sm);font-weight:var(--font-weight-medium);color:var(--color-text);display:block}.form-field label .required{color:var(--color-danger);margin-left:var(--spacing-xs)}.form-field .error-message{font-size:var(--font-xs);color:var(--color-danger);margin-top:var(--spacing-xs);display:block}.form-field .help-text{font-size:var(--font-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs);display:block}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--spacing-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--input-padding-y) var(--input-padding-x);font-family:var(--font-family-base);font-size:var(--font-md);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-focus)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted);opacity:.7}.form-input-error,.form-select-error,.form-textarea-error{border-color:var(--color-border-error)}.form-input-error:focus,.form-select-error:focus,.form-textarea-error:focus{border-color:var(--color-border-error);box-shadow:0 0 0 3px var(--color-danger-light)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled,.form-input-disabled,.form-select-disabled,.form-textarea-disabled{background-color:var(--color-bg-light);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--input-padding-x) center;background-size:16px;padding-right:calc(var(--input-padding-x) * 2 + 16px);cursor:pointer}.form-select:disabled{cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px}.checkbox-wrapper{display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-wrapper.checkbox-disabled{opacity:.6;cursor:not-allowed}.checkbox-input{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.checkbox-input:disabled{cursor:not-allowed}.checkbox-label-text{font-size:var(--font-md);color:var(--color-text);line-height:var(--line-height-normal)}.checkbox-label{display:flex;align-items:center;gap:0;cursor:pointer;font-size:var(--font-md);margin:0 0 var(--spacing-sm) 0;line-height:var(--line-height-normal);-webkit-user-select:none;user-select:none}.checkbox-label.checkbox-inline{display:inline-flex;margin-right:var(--spacing-md);margin-bottom:var(--spacing-xs)}.checkbox-label.checkbox-disabled{opacity:.6;cursor:not-allowed}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;margin:0 5px 0 0;padding:0;flex-shrink:0;accent-color:var(--color-primary)}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed}.radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.radio-group.radio-inline{flex-direction:row;flex-wrap:wrap;gap:var(--spacing-md)}.radio-wrapper{display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.radio-wrapper.radio-disabled{opacity:.6;cursor:not-allowed}.radio-input{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.radio-input:disabled{cursor:not-allowed}.radio-label-text{font-size:var(--font-md);color:var(--color-text);line-height:var(--line-height-normal)}.audit-editor .form-grid,.editor-section .form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.checkbox-list,.radio-list{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:300px;overflow-y:auto}.checkbox-list .checkbox-label,.radio-list .radio-label{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs);cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-base)}.checkbox-list .checkbox-label:hover,.radio-list .radio-label:hover{background-color:var(--color-bg-light)}.checkbox-list .checkbox-label input[type=checkbox],.radio-list .radio-label input[type=radio]{flex-shrink:0}.input-group{display:flex;align-items:stretch}.input-group .form-input{border-radius:0}.input-group .form-input:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.input-group .form-input:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.input-group-addon{display:flex;align-items:center;padding:var(--input-padding-y) var(--input-padding-x);font-size:var(--font-md);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text);text-align:center;white-space:nowrap;background-color:var(--color-bg-light);border:1px solid var(--color-border)}.input-group-addon:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md);border-right:0}.input-group-addon:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);border-left:0}.form-field.has-error .form-input,.form-field.has-error .form-select,.form-field.has-error .form-textarea{border-color:var(--color-border-error)}.form-field.has-success .form-input,.form-field.has-success .form-select,.form-field.has-success .form-textarea{border-color:var(--color-success)}@media(max-width:768px){.audit-editor .form-grid,.editor-section .form-grid{grid-template-columns:1fr}}.draggable-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.draggable-list-item{display:flex;gap:.5rem;align-items:center;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;padding:.5rem;cursor:move;transition:all .2s}.draggable-list-item:hover{background-color:#f0f0f0;border-color:#ccc}.draggable-list-item[draggable=true]{-webkit-user-select:none;user-select:none}.drag-handle{color:#999;font-size:1.2rem;cursor:grab;padding:0 .25rem;-webkit-user-select:none;user-select:none;line-height:1}.drag-handle:active{cursor:grabbing}.drop-indicator{position:absolute;top:-2px;left:0;right:0;height:3px;background-color:var(--color-primary);z-index:10;pointer-events:none;animation:pulse .5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 8px #007bff99}50%{opacity:.8;box-shadow:0 0 12px #007bffe6}}.draggable-list-input{flex:1;padding:.5rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;height:38px;box-sizing:border-box;line-height:1.5}.draggable-list-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #007bff1a}.add-item-row{display:flex;gap:.5rem;margin-top:.5rem}.add-item-input{flex:1;padding:.5rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;height:38px;box-sizing:border-box;line-height:1.5;transition:border-color .2s}.add-item-input:focus{outline:none;border-color:var(--color-success);box-shadow:0 0 0 3px #28a7451a}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit;font-weight:500;text-align:center;white-space:nowrap;border:none;border-radius:6px;cursor:pointer;transition:all .2s;text-decoration:none;line-height:1.5}.btn:focus{outline:none;box-shadow:0 0 0 3px #007bff40}.btn-sm{padding:.25rem .75rem;font-size:.875rem}.btn-md{padding:.5rem 1rem;font-size:.9rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3;box-shadow:0 2px 4px #007bff4d}.btn-primary:active:not(:disabled){background-color:#004085}.btn-secondary{background-color:#f8f9fa;color:#333;border:1px solid #e0e0e0}.btn-secondary:hover:not(:disabled){background-color:#e9ecef;border-color:#d0d0d0}.btn-secondary:active:not(:disabled){background-color:#dee2e6}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover:not(:disabled){background-color:#218838;box-shadow:0 2px 4px #28a7454d}.btn-success:active:not(:disabled){background-color:#1e7e34}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333;box-shadow:0 2px 4px #dc35454d}.btn-danger:active:not(:disabled){background-color:#bd2130}.btn-warning{background-color:#ffc107;color:#333}.btn-warning:hover:not(:disabled){background-color:#e0a800;box-shadow:0 2px 4px #ffc1074d}.btn-warning:active:not(:disabled){background-color:#d39e00}.btn-ghost{background-color:transparent;color:#007bff;border:1px solid #007bff}.btn-ghost:hover:not(:disabled){background-color:#007bff;color:#fff}.btn-ghost:active:not(:disabled){background-color:#0056b3}.btn:disabled,.btn-disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-loading{position:relative;pointer-events:none;opacity:.7}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btn-spin .6s linear infinite}.btn-secondary .btn-spinner,.btn-warning .btn-spinner{border-color:#0003;border-top-color:#333}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-icon{display:inline-flex;align-items:center;line-height:1}.btn-icon-left{margin-right:-.25rem}.btn-icon-right{margin-left:-.25rem}.btn-block{width:100%}.btn-group{display:inline-flex;gap:.5rem}.btn-group-vertical{display:flex;flex-direction:column;gap:.5rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xl)}.empty-state-sm{padding:var(--spacing-md)}.empty-state-md{padding:var(--spacing-xl)}.empty-state-lg{padding:var(--spacing-2xl)}.empty-state-icon{font-size:4rem;line-height:1;margin-bottom:var(--spacing-md);opacity:.7}.empty-state-sm .empty-state-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.empty-state-lg .empty-state-icon{font-size:5rem;margin-bottom:var(--spacing-lg)}.empty-state-title{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0 0 var(--spacing-sm) 0;line-height:var(--line-height-tight)}.empty-state-sm .empty-state-title{font-size:var(--font-lg);margin-bottom:var(--spacing-xs)}.empty-state-lg .empty-state-title{font-size:var(--font-2xl);margin-bottom:var(--spacing-md)}.empty-state-message{font-size:var(--font-md);color:var(--color-text-light);margin:0 0 var(--spacing-lg) 0;line-height:var(--line-height-relaxed);max-width:500px}.empty-state-sm .empty-state-message{font-size:var(--font-sm);margin-bottom:var(--spacing-md);max-width:300px}.empty-state-lg .empty-state-message{font-size:var(--font-lg);margin-bottom:var(--spacing-xl);max-width:600px}.empty-state-action{margin-top:var(--spacing-sm)}.empty-state.empty-state-light{background-color:var(--color-bg-light);border-radius:var(--radius-lg);border:1px dashed var(--color-border)}@media(max-width:768px){.empty-state{padding:var(--spacing-lg)}.empty-state-lg{padding:var(--spacing-xl)}.empty-state-icon{font-size:3rem}.empty-state-lg .empty-state-icon{font-size:4rem}.empty-state-title{font-size:var(--font-lg)}.empty-state-lg .empty-state-title{font-size:var(--font-xl)}.empty-state-message{font-size:var(--font-sm);max-width:100%}}.content-container,.tab-content-container{flex:1;overflow-y:auto;padding:2rem;background-color:#f5f5f5}.content-section{background-color:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.content-section h3{font-size:1.2rem;font-weight:600;color:#2c3e50;margin-bottom:1rem}.accordion-content .content-section{background-color:transparent;box-shadow:none;padding:0 0 1.5rem;border-bottom:1px solid #e0e0e0}.accordion-content .content-section:last-child{border-bottom:none;padding-bottom:0}@media(max-width:1024px){.content-container,.tab-content-container{padding:1rem}}.gtm-layout{display:flex;flex-direction:column;height:100vh;background-color:#f5f5f5}.gtm-main{display:flex;flex:1;overflow:hidden}.domain-selector{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.selector-group{position:relative;display:flex;flex-direction:column;gap:.5rem}.selector-group label{font-weight:500;color:#333;font-size:.9rem}.domain-dropdown,.version-dropdown{width:100%;padding:.5rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;height:38px;box-sizing:border-box;line-height:1.5;background-color:#fff}.gtm-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.no-config-selected{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-size:1.1rem}.settings-tab{width:100%}.settings-tab h2{font-size:1.8rem;color:#333;margin-bottom:1.5rem}.section-description{color:#666;font-size:.9rem;margin-bottom:1rem}.datalayer-vars-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.datalayer-var-item{display:flex;gap:.5rem;align-items:center}.var-key-label{flex:0 0 250px;font-weight:500;color:#333;padding:.5rem;background-color:#f5f5f5;border-radius:4px;font-size:.9rem}.var-key{flex:1;background-color:#f5f5f5}.var-value{flex:2}.contacts-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.contact-item{display:flex;gap:.5rem;align-items:flex-start;padding:.75rem;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px}.contact-fields{display:grid;grid-template-columns:2fr 2fr 2fr 1fr 1fr;gap:.5rem;flex:1}.contact-field,.contact-field-small{padding:.5rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;height:38px;box-sizing:border-box;line-height:1.5}.contact-field:focus,.contact-field-small:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.contact-fields-vertical{display:flex;flex-direction:column;gap:.5rem;flex:1}.contact-field-row{display:flex;gap:.5rem;align-items:center}.contact-field-label{min-width:120px;width:120px;flex-shrink:0;font-weight:500;color:#333;font-size:.9rem}.cmp-specific-section{margin-top:1.5rem;padding:1.5rem;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px}.cmp-specific-section h4{font-size:1.1rem;color:#333;margin:0 0 1rem;border-bottom:2px solid #dee2e6;padding-bottom:.5rem}.info-box{background-color:#e7f3ff;border-left:4px solid #007bff;padding:1rem;border-radius:4px;color:#004085;font-size:.9rem}.variables-tab{width:100%}.variables-tab h2{font-size:1.8rem;color:#333;margin-bottom:.5rem}.tab-description{color:#666;font-size:.95rem;margin-bottom:1.5rem}.variable-section{background-color:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.variable-section h3{font-size:1.2rem;color:#333;margin-bottom:1rem;border-bottom:2px solid #f0f0f0;padding-bottom:.5rem}.variable-repeater{margin-top:1rem}.variables-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.variable-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;transition:all .2s}.variable-item:hover{background-color:#f0f0f0;border-color:#ccc}.variable-info{flex:1;display:flex;align-items:center;gap:.5rem}.variable-detail{color:#666;font-size:.9rem}.variable-actions{display:flex;gap:.5rem}.edit-form{background-color:#f9f9f9;border:2px solid #007bff;border-radius:8px;padding:1.5rem;margin-top:1rem}.edit-form h4{margin-top:0;margin-bottom:1rem;color:#333}.edit-form.inline-edit{margin-top:.5rem;margin-bottom:.5rem;background-color:#fff;border-left:4px solid #007bff;box-shadow:0 2px 4px #0000001a}.required{color:#dc3545;margin-left:.2rem}.field-hint{color:#666;font-size:.85rem;font-weight:400;font-style:italic}.tools-config-note{background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:1rem;margin-top:.5rem}.tools-config-note p{margin:.5rem 0;font-size:.9rem;color:#856404}.tools-config-note p:first-child{margin-top:0}.tools-config-note p:last-child{margin-bottom:0}.event-tools-editor{border:1px solid #e0e0e0;border-radius:4px;overflow:hidden}.tool-accordion-item{border-bottom:1px solid #e0e0e0}.tool-accordion-item:last-child{border-bottom:none}.tool-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#f8f9fa;cursor:pointer;transition:background-color .2s;min-height:60px}.tool-accordion-header:hover{background-color:#e9ecef}.tool-accordion-item.expanded .tool-accordion-header{background-color:#e7f3ff;border-bottom:1px solid #007bff}.tool-accordion-header .tool-title{display:flex;align-items:center;gap:.8rem;margin:0}.tool-accordion-header .tool-icon{font-size:1.5rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;margin:0}.tool-accordion-header .tool-name{font-weight:600;font-size:1.1rem;line-height:1.3;display:flex;align-items:center;margin:0}.config-badge{background-color:#28a745;color:#fff;padding:.25rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500;line-height:1.2;display:inline-flex;align-items:center;flex-shrink:0;margin:0}.tool-accordion-content{padding:1rem;background-color:#fff}.tool-config-section{display:flex;flex-direction:column;gap:1rem}.ads-account-config{border:1px solid #e0e0e0;border-radius:4px;margin-bottom:.75rem;overflow:hidden}.ads-account-header{padding:.75rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.ads-account-fields{padding:1rem;background-color:#fff}.form-row{display:grid;grid-template-columns:2fr 1fr .8fr;gap:1rem;margin-bottom:1rem}.event-parameters-editor{display:flex;flex-direction:column;gap:.5rem}.parameter-row{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;align-items:center}.parameter-input{padding:.5rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;height:38px;box-sizing:border-box;line-height:1.5}.parameter-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.tools-tab{width:100%}.tools-tab h2{font-size:1.8rem;color:#333;margin-bottom:.5rem}.tools-accordion{display:flex;flex-direction:column;gap:.5rem}.tool-accordion-item{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .2s}.tool-accordion-item.expanded{box-shadow:0 2px 6px #00000026}.tool-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:all .2s;min-height:60px}.tool-header:hover{background-color:#f9f9f9}.tool-header .tool-title{display:flex;align-items:center;gap:.8rem;margin:0}.tool-header .tool-icon{font-size:1.5rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;margin:0}.tool-header .tool-name{font-weight:600;font-size:1.1rem;color:#333;line-height:1.3;display:flex;align-items:center;margin:0}.tool-count{color:#666;font-size:.9rem;line-height:1.3;display:flex;align-items:center;margin:0}.expand-icon{color:#666;font-size:.9rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin:0}.tool-content{padding:0 1.5rem 1.5rem;border-top:1px solid #f0f0f0}.tool-repeater{margin-top:1rem}.tools-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.tool-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;transition:all .2s}.tool-item.disabled{opacity:.6;background-color:#f5f5f5}.tool-item:hover{background-color:#f0f0f0;border-color:#ccc}.tool-info{flex:1;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.tool-detail{color:#666;font-size:.9rem}.status-badge{padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.status-badge.disabled{background-color:#ffc107;color:#000}.tool-actions{display:flex;gap:.5rem}.checkbox-group{margin-top:0}.form-fields{display:flex;flex-direction:column;gap:.5rem}.events-tab{width:100%}.events-tab h2{font-size:1.8rem;color:#333;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.event-header-info{margin-bottom:2rem}.event-header-info .event-icon{font-size:1.8rem}.events-accordion{display:flex;flex-direction:column;gap:.5rem}.event-accordion-item{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .2s}.event-accordion-item.expanded{box-shadow:0 2px 6px #00000026}.event-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:all .2s;min-height:60px}.event-header:hover{background-color:#f9f9f9}.event-title{display:flex;align-items:center;gap:.8rem;flex:1;margin:0}.event-icon{font-size:1.5rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;margin:0}.event-title-text{display:flex;flex-direction:column;justify-content:center;margin:0}.event-name{font-weight:600;font-size:1.1rem;color:#333;line-height:1.3;margin:0}.event-description{font-size:.85rem;color:#666;line-height:1.3;margin:0}.event-count{color:#666;font-size:.9rem;line-height:1.3;margin-left:auto;margin-right:1rem;display:flex;align-items:center}.event-content{padding:0 1.5rem 1.5rem;border-top:1px solid #f0f0f0}.event-repeater{margin-top:1rem}.default-event-section{background-color:#f9f9f9;border:2px solid #e0e0e0;border-radius:6px;padding:1rem;margin-bottom:1rem}.default-event-header{display:flex;justify-content:space-between;align-items:center}.default-event-info{margin-top:.8rem;padding-top:.8rem;border-top:1px solid #ddd;font-size:.9rem;color:#333}.section-divider{border:none;border-top:2px solid #e0e0e0;margin:1.5rem 0}.custom-events-section h4{font-size:1.1rem;color:#333;margin-bottom:1rem}.events-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.event-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;transition:all .2s}.event-item.disabled{opacity:.6;background-color:#f5f5f5}.event-item:hover{background-color:#f0f0f0;border-color:#ccc}.event-info{flex:1;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.event-detail{color:#666;font-size:.9rem}.event-actions{display:flex;gap:.5rem}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;color:#666}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.gtm-selector-bar{flex-direction:column;gap:1rem;align-items:stretch}.domain-selector{flex-direction:column}.action-buttons{width:100%}.save-button,.export-button{flex:1}}.shared-params-section{background-color:#f8f9fa;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #e0e0e0}.shared-params-section label{font-weight:600;color:#495057;margin-bottom:.75rem;display:block}.meta-event-name-wrapper{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.meta-event-name-wrapper input.form-input{flex:1;min-width:200px}.meta-event-name-wrapper select.meta-event-selector{flex:0 0 auto;min-width:180px;max-width:220px}.event-specific-fields{background-color:#f8f9fa;padding:1rem;border-radius:6px;margin:1rem 0;border:1px solid #e0e0e0}.event-specific-fields .form-row{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap;margin-bottom:.75rem}.event-specific-fields .form-row:last-child{margin-bottom:0}.event-specific-fields .form-group{flex:1;min-width:200px}.event-specific-fields .checkbox-group{min-width:auto;flex:0 0 auto}.keyword-tool{display:flex;flex-direction:column;height:100vh;background-color:#f8f9fa}.keyword-tool-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem}.keyword-tool-loading p{color:#666;font-size:.95rem}.keyword-tool-container{display:flex;flex:1;overflow:hidden}.keyword-sidebar{width:300px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}.sidebar-menu{flex:1;padding:.5rem 0}.sidebar-info{padding:1rem;background-color:#f8f9fa;border-top:1px solid #e0e0e0;margin-top:auto}.info-item{display:flex;flex-direction:column;margin-bottom:.5rem}.info-label{font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.info-value{font-size:.9rem;color:#333;font-weight:500}.keyword-tool-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:#fff}.keyword-tool-tab-content{flex:1;overflow:hidden;padding:1.5rem;display:flex;flex-direction:column}.settings-tab{max-width:800px;margin:0 auto;overflow-y:auto;flex:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.options-group{display:flex;flex-direction:column;gap:1rem}.action-buttons{display:flex;gap:1rem;margin-bottom:1rem}.runtime-display{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.runtime-text{font-size:.9rem;color:#666;font-weight:500}.results-tab{max-width:100%;margin:0 auto;padding:1rem;height:100%;display:flex;flex-direction:column}.results-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#666}.results-loading p{margin-top:1rem;font-size:.95rem}.results-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 0}.results-count{font-size:1.1rem;font-weight:500;color:#333}.url-link{color:#667eea;text-decoration:none;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-link:hover{text-decoration:underline;color:#5568d3}.results-hint{padding:1rem;background-color:#e7f3ff;border-radius:6px;color:#06c;font-size:.9rem;text-align:center}@media(max-width:1024px){.keyword-sidebar{width:250px}.form-row{grid-template-columns:1fr}}@media(max-width:768px){.keyword-tool-container{flex-direction:column}.keyword-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid #e0e0e0}.keyword-tool-tab-content{padding:1rem}.results-header{flex-direction:column;gap:1rem;align-items:flex-start}.action-buttons{flex-direction:column}.results-table{font-size:.85rem}.results-table th,.results-table td{padding:.5rem .75rem}}.export-modal-content{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem 0}.export-section{display:flex;flex-direction:column;gap:1rem}.export-section h3{margin:0;font-size:1rem;font-weight:600;color:#333}.format-options{display:flex;gap:1rem}.format-option{flex:1;display:flex;align-items:center;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.format-option:hover{border-color:#667eea;background-color:#f8f9fa}.format-option input[type=radio]{margin-right:.75rem;cursor:pointer}.format-option input[type=radio]:checked+.format-label{color:#667eea;font-weight:600}.format-label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:#555;transition:all .2s}.format-icon{font-size:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center}.column-actions{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.link-button{background:none;border:none;color:#667eea;cursor:pointer;padding:0;font-size:.85rem;text-decoration:none;transition:color .2s}.link-button:hover{color:#5568d3;text-decoration:underline}.separator{color:#ccc}.columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;padding:1rem;background-color:#f8f9fa;border-radius:6px;max-height:400px;overflow-y:auto}.selected-count{text-align:center;font-size:.9rem;color:#666;padding:.5rem;background-color:#e7f3ff;border-radius:4px}.export-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}@media(max-width:768px){.format-options{flex-direction:column}.columns-grid{grid-template-columns:1fr}}.customer-tools-layout{display:flex;flex-direction:column;height:100vh;background-color:#f8f9fa}.customer-tools-container{display:flex;flex:1;overflow:hidden}.customer-tools-sidebar{width:320px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}.sidebar-menu-item{padding:1rem 1.5rem;margin:.25rem .5rem;border-radius:6px;cursor:pointer;transition:all .2s;border:1px solid transparent}.menu-item-customer{font-size:.85rem;color:#667eea;font-weight:500;margin:0 0 .25rem}.customer-tools-content{flex:1;display:flex;flex-direction:column;overflow-y:auto;background-color:#fff}.customer-tool-content{flex:1;padding:2rem;overflow-y:auto}.tool-header-section{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e0e0e0}.tool-title-area{flex:1}.tool-title{font-size:1.75rem;font-weight:600;color:#333;margin:0 0 .5rem}.tool-subtitle{font-size:1rem;color:#6c757d;margin:0 0 .75rem}.tool-customer-badge{display:inline-block;padding:.25rem .75rem;background-color:#e7f3ff;color:#667eea;font-size:.85rem;font-weight:500;border-radius:4px}.tool-actions{display:flex;gap:.75rem;align-items:center}.tool-tab-content{padding:1.5rem 0}.tool-not-found-container{padding:2rem}@media(max-width:1024px){.customer-tools-sidebar{width:280px}}@media(max-width:768px){.customer-tools-sidebar{width:250px}.sidebar-header,.sidebar-search{padding:1rem}.sidebar-menu-item{padding:.75rem 1rem}.customer-tool-content{padding:1rem}.tool-header-section{flex-direction:column;gap:1rem}.tool-title{font-size:1.5rem}}@media(max-width:640px){.customer-tools-container{flex-direction:column}.customer-tools-sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid #e0e0e0}}.sidebar-menu::-webkit-scrollbar,.customer-tools-content::-webkit-scrollbar{width:8px}.sidebar-menu::-webkit-scrollbar-track,.customer-tools-content::-webkit-scrollbar-track{background:#f1f1f1}.sidebar-menu::-webkit-scrollbar-thumb,.customer-tools-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.sidebar-menu::-webkit-scrollbar-thumb:hover,.customer-tools-content::-webkit-scrollbar-thumb:hover{background:#999}.image-tools-layout{display:flex;flex-direction:column;height:100vh;background-color:#f8f9fa}.image-tools-container{display:flex;flex:1;overflow:hidden}.image-tools-sidebar{width:320px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:1.5rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.sidebar-header h2{font-size:1.1rem;font-weight:600;color:#333;margin:0}.sidebar-search{position:relative;padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0}.search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid #d0d0d0;border-radius:6px;font-size:.9rem;transition:all .2s ease;outline:none}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-input::placeholder{color:#999}.search-clear{position:absolute;right:2rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:color .2s ease;line-height:1}.search-clear:hover{color:#333}.sidebar-menu{flex:1;padding:.5rem 0;overflow-y:auto}.no-tools-found{padding:2rem 1rem;text-align:center;color:#6c757d}.no-tools-found p{margin:0 0 .5rem;font-size:.95rem}.no-tools-found .hint{font-size:.85rem;color:#999}.sidebar-menu-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;margin:.25rem .5rem;border-radius:6px;cursor:pointer;transition:all .2s;border:1px solid transparent}.sidebar-menu-item:hover{background-color:#f8f9fa;border-color:#e0e0e0}.sidebar-menu-item.active{background-color:#e7f3ff;border-color:#667eea;border-left-width:3px}.menu-item-icon{font-size:1.5rem;flex-shrink:0}.menu-item-content{flex:1;min-width:0}.menu-item-content h3{font-size:.95rem;font-weight:500;color:#333;margin:0 0 .25rem}.menu-item-description{font-size:.8rem;color:#6c757d;margin:0;line-height:1.4}.image-tools-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:#f5f5f5}.tool-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem;color:#666}.tool-loading p{font-size:.95rem;margin:0}@media(max-width:1024px){.image-tools-sidebar{width:280px}}@media(max-width:768px){.image-tools-sidebar{width:250px}.sidebar-header,.sidebar-search{padding:1rem}.sidebar-menu-item{padding:.75rem 1rem}}@media(max-width:640px){.image-tools-container{flex-direction:column}.image-tools-sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid #e0e0e0}}.sidebar-menu::-webkit-scrollbar,.image-tools-content::-webkit-scrollbar{width:8px}.sidebar-menu::-webkit-scrollbar-track,.image-tools-content::-webkit-scrollbar-track{background:#f1f1f1}.sidebar-menu::-webkit-scrollbar-thumb,.image-tools-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.sidebar-menu::-webkit-scrollbar-thumb:hover,.image-tools-content::-webkit-scrollbar-thumb:hover{background:#999}.app{width:100%;height:100vh;overflow:hidden}*{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;color:#333;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;height:100vh}
