:root,[data-theme=dark]{--font-family: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--color-bg: #0a0f0c;--color-bg-elevated: #0f1a14;--color-surface: #141f18;--color-surface-hover: #1a2820;--color-primary: #52b788;--color-primary-hover: #6ec99a;--color-primary-muted: #3d8b68;--color-accent: #e9c46a;--color-accent-hover: #f4d58d;--color-text: #e8f0ea;--color-text-muted: #9cb3a0;--color-text-dim: #6a8a70;--color-border: #2d4a38;--color-border-focus: #52b788;--color-success: #52b788;--color-warning: #e9c46a;--color-error: #e76f51;--color-primary-alpha-15: rgba(82, 183, 136, .15);--color-primary-alpha-25: rgba(82, 183, 136, .25);--color-primary-alpha-35: rgba(82, 183, 136, .35);--color-zone-b: #f4a261;--color-zone-b-hover: #f4b982;--color-zone-b-alpha-15: rgba(244, 162, 97, .15);--color-zone-b-alpha-25: rgba(244, 162, 97, .25);--color-zone-b-alpha-35: rgba(244, 162, 97, .35);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(82, 183, 136, .15);--shadow-glow-accent: 0 0 20px rgba(233, 196, 106, .15);--shadow-brutal: 4px 4px 0px var(--color-border);--shadow-brutal-hover: 6px 6px 0px var(--color-primary);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-modal: 200;--z-tooltip: 300;--z-notification: 400;--container-max: 1400px;--header-height: 70px}[data-theme=light]{--color-bg: #dce0db;--color-bg-elevated: #e8ebe7;--color-surface: #eaede9;--color-surface-hover: #f2f4f1;--color-primary: #2d6a4f;--color-primary-hover: #40916c;--color-primary-muted: #95d5b2;--color-accent: #d4a348;--color-accent-hover: #e9c46a;--color-text: #1b2e1f;--color-text-muted: #5c745f;--color-text-dim: #8a9f8d;--color-border: #c9d6ca;--color-border-focus: #2d6a4f;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .15);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .2);--shadow-glow: 0 0 20px rgba(45, 106, 79, .1);--shadow-brutal: 4px 4px 0px #1b2e1f;--shadow-brutal-hover: 6px 6px 0px var(--color-primary)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth;background-color:#0a0f0c}body{font-family:var(--font-family),-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--color-bg, #0a0f0c);color:var(--color-text, #e8f0ea);line-height:1.6;min-height:100vh;overflow-x:hidden;transition:background-color var(--transition-slow),color var(--transition-slow)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full);border:2px solid var(--color-bg)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-muted)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--color-text)}h1{font-size:2.5rem}h2{font-size:1.75rem}h3{font-size:1.25rem}h4{font-size:1rem}p{margin-bottom:var(--space-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::selection{background:var(--color-primary);color:var(--color-bg)}.text-muted{color:var(--color-text-muted)}.text-primary{color:var(--color-primary)}.text-accent{color:var(--color-accent)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-lg)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}@media(max-width:768px){.grid-2{grid-template-columns:1fr}}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.notification-container{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:600;display:flex;flex-direction:column;gap:var(--space-sm)}.notification{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:.875rem;animation:slideIn .2s ease}.notification.success{border-color:var(--color-success)}.notification.error{border-color:var(--color-error)}.notification.warning{border-color:var(--color-warning)}.notification svg{width:18px;height:18px}.notification.success svg{color:var(--color-success)}.notification.error svg{color:var(--color-error)}.notification.warning svg{color:var(--color-warning)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.header{height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:var(--space-sm)}.header-brand .logo{color:var(--color-primary)}.header-title{font-size:1.25rem;font-weight:700;color:var(--color-text)}.header-center{flex:1;display:flex;justify-content:center;padding:0 var(--space-xl)}.header-actions{display:flex;align-items:center;gap:var(--space-xs)}.header-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.75rem;font-weight:600;font-family:var(--font-family)}.header-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.header-btn svg{width:18px;height:18px}.lang-dropdown{position:relative}.lang-trigger{width:auto;padding:0 var(--space-sm);gap:var(--space-xs)}.lang-trigger .lang-chevron{width:10px;height:10px;transition:transform var(--transition-fast)}.lang-trigger[aria-expanded=true] .lang-chevron{transform:rotate(180deg)}.lang-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:dropdownFadeIn .15s ease}.lang-menu.hidden{display:none}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.lang-option{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:transparent;border:none;color:var(--color-text);font-size:.8125rem;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.lang-option:hover{background:var(--color-surface-hover)}.lang-option.active{background:var(--color-primary-alpha-15);color:var(--color-primary)}.lang-code{font-weight:700;min-width:24px}.lang-name{color:var(--color-text-muted);font-size:.75rem}.lang-option.active .lang-name{color:var(--color-primary)}.tablet-selector-compact{position:relative;min-width:280px;max-width:400px}.tablet-selector-compact .select-trigger{height:40px;padding:0 var(--space-md);font-size:.875rem;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-surface) 100%);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);width:100%;box-shadow:0 2px 4px #0000001a}.tablet-selector-compact .select-trigger:hover{border-color:var(--color-primary-muted);box-shadow:0 4px 12px #00000026}.tablet-selector-compact .select-trigger.open{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-15)}.tablet-selector-compact .select-text{color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.tablet-selector-compact .select-trigger svg{width:16px;height:16px;color:var(--color-text-muted);flex-shrink:0;transition:transform var(--transition-fast)}.tablet-selector-compact .select-trigger.open svg{transform:rotate(180deg)}.tablet-selector-compact .dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);min-width:480px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 20px 40px #0003;z-index:200;animation:dropdownFadeIn .2s ease}.main{flex:1;display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-lg);max-width:1400px;margin:0 auto;width:100%}.top-row{display:grid;grid-template-columns:400px 1fr;gap:var(--space-lg);min-height:520px}.config-panel{display:flex;flex-direction:column;gap:var(--space-sm);height:100%}.config-panel .config-card-main{flex:1}.comparison-toggle-wrapper{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0}.comparison-toggle{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.75rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.comparison-toggle:hover{border-color:var(--color-primary-muted);color:var(--color-primary)}.comparison-toggle.active{background:var(--color-primary-alpha-15);border-color:var(--color-primary);color:var(--color-primary)}.comparison-toggle svg{width:14px;height:14px}.zone-selector{display:flex;gap:2px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:2px}.zone-selector.hidden{display:none}.zone-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.6875rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.zone-btn:hover{background:var(--color-surface-hover)}.zone-btn.active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 3px #0003}.zone-indicator{width:8px;height:8px;border-radius:50%}.zone-indicator.zone-a{background:var(--color-primary)}.zone-indicator.zone-b{background:var(--color-zone-b, #f4a261)}.visualizer-panel{display:flex;flex-direction:column}.visualizer-frame{position:relative;flex:1;min-height:480px;background:var(--color-bg-elevated);border:2px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.visualizer{width:100%;height:100%}.visualizer-grid{position:absolute;inset:0;background-size:20px 20px;background-image:linear-gradient(to right,var(--color-border) 1px,transparent 1px),linear-gradient(to bottom,var(--color-border) 1px,transparent 1px);opacity:.4;pointer-events:none}.visualizer-grid.hidden{opacity:0}.tablet-boundary{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid var(--color-text-dim);border-radius:var(--radius-sm);background:#ffffff05}.area-rectangle{position:absolute;background:var(--color-primary-alpha-25);border:2px solid var(--color-primary);cursor:move;box-shadow:0 0 20px var(--color-primary-alpha-15);transition:border-radius var(--transition-fast);transform-origin:center center}.area-rectangle:hover{background:var(--color-primary-alpha-35);box-shadow:0 0 30px var(--color-primary-alpha-25)}.area-rectangle.dragging{cursor:grabbing}.area-rectangle-b{position:absolute;background:var(--color-zone-b-alpha-25);border:2px solid var(--color-zone-b);box-shadow:0 0 20px var(--color-zone-b-alpha-15);transition:border-radius var(--transition-fast);transform-origin:center center;pointer-events:none}.area-rectangle-b.active{cursor:move;pointer-events:auto}.area-rectangle-b.active:hover{background:var(--color-zone-b-alpha-35);box-shadow:0 0 30px var(--color-zone-b-alpha-25)}.area-rectangle-b.dragging{cursor:grabbing}.area-rectangle.inactive{pointer-events:none;opacity:.6}.visualizer-info{position:absolute;bottom:var(--space-md);left:var(--space-md);display:flex;gap:var(--space-sm);pointer-events:none}.info-dimensions,.info-ratio{padding:6px 12px;background:#000000bf;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;backdrop-filter:blur(4px)}.info-dimensions{color:var(--color-text)}.info-ratio{color:var(--color-primary)}.config-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding:var(--space-md) var(--space-lg) var(--space-lg);align-items:center}.config-actions-grid{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);align-items:center}.config-actions-grid .btn-primary{flex:1;min-width:0;height:42px;overflow:hidden;text-overflow:ellipsis}.config-actions-grid .quick-tools{display:flex;gap:var(--space-xs);flex-shrink:0}.config-actions-compact{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--color-border);background:var(--color-bg-elevated)}.config-actions-compact .btn-sm{flex:1;height:36px;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);font-size:.6875rem}.config-actions-compact .btn-sm svg{width:14px;height:14px}.btn-secondary{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-weight:600;font-family:var(--font-family);text-transform:uppercase;letter-spacing:.03em;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-alpha-15)}.header-tools{display:flex;gap:2px}.header-tools .tool-btn{width:32px;height:32px}.header-tools .tool-btn svg{width:14px;height:14px}.config-actions .btn-primary{flex:1;margin:0;width:auto;height:42px}.quick-tools{display:flex;gap:var(--space-xs)}.tool-btn{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.tool-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-alpha-15)}.tool-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.tool-btn svg{width:18px;height:18px}.visualizer-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated)}.visualizer-loading.hidden{display:none}.config-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.config-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated)}.config-header h2{font-size:.8125rem;font-weight:600;color:var(--color-text);text-transform:uppercase;letter-spacing:.05em}.config-body{padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);flex:1}.field-row{display:flex;align-items:center;gap:var(--space-sm)}.field{flex:1;min-width:0;display:flex;align-items:center;gap:var(--space-xs);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-sm);height:42px;transition:border-color var(--transition-fast)}.field:focus-within{border-color:var(--color-primary)}.field-label{font-size:.6875rem;font-weight:700;color:var(--color-text-dim);text-transform:uppercase;min-width:14px}.field input{flex:1;min-width:0;background:transparent;border:none;color:var(--color-text);font-size:.9375rem;font-family:var(--font-family);font-weight:500;outline:none;-moz-appearance:textfield}.field input::-webkit-outer-spin-button,.field input::-webkit-inner-spin-button{-webkit-appearance:none}.field-unit{font-size:.6875rem;color:var(--color-text-dim)}.btn-lock{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-lock:hover{border-color:var(--color-primary-muted)}.btn-lock.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.btn-lock svg{width:16px;height:16px}.field-slider{display:flex;align-items:center;gap:var(--space-sm);padding-top:var(--space-xs)}.field-slider .field-label{min-width:55px;font-size:.75rem}.field-slider input[type=range]{flex:1;height:4px;-webkit-appearance:none;background:var(--color-border);border-radius:2px;outline:none}.field-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:2px solid var(--color-bg)}.field-slider .field-value{min-width:36px;text-align:right;font-size:.8125rem;font-weight:600;color:var(--color-primary)}.field-slider .field-value-input{width:42px;padding:2px 4px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-primary);font-size:.8125rem;font-weight:600;font-family:var(--font-family);text-align:center;-moz-appearance:textfield}.field-slider .field-value-input::-webkit-outer-spin-button,.field-slider .field-value-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.field-slider .field-value-input:focus{outline:none;border-color:var(--color-primary)}.field-slider .field-unit{font-size:.75rem;color:var(--color-text-muted);margin-left:2px}.btn-primary{height:42px;padding:0 var(--space-lg);background:var(--color-primary);border:none;border-radius:var(--radius-md);color:var(--color-bg);font-size:.75rem;font-weight:700;font-family:var(--font-family);text-transform:uppercase;letter-spacing:.03em;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 4px 12px var(--color-primary-alpha-25)}.favorites-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.favorites{display:flex;flex-direction:column;height:100%}.favorites-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-elevated);flex-shrink:0}.favorites-title{font-size:.8125rem;font-weight:600;color:var(--color-text);text-transform:uppercase;letter-spacing:.05em}.favorites-controls{display:flex;align-items:center;gap:var(--space-xs)}.favorites-sort-wrapper{display:flex;align-items:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.favorites-sort{appearance:none;background:var(--color-bg);border:none;padding:6px 10px;font-size:.6875rem;font-weight:600;font-family:var(--font-family);color:var(--color-text);cursor:pointer}.favorites-sort option{background:var(--color-surface);color:var(--color-text)}.sort-direction{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-left:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast)}.sort-direction:hover{color:var(--color-primary)}.sort-direction svg{width:12px;height:12px}.favorites-list{padding:var(--space-md);display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-sm);overflow-y:auto;max-height:300px}.favorite-card{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.favorite-card:hover{border-color:var(--color-primary-muted);background:var(--color-bg-elevated)}.favorite-preview-wrapper{width:52px;height:34px;flex-shrink:0;border-radius:var(--radius-xs);overflow:hidden;background:var(--color-surface)}.favorite-preview{width:100%;height:100%}.preview-tablet{fill:var(--color-surface-hover);stroke:var(--color-border);stroke-width:1}.preview-area{fill:var(--color-primary-alpha-25);stroke:var(--color-primary);stroke-width:1}.favorite-info{flex:1;min-width:0}.favorite-name{font-size:.8125rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.favorite-comment{font-size:.6875rem;color:var(--color-text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;max-width:100%}.favorite-details{font-size:.6875rem;color:var(--color-text-muted);display:flex;flex-wrap:wrap;gap:var(--space-xs)}.favorite-tablet{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.favorite-area{color:var(--color-primary);font-weight:600}.favorite-actions{display:flex;gap:2px;flex-shrink:0}.favorite-actions button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.favorite-actions button:hover{background:var(--color-primary-alpha-15);color:var(--color-primary)}.favorite-actions button.delete:hover{background:#e76f5126;color:var(--color-error)}.favorite-actions button svg{width:14px;height:14px}.favorites-empty{padding:var(--space-xl);text-align:center;color:var(--color-text-muted);flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.favorites-empty svg{width:36px;height:36px;margin-bottom:var(--space-sm);opacity:.4}.favorites-empty p{font-size:.75rem;max-width:200px}.context-menu{position:fixed;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:300;padding:var(--space-sm);min-width:160px}.context-menu.hidden{display:none}.context-menu-title{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-xs)}.context-menu-title svg{width:12px;height:12px}.context-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.context-menu-grid button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.context-menu-grid button:hover{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.context-menu-grid button svg{width:16px;height:16px}.modal-container{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center}.modal-container.hidden{display:none}.modal-overlay{position:absolute;inset:0;background:#0009;backdrop-filter:blur(4px)}.modal{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-width:340px;max-width:90vw;max-height:90vh;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-title{font-size:1rem;font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer}.modal-close:hover{background:var(--color-surface-hover);color:var(--color-text)}.modal-close svg{width:18px;height:18px}.modal-body{padding:var(--space-lg)}.modal-message{font-size:.9375rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.modal-input,.input{width:100%;height:42px;padding:0 var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.9375rem;font-family:var(--font-family)}.modal-input:focus,.input:focus{outline:none;border-color:var(--color-primary)}.textarea{height:auto;min-height:80px;padding:var(--space-sm) var(--space-md);resize:vertical;font-family:var(--font-family);line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);background:var(--color-bg-elevated)}.btn{height:40px;padding:0 var(--space-lg);border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.btn-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{background:var(--color-error);border:none;color:#fff}.btn-danger:hover{opacity:.9}.modal-confirm{background:var(--color-primary);border:none;color:var(--color-bg)}.modal-confirm:hover{background:var(--color-primary-hover)}.pro-players-modal{min-width:400px;max-width:500px}.pro-players-modal .modal-title{display:flex;align-items:center;gap:var(--space-sm)}.pro-players-modal .modal-title svg{width:20px;height:20px;color:var(--color-primary)}.pro-players-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto}.pro-player-card{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.pro-player-card:hover{border-color:var(--color-primary-muted);background:var(--color-bg-elevated)}.pro-player-preview-wrapper{width:52px;height:34px;flex-shrink:0;border-radius:var(--radius-xs);overflow:hidden;background:var(--color-surface)}.pro-player-preview{width:100%;height:100%}.pro-player-info{flex:1;min-width:0}.pro-player-name{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:2px}.pro-player-details{font-size:.6875rem;color:var(--color-text-muted);display:flex;flex-wrap:wrap;gap:var(--space-xs)}.pro-player-tablet{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pro-player-area{color:var(--color-primary);font-weight:600}.pro-player-load{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.pro-player-load:hover{background:var(--color-primary-alpha-15);color:var(--color-primary)}.pro-player-load svg{width:16px;height:16px}.pro-players-empty{padding:var(--space-xl);text-align:center;color:var(--color-text-muted)}.pro-players-empty svg{width:36px;height:36px;margin-bottom:var(--space-sm);opacity:.4}.pro-players-empty p{font-size:.75rem}.recap-modal-content .recap{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--space-md)}.recap-item{display:flex;justify-content:space-between;padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border)}.recap-item:last-child{border-bottom:none}.recap-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.recap-value{font-size:.875rem;font-weight:600;color:var(--color-text)}.modal-form{display:flex;flex-direction:column;gap:var(--space-md)}.modal-form-section{padding-top:var(--space-md);border-top:1px solid var(--color-border)}.modal-form-section:first-child{padding-top:0;border-top:none}.modal-form-section h4{font-size:.6875rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-group label{font-size:.6875rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted)}.input-row{display:flex;gap:var(--space-sm)}.input-row .input-group{flex:1}.slider{width:100%;height:4px;-webkit-appearance:none;background:var(--color-border);border-radius:2px}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:2px solid var(--color-bg)}.slider-with-value{display:flex;align-items:center;gap:var(--space-sm)}.slider-with-value .slider{flex:1}.slider-with-value .slider-value{min-width:40px;text-align:right;font-size:.875rem;font-weight:600;color:var(--color-primary)}.dropdown{max-height:420px;overflow:hidden;display:flex;flex-direction:column}.dropdown.hidden{display:none}.dropdown-search{padding:var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated)}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input-wrapper svg{position:absolute;left:var(--space-md);width:16px;height:16px;color:var(--color-text-muted)}.search-input{width:100%;height:40px;padding:0 var(--space-md) 0 calc(var(--space-md) + 24px);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.875rem;font-family:var(--font-family);transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-15)}.dropdown-body{display:flex;flex:1;overflow:hidden}.brands-list{width:140px;border-right:1px solid var(--color-border);overflow-y:auto;background:var(--color-bg-elevated);padding:var(--space-xs)}.tablet-brand-item{width:100%;padding:var(--space-sm) var(--space-md);text-align:left;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text);font-size:.8125rem;font-weight:500;font-family:var(--font-family);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all var(--transition-fast);margin-bottom:2px}.tablet-brand-item:hover{background:var(--color-surface-hover)}.tablet-brand-item.active{background:var(--color-primary);color:var(--color-bg);box-shadow:0 2px 8px var(--color-primary-alpha-25)}.brand-count{font-size:.625rem;font-weight:600;padding:2px 6px;background:var(--color-bg);border-radius:var(--radius-sm);opacity:.8}.tablet-brand-item.active .brand-count{background:#fff3;color:var(--color-bg)}.models-list{flex:1;overflow-y:auto;padding:var(--space-sm);display:flex;flex-direction:column;gap:4px}.tablet-model-item{width:100%;padding:var(--space-sm) var(--space-md);text-align:left;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;gap:2px}.tablet-model-item:hover{background:var(--color-surface-hover);border-color:var(--color-primary-muted);transform:translate(4px)}.tablet-model-item.active{background:var(--color-primary-alpha-15);border-color:var(--color-primary)}.model-name{font-size:.875rem;font-weight:600;display:block}.model-brand{font-size:.6875rem;color:var(--color-primary);font-weight:600}.model-size{font-size:.75rem;color:var(--color-text-muted);font-weight:500}.models-empty{padding:var(--space-xl);text-align:center;color:var(--color-text-muted);font-size:.875rem}.dropdown-footer{padding:var(--space-md);border-top:1px solid var(--color-border);background:var(--color-bg-elevated)}.custom-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md);background:transparent;border:2px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.8125rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.custom-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-alpha-15)}.custom-btn svg{width:14px;height:14px}@media(max-width:900px){.top-row{grid-template-columns:1fr}.config-panel{order:2}.visualizer-panel{order:1}.header-center{display:none}.visualizer-frame{min-height:350px}.favorites-list{grid-template-columns:1fr}}@media(max-width:600px){.header{padding:0 var(--space-md)}.main{padding:var(--space-md);gap:var(--space-md)}.top-row{gap:var(--space-md)}.visualizer-frame{min-height:300px}.config-actions{flex-direction:column}.config-actions .btn-primary{width:100%}.quick-tools{justify-content:center;width:100%}}.hidden{display:none!important}.mt-md{margin-top:var(--space-md)}.custom-dimensions-section{padding-top:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.section-divider{height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent)}.section-label{font-size:.6875rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em}.ratio-presets{display:flex;align-items:center;gap:var(--space-sm)}.ratio-presets .field-label{min-width:auto}.preset-buttons{display:flex;gap:var(--space-xs);flex:1}.preset-btn{flex:1;height:32px;padding:0 var(--space-sm);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.6875rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.preset-btn:hover{border-color:var(--color-primary-muted);color:var(--color-primary)}.preset-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}
