.ev2-app{height:100vh;font-family:var(--font);color:var(--text);background:var(--bg);flex-direction:row;display:flex;overflow:hidden}.ev2-viewer{background:var(--bg);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.ev2-topbar-name{font-size:var(--text-lg);color:var(--text);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);transition:border-color var(--duration-fast) var(--ease);background:0 0;border:1px solid #0000;outline:none;flex:1;min-width:0;font-weight:600}.ev2-topbar-name:hover{border-color:var(--border-light)}.ev2-topbar-name:focus{border-color:var(--primary)}.ev2-topbar-btn{border-radius:var(--radius);background:var(--bg-card);width:36px;height:36px;color:var(--text-dim);cursor:pointer;transition:background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease);border:none;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.ev2-topbar-btn:hover{background:var(--bg-input);color:var(--text)}.ev2-btn{justify-content:center;align-items:center;gap:var(--space-1);cursor:pointer;font-family:var(--font);transition:all .15s var(--ease);border:none;display:inline-flex}.ev2-btn-icon{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);width:36px;height:36px;color:var(--text-dim)}.ev2-btn-icon:hover{background:var(--bg-input);color:var(--text);border-color:var(--border-light)}.ev2-btn-sm{width:28px;height:28px}.ev2-btn-primary{padding:var(--space-2) var(--space-4);border-radius:var(--radius);background:var(--gradient-primary);color:#fff;font-size:var(--text-sm);font-weight:600}.ev2-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.ev2-btn-secondary{padding:var(--space-2) var(--space-4);border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);font-size:var(--text-sm)}.ev2-btn-secondary:hover{border-color:var(--border-light);color:var(--text)}.ev2-design-name{align-items:center;gap:var(--space-1);flex:1;min-width:0;display:flex}.ev2-name-text{font-size:var(--text-base);color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.ev2-name-input{height:30px;padding:0 var(--space-2);background:var(--bg-input);border:1px solid var(--primary);border-radius:var(--radius-sm);color:var(--text);font-size:var(--text-base);font-weight:600;font-family:var(--font);outline:none;flex:1}.ev2-topbar-actions{gap:var(--space-1);flex-shrink:0;display:flex}.ev2-icon-rail{background:var(--bg-sidebar);border-inline-start:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;gap:2px;width:62px;min-width:62px;padding:8px 0;display:flex}.ev2-icon-rail-btn{border-radius:var(--radius-sm);width:54px;color:var(--text-muted);cursor:pointer;transition:all .15s var(--ease);font-size:.6rem;font-family:var(--font);text-align:center;background:0 0;border:1px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:8px 4px;line-height:1.2;display:flex;position:relative}.ev2-icon-rail-btn:hover{background:var(--bg-card);color:var(--text-dim);border-color:var(--border)}.ev2-icon-rail-btn.active{background:var(--primary-subtle);color:var(--primary);border-color:var(--primary)}.ev2-icon-rail-btn svg{stroke-width:1.8px;flex-shrink:0;width:20px;height:20px}.ev2-icon-rail-label{white-space:normal;word-break:break-word;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;font-weight:600;display:-webkit-box;overflow:hidden}.ev2-rail-divider{background:var(--border);width:34px;height:1px;margin:4px 0}.ev2-panel-area{background:var(--bg-sidebar);border-inline-start:1px solid var(--border);width:360px;min-width:300px;animation:ev2PanelSlide .2s var(--ease);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}@keyframes ev2PanelSlide{0%{opacity:0}to{opacity:1}}.ev2-panel-area-header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);background:var(--bg-sidebar);font-weight:700;font-size:var(--text-sm);color:var(--primary);flex-shrink:0;display:flex}.ev2-panel-body-scroll{background:var(--bg);flex:1;min-height:0;overflow-y:auto}.ev2-canvas-topbar{top:16px;z-index:50;pointer-events:none;align-items:center;gap:6px;display:flex;position:absolute;inset-inline-end:16px}.ev2-canvas-topbar>*{pointer-events:auto}.ev2-canvas-pill{background:var(--bg-overlay);border:1px solid var(--border);border-radius:var(--radius-sm);height:40px;font-size:var(--text-xs);color:var(--text-dim);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:center;gap:6px;padding:0 12px;display:flex}.ev2-canvas-pill strong{color:var(--text)}.ev2-canvas-pill-btn{color:inherit;cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex}.ev2-canvas-pill-btn:hover{color:var(--primary)}.ev2-top-tip-wrap{position:relative}.ev2-top-tip{white-space:nowrap;color:#fff;pointer-events:none;opacity:0;z-index:500;background:#0f111eeb;border:1px solid #ffffff14;border-radius:7px;padding:5px 10px;font-size:.72rem;font-weight:600;transition:opacity .15s,transform .15s;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(-4px)}.ev2-top-tip:after{content:"";border:5px solid #0000;border-bottom-color:#0f111eeb;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.ev2-top-tip-wrap:hover .ev2-top-tip{opacity:1;transform:translate(-50%)translateY(0)}.ev2-section{margin-bottom:var(--space-4)}.ev2-section:first-child{margin-top:0}.ev2-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-3);padding-bottom:var(--space-1);border-bottom:1px solid var(--border);font-weight:600}.ev2-field-row{gap:var(--space-2);margin-bottom:var(--space-2);align-items:center;display:flex}.ev2-label{font-size:var(--text-sm);color:var(--text-dim);flex:1;min-width:60px}.ev2-input{width:120px;height:36px;padding:0 var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:var(--text-sm);font-family:var(--font);transition:border-color var(--duration-fast) var(--ease);outline:none;flex:none}.ev2-input:focus{border-color:var(--primary)}.ev2-input::placeholder{color:var(--text-muted)}.ev2-select{height:36px;padding:0 var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:var(--text-sm);font-family:var(--font);appearance:none;transition:border-color var(--duration-fast) var(--ease);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239aa0a6' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:calc(100% - 10px);background-repeat:no-repeat;outline:none;flex:1;padding-inline-end:32px}[dir=rtl] .ev2-select{background-position:10px}.ev2-select:focus{border-color:var(--primary)}.ev2-checkbox{gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);color:var(--text-dim);flex-direction:row;align-items:center;display:flex}.ev2-checkbox input[type=checkbox]{accent-color:var(--primary)}.ev2-toggle{cursor:pointer;align-items:center;gap:10px;padding:6px 0;display:flex}.ev2-toggle input{display:none}.ev2-toggle-label{font-size:var(--text-sm);min-width:0;color:var(--text-dim);flex:1}.ev2-toggle-ui{background:var(--border);border-radius:11px;flex-shrink:0;width:38px;height:22px;transition:background .2s;position:relative}.ev2-toggle-ui:after{content:"";background:var(--text-dim);border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;top:3px;left:3px}.ev2-toggle input:checked+.ev2-toggle-ui{background:var(--primary)}.ev2-toggle input:checked+.ev2-toggle-ui:after{background:#fff;left:19px}.ev2-counter{align-items:center;gap:4px;display:flex}.ev2-counter-btn{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);width:30px;height:30px;color:var(--text);cursor:pointer;transition:all .15s var(--ease);justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.ev2-counter-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}.ev2-counter-btn:disabled{opacity:.3;pointer-events:none}.ev2-counter-value{text-align:center;width:40px;color:var(--text);font-size:var(--text-sm);font-weight:700;font-family:var(--font);background:0 0;border:none}.ev2-counter-value::-webkit-inner-spin-button{display:none}.ev2-card-desc{font-size:var(--text-2xs,10px);color:var(--text-muted);line-height:1.3}.ev2-mini-card-grid{flex-wrap:wrap;gap:5px;display:flex}.ev2-mini-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);color:var(--text-dim);transition:border-color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);white-space:nowrap;align-items:center;padding:5px 10px;display:inline-flex}.ev2-mini-card:hover{border-color:var(--border-light)}.ev2-mini-card.active{border-color:var(--primary);background:var(--primary-subtle);color:var(--text)}.ev2-profile-grid{gap:var(--space-3);flex-direction:column;display:flex}.ev2-profile-section{gap:var(--space-1);flex-direction:column;display:flex}.ev2-front-card svg{flex-shrink:0}.ev2-field-stack{margin-bottom:var(--space-2);flex-direction:column;gap:4px;display:flex}.ev2-field-stack .ev2-label{min-width:unset;flex:unset;font-size:var(--text-xs)}.ev2-field-stack .ev2-input,.ev2-field-stack .ev2-select{width:100%}.ev2-field-inline{align-items:center;gap:6px;display:flex}.ev2-field-inline .ev2-input{flex:none;width:72px}.ev2-material-desc{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-2) 0;line-height:1.4}.ev2-card-tip{font-size:var(--text-2xs,10px);color:var(--primary);background:var(--primary-subtle);border-radius:var(--radius-full);white-space:nowrap;margin-top:2px;padding:1px 8px}.ev2-sub-title{font-size:var(--text-sm);color:var(--text-dim);margin-bottom:var(--space-2);margin-top:var(--space-2);font-weight:600}.ev2-unit{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0}.ev2-note{font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-2);background:var(--bg-input);border-radius:var(--radius-sm);line-height:1.4}.ev2-note-accent{color:var(--accent);background:var(--accent-subtle,#ffa00014)}.ev2-note-center{text-align:center}.ev2-warning{margin-top:var(--space-3);padding:var(--space-2) var(--space-3);border:1px solid var(--danger);background:var(--danger-subtle,#dc323214);color:var(--danger);border-radius:var(--radius-sm);font-size:var(--text-xs);line-height:1.45}.ev2-warning-title{text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:10px;font-weight:700}.ev2-warning-body{color:var(--danger)}.ev2-info-note{margin-top:var(--space-3);padding:var(--space-2) var(--space-3);border:1px solid var(--accent,#4a9eff);background:var(--accent-subtle,#4a9eff14);color:var(--text-secondary);border-radius:var(--radius-sm);font-size:var(--text-xs);line-height:1.45}.ev2-value-badge{font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);white-space:nowrap;font-weight:600;display:inline-block}.ev2-tab-group{gap:var(--space-1);background:var(--bg-input);border-radius:var(--radius);padding:2px;display:flex}.ev2-tab-btn{padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);font-size:var(--text-sm);color:var(--text-muted);transition:all .15s var(--ease);background:0 0;border:none;flex:1;font-weight:600}.ev2-tab-btn.active{background:var(--primary);color:#fff}.ev2-export-btn{border-radius:var(--radius-sm);cursor:pointer;width:100%;font-weight:600;font-size:var(--text-sm);font-family:var(--font);transition:opacity .15s var(--ease), border-color .15s var(--ease);background:var(--gradient-primary);color:#fff;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 16px;display:flex}.ev2-export-btn:hover{opacity:.9}.ev2-export-btn-secondary{background:var(--bg-card);width:100%;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-weight:500;font-size:var(--text-sm);font-family:var(--font);transition:border-color .15s var(--ease);justify-content:center;align-items:center;gap:8px;padding:10px 16px;display:flex}.ev2-export-btn-secondary:hover{border-color:var(--border-light);color:var(--text)}.ev2-details-summary{cursor:pointer;font-weight:600;font-size:var(--text-sm);color:var(--text);padding:4px 0}.ev2-details-summary-muted{cursor:pointer;font-size:var(--text-sm);color:var(--text-muted)}.ev2-action-btn{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:var(--text-sm);font-weight:600;font-family:var(--font);transition:all .15s var(--ease);background:var(--bg-card);color:var(--text)}.ev2-action-btn:hover{border-color:var(--border-light)}.ev2-action-btn-active{background:var(--accent-subtle,#ffa00014);color:var(--accent);border-color:var(--accent)}.ev2-add-btn{border:1px dashed var(--border);border-radius:var(--radius-sm);width:100%;color:var(--primary);cursor:pointer;font-size:var(--text-xs);font-family:var(--font);transition:border-color .15s var(--ease);background:0 0;justify-content:center;align-items:center;gap:4px;margin-top:8px;padding:6px 12px;display:flex}.ev2-add-btn:hover{border-color:var(--primary)}.ev2-material-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px;margin-bottom:var(--space-2)}.ev2-stat-card{background:var(--bg-input);border-radius:var(--radius-sm);padding:var(--space-2)}.ev2-stat-label{font-size:var(--text-xs);color:var(--text-muted)}.ev2-stat-value{font-size:var(--text-sm);color:var(--text);font-weight:600}.ev2-stat-sub{font-size:var(--text-xs);color:var(--text-dim)}.ev2-total-row{padding:var(--space-2);background:var(--primary-subtle);border-radius:var(--radius-sm);margin-top:var(--space-2);justify-content:space-between;align-items:center;display:flex}.ev2-total-label{font-size:var(--text-sm);color:var(--text);font-weight:700}.ev2-total-value{font-size:var(--text-base);color:var(--primary);font-weight:700}.ev2-card-grid{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.ev2-card-grid.cols-2{grid-template-columns:repeat(2,1fr)}.ev2-card{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-1);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;font-size:var(--text-xs);color:var(--text-dim);transition:border-color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);word-break:break-word;flex-direction:column;line-height:1.3;display:flex}.ev2-card:hover{border-color:var(--border-light)}.ev2-card.active{border-color:var(--primary);background:var(--primary-subtle);color:var(--text)}.ev2-info-bar{background:var(--bg-glass);-webkit-backdrop-filter:blur(8px);border-top:1px solid var(--border);justify-content:center;align-items:center;gap:var(--space-6);height:40px;font-size:var(--text-sm);color:var(--text-dim);z-index:10;display:flex;position:absolute;bottom:0;left:0;right:0}.ev2-info-item{gap:var(--space-1);align-items:center;display:flex}.ev2-info-value{color:var(--text);font-weight:600}.ev2-template-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;animation:ev2TgFadeIn .2s var(--ease);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes ev2TgFadeIn{0%{opacity:0}to{opacity:1}}.ev2-tg{background:var(--bg-sidebar);border:1px solid var(--border);width:92vw;max-width:860px;max-height:85vh;animation:ev2TgSlideUp .3s var(--ease);border-radius:16px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000080,inset 0 0 0 1px #ffffff08}@keyframes ev2TgSlideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.ev2-tg-header{flex-shrink:0;padding:24px 28px 16px}.ev2-tg-title-row{justify-content:space-between;align-items:center;display:flex}.ev2-tg-title{color:var(--text);letter-spacing:-.01em;margin:0;font-size:1.3rem;font-weight:700}.ev2-tg-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:4px 0 0}.ev2-tg-close{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);width:32px;height:32px;color:var(--text-dim);cursor:pointer;transition:all .15s var(--ease);justify-content:center;align-items:center;display:flex}.ev2-tg-close:hover{background:var(--danger-subtle);border-color:var(--danger);color:var(--danger)}.ev2-tg-cats{scrollbar-width:none;flex-shrink:0;gap:6px;padding:0 28px 16px;display:flex;overflow-x:auto}.ev2-tg-cats::-webkit-scrollbar{display:none}.ev2-tg-cat{border-radius:var(--radius-full);border:1px solid var(--border);color:var(--text-muted);font-size:.78rem;font-family:var(--font);cursor:pointer;white-space:nowrap;transition:all .18s var(--ease);background:0 0;align-items:center;gap:6px;padding:7px 14px;font-weight:500;display:flex}.ev2-tg-cat:hover{border-color:var(--border-light);color:var(--text-dim);background:var(--bg-card)}.ev2-tg-cat.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px var(--primary-glow);font-weight:600}.ev2-tg-cat.active svg{stroke-width:2.2px}.ev2-tg-body{border-top:1px solid var(--border);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.ev2-tg-grid{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));align-content:start;gap:10px;padding:20px 28px;display:grid;overflow:hidden auto}.ev2-tg-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .18s var(--ease);text-align:center;flex-direction:column;align-items:center;padding:14px 6px 10px;display:flex;position:relative}.ev2-tg-card:hover{border-color:var(--border-light);background:color-mix(in srgb, var(--bg-card) 60%, var(--primary-subtle) 40%);transform:translateY(-2px);box-shadow:0 6px 20px #0003}.ev2-tg-card.selected{border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 1px var(--primary), 0 4px 16px var(--primary-glow)}.ev2-tg-card-preview{justify-content:center;align-items:center;margin-bottom:8px;display:flex}.ev2-tg-card-label{color:var(--text);margin-bottom:2px;font-size:.75rem;font-weight:600;line-height:1.3}.ev2-tg-card-dims{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.65rem}.ev2-tg-card-badge{top:6px;background:var(--primary);color:#fff;width:18px;height:18px;animation:ev2TgBadgePop .25s var(--ease-bounce);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset-inline-end:6px}@keyframes ev2TgBadgePop{0%{transform:scale(0)}to{transform:scale(1)}}.ev2-tg-preview{border-top:1px solid var(--border);background:var(--bg-card);height:180px;transition:opacity .15s var(--ease);opacity:.4;flex-shrink:0;align-items:center;gap:20px;padding:16px 28px;display:flex}.ev2-tg-preview.visible{opacity:1}.ev2-tg-preview-placeholder{text-align:center;font-size:var(--text-sm);color:var(--text-muted);flex:1}.ev2-tg-preview-svg{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;padding:10px;display:flex}.ev2-tg-preview-info{flex-direction:column;flex:1;justify-content:center;gap:6px;min-width:0;display:flex}.ev2-tg-preview-name{font-size:var(--text-base);color:var(--text);font-weight:700}.ev2-tg-preview-desc{font-size:var(--text-sm);color:var(--text-dim);line-height:1.4}.ev2-tg-preview-specs{gap:12px;margin-top:4px;display:flex}.ev2-tg-spec{font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;align-items:center;gap:5px;display:flex}.ev2-tg-spec svg{color:var(--primary);flex-shrink:0}@media (width<=640px){.ev2-tg{border-radius:12px;width:98vw;max-height:95vh}.ev2-tg-header{padding:16px 16px 12px}.ev2-tg-cats{padding:0 16px 12px}.ev2-tg-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;padding:12px 16px}.ev2-tg-preview{flex-direction:column;align-items:center;gap:12px;padding:12px 16px}}.ev2-modal-overlay{background:var(--bg-overlay);z-index:200;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ev2-modal{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-6);width:90%;max-width:400px;box-shadow:var(--shadow-xl)}.ev2-modal h3{margin:0 0 var(--space-2);color:var(--text)}.ev2-modal p{color:var(--text-dim);font-size:var(--text-sm);margin:0 0 var(--space-4)}.ev2-modal-actions{gap:var(--space-2);justify-content:flex-end;display:flex}.zone-canvas-hint{z-index:20;font-size:var(--text-sm);font-family:var(--font);color:var(--text-muted);background:color-mix(in srgb, var(--bg-sidebar) 90%, transparent);border:1px solid var(--border);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none;white-space:nowrap;padding:8px 20px;animation:.3s zoneHintFadeIn;position:absolute;top:60px;left:50%;transform:translate(-50%)}.zone-canvas-hint-selected{color:var(--primary);border-color:var(--primary)}@keyframes zoneHintFadeIn{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.zone-dims{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--primary-subtle);border:1px solid var(--primary);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--primary);font-variant-numeric:tabular-nums;font-weight:600;display:flex}@media (width<=768px){.ev2-app{flex-direction:column}.ev2-icon-rail{border-inline-start:none;border-top:1px solid var(--border);flex-direction:row;width:100%;min-width:auto;padding:4px 8px;overflow-x:auto}.ev2-icon-rail-btn{width:auto;min-width:48px}.ev2-rail-divider{width:1px;height:24px;margin:0 4px}.ev2-panel-area{border-inline-start:none;border-top:1px solid var(--border);width:100%;min-width:0;max-height:50vh}.ev2-viewer{min-height:40vh}.ev2-info-bar{gap:var(--space-3);font-size:var(--text-xs)}.ev2-template-gallery{width:95vw;max-height:90vh}.ev2-template-grid{gap:var(--space-3);padding:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.ev2-context-menu{z-index:999;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-1);min-width:180px;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:fixed}.ev2-context-header{padding:var(--space-2) var(--space-3);font-weight:600;font-size:var(--text-xs);color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:var(--space-1)}.ev2-context-info{padding:2px var(--space-3) var(--space-1);font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums}.ev2-context-divider{background:var(--border);height:1px;margin:var(--space-1) 0}.ev2-context-item{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);cursor:pointer;font-family:var(--font);font-size:var(--text-sm);color:var(--text);border-radius:var(--radius-sm);text-align:inherit;background:0 0;border:none;display:flex}.ev2-context-item:hover{background:var(--bg-input)}@keyframes ev2-toast-in{0%{opacity:0;transform:translate(-50%,-12px)scale(.96)}to{opacity:1;transform:translate(-50%)scale(1)}}.ev2-toast{z-index:10000;min-width:220px;max-width:480px;font-family:var(--font);font-size:var(--text-sm);color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #ffffff24;border-radius:12px;align-items:center;gap:10px;padding:12px 18px;font-weight:600;animation:.22s ease-out ev2-toast-in;display:inline-flex;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 32px #00000047}.ev2-toast-success{background:linear-gradient(135deg,#16a34a 0%,#15803d 100%)}.ev2-toast-error{background:linear-gradient(135deg,#dc2626 0%,#991b1b 100%)}.ev2-toast svg{flex-shrink:0}.fspec-panel{max-width:1100px;margin:0 auto;padding:20px 0 60px}.fspec-header{margin-bottom:24px}.fspec-header-row{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px;display:flex}.fspec-header h2{color:var(--text);align-items:center;gap:10px;margin:0 0 8px;font-size:1.4rem;font-weight:700;display:flex}.fspec-template-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:.76rem;font-weight:600;transition:all .15s;display:inline-flex}.fspec-template-btn:hover{border-color:var(--primary);color:var(--primary);background:#6366f114}.fspec-header h2 svg{color:var(--primary)}.fspec-intro{color:var(--text-muted);max-width:760px;margin:0;font-size:.9rem;line-height:1.55}.fspec-back-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;margin-bottom:12px;padding:6px 12px;font-size:.82rem;transition:all .2s;display:inline-flex}.fspec-back-btn:hover{border-color:var(--primary);color:var(--primary);background:#6366f114}.fspec-loading,.fspec-error{border-radius:10px;margin-bottom:16px;padding:14px 18px;font-size:.88rem}.fspec-loading{background:var(--bg);border:1px dashed var(--border);color:var(--text-muted)}.fspec-error{color:var(--danger);background:#ef444414;border:1px solid #ef44444d;align-items:center;gap:8px;display:flex}.fspec-category-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.fspec-category-card{border:1px solid var(--border);background:var(--bg-sidebar);cursor:pointer;text-align:start;border-radius:14px;flex-direction:column;align-items:flex-start;gap:10px;padding:20px;transition:all .2s;display:flex}.fspec-category-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 10px 24px #6366f124}.fspec-category-icon{width:46px;height:46px;color:var(--primary);background:#6366f11f;border-radius:10px;justify-content:center;align-items:center;display:flex}.fspec-category-name{color:var(--text);font-size:1rem;font-weight:700}.fspec-category-count{color:var(--text-muted);font-size:.78rem}.fspec-readonly-note{color:var(--text-muted);text-align:center;background:#6366f10f;border:1px dashed #6366f14d;border-radius:10px;margin-top:18px;padding:12px 16px;font-size:.82rem}.fspec-feature-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:12px;display:grid}.fspec-feature-card{border:1px solid var(--border);background:var(--bg-sidebar);cursor:pointer;text-align:start;border-radius:12px;flex-direction:column;gap:4px;min-height:72px;padding:16px 18px;transition:all .2s;display:flex}.fspec-feature-card:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 6px 16px #6366f11f}.fspec-feature-title{color:var(--text);font-size:.95rem;font-weight:700}.fspec-feature-subtitle{color:var(--text-muted);font-size:.76rem}.fspec-subcategory-list{flex-direction:column;gap:28px;margin-top:16px;display:flex}.fspec-subcategory{flex-direction:column;gap:10px;display:flex}.fspec-subcategory-title{color:var(--text);border-bottom:1px dashed var(--border);align-items:center;gap:10px;margin:0;padding-bottom:6px;font-size:.95rem;font-weight:700;display:flex}.fspec-subcategory-actions{align-items:center;gap:6px;margin-inline-start:auto;display:flex}.fspec-add-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:600;transition:all .15s;display:inline-flex}.fspec-add-btn:hover{border-color:var(--primary);color:var(--primary);background:#6366f114}.fspec-subcategory-count{min-width:20px;height:20px;color:var(--primary);background:#6366f126;border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:.7rem;font-weight:700;display:inline-flex}.fspec-subcategory-empty{background:var(--bg);border:1px dashed var(--border);color:var(--text-muted);text-align:center;border-radius:10px;padding:14px 16px;font-size:.78rem}.fspec-feature-default{border-style:dashed;position:relative}.fspec-feature-recent{background:linear-gradient(135deg, var(--bg-sidebar) 0%, #22c55e0a 100%);border-color:#22c55e80;position:relative}.fspec-feature-badge{top:6px;color:var(--primary);letter-spacing:.02em;background:#6366f124;border-radius:6px;padding:2px 6px;font-size:.62rem;font-weight:700;position:absolute;inset-inline-end:6px}.fspec-feature-badge-recent{top:auto;bottom:6px;color:#22c55e;background:#22c55e26;align-items:center;gap:3px;display:inline-flex;inset-inline-end:6px}.fspec-feature-meta{color:var(--text-muted);opacity:.85;align-items:center;gap:4px;margin-top:6px;font-size:.68rem;display:inline-flex}.fspec-empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.fspec-empty-state svg{opacity:.4;margin-bottom:14px}.fspec-empty-state h3{color:var(--text);margin:0 0 6px;font-size:1rem;font-weight:700}.fspec-empty-state p{max-width:440px;margin:0;font-size:.85rem;line-height:1.5}.fspec-modal-overlay{z-index:1100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.fspec-modal{background:var(--bg-sidebar);border:1px solid var(--border-light);border-radius:18px;flex-direction:column;width:100%;max-width:780px;max-height:86vh;display:flex;overflow:hidden;box-shadow:0 30px 80px #00000080}.fspec-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.fspec-modal-header h3{color:var(--text);align-items:center;gap:10px;margin:0;font-size:1.05rem;font-weight:700;display:flex}.fspec-modal-header h3 svg{color:var(--primary)}.fspec-modal-close{border:1px solid var(--border);width:32px;height:32px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.fspec-modal-close:hover{color:var(--danger);border-color:var(--danger);background:#ef44441a}.fspec-modal-actions{align-items:center;gap:6px;display:flex}.fspec-icon-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.fspec-icon-btn:hover{border-color:var(--primary);color:var(--primary);background:#6366f11a}.fspec-icon-btn-danger:hover{border-color:var(--danger);color:var(--danger);background:#ef44441a}.fspec-modal-subtitle{color:var(--text-muted);margin:0 0 16px;font-size:.82rem;font-style:italic}.fspec-default-note{color:var(--text-muted);background:#6366f10f;border:1px dashed #6366f14d;border-radius:8px;margin-top:18px;padding:10px 14px;font-size:.78rem}.fspec-field-label{color:var(--text-muted);margin:14px 0 6px;font-size:.78rem;font-weight:600;display:block}.fspec-field-label:first-of-type{margin-top:0}.fspec-field-input,.fspec-field-textarea{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:.88rem;transition:border-color .15s}.fspec-field-input:focus,.fspec-field-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11f}.fspec-field-textarea{resize:vertical;min-height:220px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.82rem;line-height:1.55}.fspec-edit-hint{color:var(--text-muted);margin-top:6px;font-size:.72rem}.fspec-edit-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:18px;padding-top:14px;display:flex}.fspec-btn-primary,.fspec-btn-secondary{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:.82rem;font-weight:600;transition:all .15s;display:inline-flex}.fspec-btn-primary{background:var(--primary);color:#fff}.fspec-btn-primary:hover:not(:disabled){background:var(--primary-hover,#5658e0);transform:translateY(-1px)}.fspec-btn-primary:disabled{opacity:.6;cursor:not-allowed}.fspec-btn-secondary{color:var(--text);border-color:var(--border);background:0 0}.fspec-btn-secondary:hover:not(:disabled){border-color:var(--text-muted);background:var(--bg)}.fspec-btn-secondary:disabled{opacity:.6;cursor:not-allowed}.fspec-modal-body{flex:1;padding:24px 28px;overflow:auto}.fspec-modal-footer{border-top:1px dashed var(--border);color:var(--text-muted);flex-direction:column;gap:6px;margin-top:20px;padding-top:14px;font-size:.76rem;display:flex}.fspec-history-line{align-items:center;gap:6px;display:flex}.fspec-history-line svg{color:var(--primary);flex-shrink:0}.fspec-history-line-subtle{opacity:.65;font-size:.7rem}.fspec-history-line-subtle svg{color:var(--text-muted)}.fspec-markdown{color:var(--text);font-size:.93rem;line-height:1.65}.fspec-markdown h1,.fspec-markdown h2,.fspec-markdown h3,.fspec-markdown h4{color:var(--text);margin:1.4em 0 .6em;font-weight:700}.fspec-markdown h1{font-size:1.25rem}.fspec-markdown h2{font-size:1.1rem}.fspec-markdown h3{font-size:1rem}.fspec-markdown h4{font-size:.94rem}.fspec-markdown p{margin:.6em 0}.fspec-markdown ul,.fspec-markdown ol{margin:.6em 0;padding-inline-start:1.6em}.fspec-markdown li{margin:.25em 0}.fspec-markdown strong{color:var(--text);font-weight:700}.fspec-markdown code{background:var(--bg);color:var(--primary);border-radius:5px;padding:1px 6px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85em}.fspec-markdown pre{background:var(--bg);border-radius:10px;margin:.8em 0;padding:12px 14px;font-size:.82em;overflow-x:auto}.fspec-markdown pre code{color:var(--text);background:0 0;padding:0}.fspec-markdown blockquote{border-inline-start:3px solid var(--primary);color:var(--text-muted);background:#6366f10f;border-radius:6px;margin:.8em 0;padding:2px 14px}.fspec-markdown a{color:var(--primary);text-decoration:underline}.fspec-markdown table{border-collapse:collapse;margin:.8em 0;font-size:.85em}.fspec-markdown th,.fspec-markdown td{border:1px solid var(--border);text-align:start;padding:6px 10px}.fspec-markdown th{background:var(--bg);font-weight:700}.kb-page{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font)}.kb-nav{z-index:100;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);background:#111327cc;position:sticky;top:0}.kb-nav-inner{flex-direction:row-reverse;justify-content:space-between;align-items:center;gap:16px;max-width:1200px;margin:0 auto;padding:14px 24px;display:flex}.kb-back-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-family:var(--font);transition:all var(--duration-fast) var(--ease);background:0 0;flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;display:flex}.kb-back-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 16px var(--primary-glow)}.kb-nav-title{color:var(--primary);align-items:center;gap:10px;display:flex}.kb-nav-title h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.15rem;font-weight:700}.kb-nav-stats{color:var(--text-muted);font-size:.8rem}.kb-hero{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:280px;padding:64px 24px 48px;display:flex;position:relative;overflow:hidden}.kb-hero-glow{pointer-events:none;z-index:0;background:radial-gradient(circle,#6366f12e 0%,#6366f10d 40%,#0000 70%);width:700px;height:500px;position:absolute;top:-30%;left:50%;transform:translate(-50%)}.kb-hero-logo{z-index:1;background:var(--surface-elevated);transition:transform var(--duration-normal) var(--ease), box-shadow var(--duration-normal) var(--ease);border:1px solid #6366f133;border-radius:20px;margin-bottom:20px;padding:12px;position:relative;box-shadow:0 4px 20px #6366f140,0 0 40px #6366f126,inset 0 1px #ffffff0d}.kb-hero-logo:hover{transform:scale(1.05);box-shadow:0 6px 28px #6366f159,0 0 60px #6366f133}.kb-hero h2{z-index:1;background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 12px;font-size:2.4rem;font-weight:800;line-height:1.3;position:relative}.kb-hero p{color:var(--text-muted);z-index:1;max-width:500px;margin:0 0 28px;font-size:1.05rem;position:relative}.kb-hero-float-icon{color:var(--primary);opacity:.12;z-index:0;pointer-events:none;animation:6s ease-in-out infinite kbFloat;position:absolute}.kb-hero-search{z-index:1;width:100%;max-width:520px;position:relative}@keyframes kbFloat{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-12px)rotate(3deg)}50%{transform:translateY(-6px)rotate(-2deg)}75%{transform:translateY(-14px)rotate(1deg)}}.kb-toolbar{flex-wrap:wrap;align-items:center;gap:12px;max-width:1200px;margin:0 auto;padding:0 24px 20px;display:flex}.kb-search-wrap{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);min-width:240px;transition:all var(--duration-fast) var(--ease);flex:1;align-items:center;gap:10px;padding:11px 18px;display:flex}.kb-search-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow), 0 0 20px var(--primary-glow)}.kb-search-wrap svg{color:var(--text-muted);flex-shrink:0}.kb-search-input{color:var(--text);font-family:var(--font);background:0 0;border:none;outline:none;flex:1;width:100%;font-size:.9rem}.kb-search-input::placeholder{color:var(--text-muted)}.kb-search-clear{color:var(--text-muted);cursor:pointer;transition:color var(--duration-fast);background:0 0;border:none;padding:0 4px;font-size:1.2rem;line-height:1}.kb-search-clear:hover{color:var(--danger)}.kb-autocomplete{top:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:50;margin-top:4px;animation:.15s kbFadeIn;position:absolute;inset-inline:0;overflow:hidden;box-shadow:0 8px 24px #0000004d}.kb-autocomplete-item{cursor:pointer;transition:background var(--duration-fast);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.kb-autocomplete-item:hover{background:var(--bg-input)}.kb-autocomplete-title{color:var(--text);font-size:.85rem}.kb-autocomplete-cat{color:var(--text-muted);flex-shrink:0;font-size:.72rem}.kb-quick-tags{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:16px;display:flex}.kb-quick-tag{border-radius:var(--radius-full);color:var(--text-muted);font-size:.76rem;font-family:var(--font);cursor:pointer;transition:all var(--duration-fast) var(--ease);background:#ffffff0d;border:1px solid #ffffff1f;padding:5px 14px}.kb-quick-tag:hover{border-color:var(--primary);color:var(--primary);background:#6366f126}.kb-hero-search{position:relative}.kb-filter-pills{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.kb-filter-pill{border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:.82rem;font-family:var(--font);cursor:pointer;transition:all var(--duration-fast) var(--ease);white-space:nowrap;align-items:center;gap:4px;padding:7px 14px;display:inline-flex}.kb-filter-pill:hover{border-color:var(--border-light);color:var(--text)}.kb-filter-pill.active{background:var(--primary-subtle);border-color:var(--primary);color:var(--primary)}.kb-filter-pill.beginner{--pill-color:#22c55e}.kb-filter-pill.beginner.active{color:#22c55e;background:#22c55e1f;border-color:#22c55e}.kb-filter-pill.intermediate{--pill-color:#f59e0b}.kb-filter-pill.intermediate.active{color:#f59e0b;background:#f59e0b1f;border-color:#f59e0b}.kb-filter-pill.advanced{--pill-color:#ef4444}.kb-filter-pill.advanced.active{color:#ef4444;background:#ef44441f;border-color:#ef4444}.kb-results-count{width:100%;color:var(--text-muted);padding-inline-start:4px;font-size:.82rem}.kb-categories-grid{grid-template-columns:repeat(3,1fr);gap:20px;max-width:1200px;margin:0 auto;padding:0 24px 48px;display:grid}.kb-category-card{background:var(--bg-card);border:1px solid var(--border);border-top:4px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--duration-normal) var(--ease);animation:kbCardReveal .5s var(--ease) both;position:relative;overflow:hidden}.kb-category-card:hover{border-color:var(--border-light);box-shadow:0 12px 32px #0000004d, 0 0 24px var(--primary-glow);transform:translateY(-6px)}.kb-category-illust{height:160px;transition:transform var(--duration-normal) var(--ease);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.kb-category-card:hover .kb-category-illust{transform:scale(1.05)}.kb-category-illust-bg{opacity:.12;pointer-events:none;position:absolute;inset:0}.kb-category-illust svg{z-index:2;position:relative}.kb-category-illust-img{object-fit:cover;z-index:0;opacity:.3;filter:brightness(.7)saturate(.8);width:100%;height:100%;transition:opacity var(--duration-normal) var(--ease);position:absolute;inset:0}.kb-category-card:hover .kb-category-illust-img{opacity:.5}.kb-category-illust-bg{z-index:1}.kb-category-info{flex-direction:column;gap:8px;padding:18px 20px;display:flex}.kb-category-info h3{color:var(--text);margin:0;font-size:1.1rem;font-weight:700}.kb-category-info p{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.84rem;line-height:1.6;display:-webkit-box;overflow:hidden}.kb-category-count{color:var(--text-muted);background:var(--bg-input);border-radius:var(--radius-full);align-self:flex-start;align-items:center;gap:4px;margin-top:4px;padding:3px 10px;font-size:.75rem;display:inline-flex}.kb-category-header{flex-direction:column;gap:12px;max-width:1200px;margin:0 auto;padding:28px 24px 20px;display:flex}.kb-breadcrumb{color:var(--text-muted);direction:rtl;flex-wrap:wrap;align-items:center;gap:8px;font-size:.82rem;display:flex}.kb-breadcrumb svg{color:var(--text-dim);opacity:.5;flex-shrink:0}.kb-breadcrumb-link{cursor:pointer;transition:opacity var(--duration-fast);color:var(--primary)!important}.kb-breadcrumb-link:hover{opacity:.7;text-decoration:underline}.kb-breadcrumb-current{font-weight:600;color:var(--text)!important}.kb-category-header-illust{border-radius:var(--radius);justify-content:center;align-items:center;height:180px;margin-bottom:8px;display:flex;position:relative;overflow:hidden}.kb-category-header-illust svg{z-index:2;position:relative}.kb-category-header-img{object-fit:cover;opacity:.25;filter:brightness(.6)saturate(.8);z-index:0;width:100%;height:100%;position:absolute;inset:0}.kb-category-header h2{align-items:center;gap:12px;margin:0;font-size:1.6rem;font-weight:800;display:flex}.kb-category-header p{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.6}.kb-articles-grid{grid-template-columns:repeat(3,1fr);gap:16px;max-width:1200px;margin:0 auto;padding:0 24px 48px;display:grid}.kb-article-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--duration-normal) var(--ease);animation:kbCardReveal .5s var(--ease) both;flex-direction:column;gap:10px;padding:20px;display:flex;position:relative;overflow:hidden}.kb-article-card:before{content:"";top:0;background:var(--border);width:3px;height:100%;transition:background var(--duration-fast);position:absolute;inset-inline-start:0}.kb-article-card:hover{border-color:var(--border-light);transform:translateY(-4px);box-shadow:0 8px 24px #00000040}.kb-article-card-icon{border-radius:var(--radius-sm);background:var(--primary-subtle);width:36px;height:36px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.kb-article-card h3{color:var(--text);margin:0;font-size:.95rem;font-weight:700}.kb-article-card-summary{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.82rem;line-height:1.5;display:-webkit-box;overflow:hidden}.kb-article-card-footer{flex-wrap:wrap;align-items:center;gap:6px;margin-top:auto;display:flex}.kb-article-detail{max-width:900px;animation:kbFadeIn .35s var(--ease);margin:0 auto;padding:0 24px 48px}.kb-article-detail-header{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.kb-article-detail-header h2{color:var(--text);margin:0;font-size:1.8rem;font-weight:800;line-height:1.3}.kb-article-detail-close{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;font-size:.84rem;font-family:var(--font);transition:all var(--duration-fast);background:0 0;align-self:flex-start;align-items:center;gap:6px;margin-bottom:8px;padding:8px 14px;display:flex}.kb-article-detail-close:hover{color:var(--text);border-color:var(--primary);background:var(--primary-subtle)}.kb-article-detail-illust{border-radius:var(--radius);justify-content:center;align-items:center;width:100%;height:200px;margin-bottom:8px;display:flex;position:relative;overflow:hidden}.kb-article-detail-illust-large{border:1px solid var(--border);background:var(--bg-input);height:auto;min-height:200px;max-height:440px;padding:24px}.kb-article-detail-illust svg{z-index:2;position:relative}.kb-article-detail-illust-img{object-fit:cover;opacity:.2;filter:brightness(.6);z-index:0;width:100%;height:100%;position:absolute;inset:0}.kb-summary-box{color:var(--text);background:var(--primary-subtle);border-radius:var(--radius-sm);border-inline-start:4px solid var(--primary);margin-bottom:28px;padding:16px 20px;font-size:.94rem;line-height:1.75}.kb-detail-section{margin-bottom:24px}.kb-detail-section-header{color:var(--text);border-bottom:1px solid var(--border);align-items:center;gap:8px;margin:0 0 12px;padding-bottom:8px;font-size:1rem;font-weight:700;display:flex}.kb-detail-section-header svg{color:var(--primary);flex-shrink:0}.kb-detail-section p{color:var(--text-dim);white-space:pre-line;margin:0;font-size:.88rem;line-height:1.8}.kb-specs-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.kb-spec-item{background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color var(--duration-fast);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.kb-spec-item:hover{border-color:var(--border-light)}.kb-spec-label{color:var(--text-muted);font-size:.8rem}.kb-spec-value{color:var(--primary);direction:ltr;font-family:Courier New,monospace;font-size:.85rem;font-weight:700}.kb-pros-cons-section{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.kb-pros-card,.kb-cons-card{border-radius:var(--radius);border:1px solid var(--border);padding:20px}.kb-pros-card{background:#22c55e0a;border-color:#22c55e33}.kb-cons-card{background:#ef44440a;border-color:#ef444433}.kb-pros-card-header,.kb-cons-card-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:14px;padding-bottom:10px;display:flex}.kb-pros-card-header h4,.kb-cons-card-header h4{margin:0;font-size:.95rem;font-weight:700}.kb-pros-card-header{color:#22c55e}.kb-cons-card-header{color:#ef4444}.kb-pros-card-list,.kb-cons-card-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.kb-pros-card-list li,.kb-cons-card-list li{color:var(--text-dim);align-items:flex-start;gap:10px;font-size:.86rem;line-height:1.6;display:flex}.kb-pros-card-list li svg{color:#22c55e;flex-shrink:0;margin-top:3px}.kb-cons-card-list li svg{color:#ef4444;flex-shrink:0;margin-top:3px}.kb-tips-cards-section{margin-bottom:24px}.kb-tips-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.kb-tip-card{border-radius:var(--radius);transition:border-color var(--duration-fast), transform var(--duration-fast);background:#f59e0b0d;border:1px solid #f59e0b26;align-items:flex-start;gap:14px;padding:16px 18px;display:flex}.kb-tip-card:hover{border-color:#f59e0b66;transform:translateY(-2px)}.kb-tip-card-num{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:800;display:flex}.kb-tip-card-text{color:var(--text-dim);margin:0;font-size:.86rem;line-height:1.6}.kb-key-takeaway{border-radius:var(--radius);border:1px solid #6366f133;border-inline-start:4px solid var(--takeaway-color,var(--primary));background:linear-gradient(135deg,#6366f114 0%,#8b5cf60a 100%);align-items:flex-start;gap:16px;margin-bottom:24px;padding:20px;animation:.5s both kbFadeIn;display:flex}.kb-key-takeaway-icon{width:40px;height:40px;color:var(--takeaway-color,var(--primary));background:#6366f126;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.kb-key-takeaway-content strong{text-transform:uppercase;letter-spacing:.5px;color:var(--takeaway-color,var(--primary));margin-bottom:6px;font-size:.78rem;display:block}.kb-key-takeaway-content p{color:var(--text);margin:0;font-size:.92rem;font-weight:500;line-height:1.7}.kb-steps-list{flex-direction:column;gap:0;padding-inline-start:24px;display:flex;position:relative}.kb-steps-list:before{content:"";inset-inline-start:15px;background:linear-gradient(to bottom, var(--primary), transparent);opacity:.3;width:2px;position:absolute;top:20px;bottom:20px}.kb-step-item{align-items:flex-start;gap:16px;padding:12px 0;display:flex;position:relative}.kb-step-num{background:var(--primary);color:#fff;z-index:1;width:32px;height:32px;box-shadow:0 0 0 4px var(--bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.kb-step-text{color:var(--text-dim);padding-top:5px;font-size:.88rem;line-height:1.7}.kb-collapsible-trigger{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.kb-collapsible-trigger:hover{color:var(--primary)}.kb-collapsible-arrow{color:var(--text-muted);transition:transform var(--duration-fast) var(--ease);margin-inline-start:auto;font-size:.8rem}.kb-collapsible-body{opacity:0;max-height:0;margin-top:0;transition:max-height .35s,opacity .25s,margin .25s;overflow:hidden}.kb-collapsible-open .kb-collapsible-body{opacity:1;max-height:2000px;margin-top:12px}.kb-tags{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;margin-top:16px;padding-top:16px;display:flex}.kb-tag{color:var(--text-muted);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-full);transition:all var(--duration-fast);padding:4px 12px;font-size:.72rem}.kb-tag:hover{border-color:var(--primary);color:var(--primary)}.kb-article-nav{border-top:1px solid var(--border);flex-direction:column;gap:20px;margin-top:28px;padding-top:24px;display:flex}.kb-next-article{border-radius:var(--radius);background:var(--bg-input);border:1px solid var(--border);cursor:pointer;transition:all var(--duration-fast) var(--ease);flex-direction:column;gap:6px;padding:16px 20px;display:flex}.kb-next-article:hover{border-color:var(--primary);transform:translate(-4px)}.kb-next-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;font-size:.75rem;display:flex}.kb-next-title{color:var(--text);font-size:.95rem;font-weight:600}.kb-related-header{color:var(--text-dim);align-items:center;gap:8px;margin:0 0 12px;font-size:.85rem;font-weight:600;display:flex}.kb-related-list{flex-direction:column;gap:8px;display:flex}.kb-related-item{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);cursor:pointer;transition:all var(--duration-fast) var(--ease);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.kb-related-item:hover{border-color:var(--primary);transform:translate(-4px)}.kb-related-item-title{color:var(--text);font-size:.86rem;font-weight:500}.kb-related-item-cat{color:var(--text-muted);flex-shrink:0;font-size:.72rem}.kb-article-detail-meta{align-items:center;gap:12px;margin-top:8px;display:flex}.kb-article-actions{gap:6px;margin-inline-start:auto;display:flex}.kb-action-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;width:34px;height:34px;transition:all var(--duration-fast) var(--ease);justify-content:center;align-items:center;display:flex}.kb-action-btn:hover{color:var(--primary);border-color:var(--primary)}.kb-action-btn.kb-action-active{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b}.kb-mark-read{border-top:1px solid var(--border);justify-content:center;margin-top:24px;padding-top:20px;display:flex}.kb-mark-read-btn{border-radius:var(--radius);border:2px solid var(--border);color:var(--text-muted);font-size:.88rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--duration-fast) var(--ease);background:0 0;align-items:center;gap:8px;padding:12px 28px;display:flex}.kb-mark-read-btn:hover{border-color:var(--success);color:var(--success)}.kb-mark-read-done{color:#22c55e;background:#22c55e1a;border-color:#22c55e}.kb-article-card{position:relative}.kb-article-card-indicators{top:10px;gap:4px;display:flex;position:absolute;inset-inline-end:10px}.kb-article-card-check{color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.kb-article-card-bookmark{color:#f59e0b;align-items:center;display:flex}.kb-article-card-completed{opacity:.85}.kb-article-card-completed:after{content:"";top:0;pointer-events:none;border-radius:inherit;width:100%;height:100%;position:absolute;inset-inline-start:0;box-shadow:inset 0 0 0 1px #22c55e33}.kb-category-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.kb-category-progress-text{color:var(--text-muted);font-size:.72rem;font-weight:600}.kb-category-progress-bar{background:var(--bg-input);border-radius:2px;height:3px;margin-top:10px;overflow:hidden}.kb-category-progress-fill{border-radius:2px;height:100%;transition:width .5s}.kb-difficulty{border-radius:var(--radius-full);letter-spacing:.3px;white-space:nowrap;align-items:center;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.kb-difficulty.beginner{color:#22c55e;background:#22c55e1f}.kb-difficulty.intermediate{color:#f59e0b;background:#f59e0b1f}.kb-difficulty.advanced{color:#ef4444;background:#ef44441f;animation:3s ease-in-out infinite kbPulse}.kb-landing-section{max-width:1200px;margin:0 auto;padding:0 24px 24px}.kb-landing-section-title{color:var(--text-dim);align-items:center;gap:8px;margin:0 0 16px;font-size:1rem;font-weight:600;display:flex}.kb-landing-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px;padding-bottom:8px;display:flex;overflow-x:auto}.kb-landing-scroll::-webkit-scrollbar{height:4px}.kb-landing-scroll::-webkit-scrollbar-track{background:0 0}.kb-landing-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.kb-landing-scroll .kb-article-card{scroll-snap-align:start;flex-shrink:0;min-width:260px;max-width:300px}.kb-continue-list{flex-direction:column;gap:10px;display:flex}.kb-continue-item{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all var(--duration-fast) var(--ease);padding:14px 18px}.kb-continue-item:hover{border-color:var(--primary);transform:translate(-4px)}.kb-continue-info{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.kb-continue-title{color:var(--text);font-size:.9rem;font-weight:600}.kb-continue-progress{color:var(--text-muted);font-size:.75rem;font-weight:600}.kb-continue-next{color:var(--text-muted);margin-top:8px;font-size:.78rem;display:block}.kb-empty{text-align:center;color:var(--text-muted);max-width:1200px;margin:0 auto;padding:80px 24px}.kb-empty svg{opacity:.3;margin-bottom:16px}.kb-empty h3{margin:0 0 8px;font-size:1.1rem}.kb-empty p{margin:0;font-size:.88rem}.kb-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);max-width:1200px;margin:0 auto;padding:32px 24px;font-size:.8rem}.kb-glossary-text{position:relative}.kb-glossary-term{border-bottom:1px dotted var(--text-muted);cursor:help;transition:color var(--duration-fast)}.kb-glossary-term:hover{color:var(--primary);border-color:var(--primary)}.kb-glossary-tooltip{z-index:1000;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);pointer-events:none;flex-direction:column;gap:4px;max-width:300px;padding:10px 14px;display:flex;box-shadow:0 8px 24px #0000004d}.kb-glossary-tooltip strong{color:var(--primary);font-size:.82rem}.kb-glossary-tooltip span{color:var(--text-dim);font-size:.78rem;line-height:1.5}.kb-interactive-svg{display:inline-flex;position:relative}.kb-interactive-svg [data-label]{cursor:pointer;transition:filter .2s,opacity .2s}.kb-interactive-svg [data-label]:hover,.kb-interactive-svg .kb-svg-highlight{filter:brightness(1.3)drop-shadow(0 0 6px #6366f180)}.kb-svg-tooltip{background:var(--bg-card);border:1px solid var(--primary);color:var(--text);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;z-index:10;padding:6px 12px;font-size:.78rem;position:absolute;transform:translate(-50%,-100%);box-shadow:0 4px 12px #0003}.kb-svg-tooltip:after{content:"";border:5px solid #0000;border-top-color:var(--primary);position:absolute;top:100%;left:50%;transform:translate(-50%)}.kb-comparison{margin-bottom:24px}.kb-comparison-table-wrap{-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}.kb-comparison-table{border-collapse:collapse;width:100%;font-size:.82rem}.kb-comparison-table th{text-align:center;background:var(--bg-input);border-bottom:1px solid var(--border);border-top:3px solid var(--primary);vertical-align:top;padding:16px 14px}.kb-comparison-title{margin-bottom:6px;font-size:.88rem;font-weight:700;display:block}.kb-comparison-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:10px 14px}.kb-comparison-table tr:last-child td{border-bottom:none}.kb-comparison-label{color:var(--text-dim);white-space:nowrap;background:var(--bg);z-index:1;align-items:center;gap:6px;min-width:120px;font-weight:600;display:flex;position:sticky;inset-inline-start:0}.kb-comparison-value{color:var(--text);text-align:center;direction:ltr;font-family:Courier New,monospace}.kb-comparison-pros span,.kb-comparison-cons span{padding:2px 0;font-size:.78rem;line-height:1.5;display:block}.kb-comparison-pros span{color:#22c55e}.kb-comparison-cons span{color:#ef4444}@keyframes kbFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes kbCardReveal{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes kbPulse{0%,to{opacity:1}50%{opacity:.75}}@keyframes kbSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes kbDrawLine{0%{stroke-dashoffset:100px}to{stroke-dashoffset:0}}.kb-content{animation:.4s both kbSlideUp}.kb-category-header{animation:.5s both kbFadeIn}.kb-article-detail-illust svg,.kb-category-header-illust svg,.kb-category-illust svg{animation:.6s both kbFadeIn}.kb-article-detail-illust svg rect,.kb-article-detail-illust svg path{transition:transform .3s,fill-opacity .3s,filter .3s}.kb-article-detail-illust svg rect:hover,.kb-article-detail-illust svg path:hover{fill-opacity:.7;filter:brightness(1.2)}.kb-article-detail-illust svg line,.kb-article-detail-illust svg polyline{stroke-dasharray:100;animation:1.5s both kbDrawLine}.kb-category-header-illust svg{transition:transform .3s}.kb-category-header-illust:hover svg{transform:scale(1.05)}@media (width<=1024px){.kb-categories-grid,.kb-articles-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.kb-categories-grid,.kb-articles-grid{grid-template-columns:1fr}.kb-nav-inner{padding:12px 16px}.kb-nav-stats{display:none}.kb-hero{min-height:220px;padding:40px 16px 32px}.kb-hero h2{font-size:1.6rem}.kb-hero p{font-size:.92rem}.kb-hero-glow{width:400px;height:300px}.kb-toolbar{padding:0 16px 16px}.kb-categories-grid,.kb-articles-grid{padding:0 16px 32px}.kb-category-header{padding:20px 16px 16px}.kb-article-detail{padding:0 16px 32px}.kb-article-detail-header h2{font-size:1.4rem}.kb-landing-section{padding:0 16px 20px}.kb-landing-scroll .kb-article-card{min-width:220px}.kb-quick-tags{gap:6px}.kb-article-nav{margin-top:20px}.kb-specs-grid{grid-template-columns:1fr}.kb-category-illust{height:120px}}@media (width<=480px){.kb-hero{min-height:180px;padding:32px 12px 24px}.kb-hero h2{font-size:1.3rem}.kb-hero-float-icon{display:none}.kb-toolbar{padding:0 12px 12px}.kb-filter-pills{justify-content:center;width:100%}.kb-categories-grid,.kb-articles-grid{gap:12px;padding:0 12px 24px}.kb-category-info{padding:14px 16px}.kb-article-card{padding:16px}.kb-article-detail{padding:0 12px 24px}.kb-summary-box{padding:12px 16px;font-size:.88rem}.kb-pros-cons-section,.kb-tips-cards{grid-template-columns:1fr}.kb-article-detail-illust-large{max-height:300px;padding:12px}}[data-theme=light] .kb-nav{background:#ffffffd9}[data-theme=light] .kb-category-card{box-shadow:0 2px 8px #0000000f}[data-theme=light] .kb-category-card:hover{box-shadow:0 12px 32px #0000001a,0 0 24px #6366f11a}[data-theme=light] .kb-article-card{box-shadow:0 1px 4px #0000000a}[data-theme=light] .kb-article-card:hover{box-shadow:0 8px 24px #00000014}[data-theme=light] .kb-summary-box{background:#6366f10d}[data-theme=light] .kb-tip-card{background:#f59e0b0d;border-color:#f59e0b1f}[data-theme=light] .kb-pros-card{background:#22c55e08}[data-theme=light] .kb-cons-card{background:#ef444408}[data-theme=light] .kb-article-detail-illust-large{background:#00000005;border-color:#00000014}[data-theme=light] .kb-hero-glow{background:radial-gradient(circle,#6366f11a 0%,#0000 70%)}[data-theme=light] .kb-hero-float-icon{opacity:.08}[data-theme=light] .kb-spec-item{background:#00000005}[data-theme=light] .kb-mark-read-done{background:#22c55e14}[data-theme=light] .kb-glossary-tooltip{box-shadow:0 8px 24px #0000001f}[data-theme=light] .kb-comparison-table th{background:#00000008}[data-theme=light] .kb-comparison-label,[data-theme=light] .kb-continue-item{background:#fff}[data-theme=light] .kb-autocomplete{box-shadow:0 8px 24px #0000001a}[data-theme=light] .kb-quick-tag{background:#0000000a;border-color:#0000001a}[data-theme=light] .kb-quick-tag:hover{background:#6366f114}@media print{.kb-nav,.kb-back-btn,.kb-breadcrumb,.kb-mark-read,.kb-article-actions,.kb-article-card-indicators{display:none!important}.kb-page{color:#000;background:#fff;min-height:auto}.kb-article-detail{max-width:100%;padding:0}.kb-collapsible-body{opacity:1!important;max-height:none!important}.kb-summary-box{background:#f5f5f5;border-color:#333!important}.kb-key-takeaway{background:#f0f0ff;border-color:#666}.kb-specs-grid{break-inside:avoid}.kb-spec-item{background:#f5f5f5;border-color:#ddd}.kb-pros-card,.kb-cons-card{background:0 0;border-color:#ddd}.kb-tip-card{background:#fffbeb;border-color:#e5c100}.kb-pros-cons-section{grid-template-columns:1fr 1fr}.kb-difficulty{border:1px solid}}[data-theme=light] .kb-key-takeaway{background:linear-gradient(135deg,#6366f10f 0%,#8b5cf608 100%);border-color:#6366f126}[data-theme=light] .kb-step-num{box-shadow:0 0 0 4px #fff}.kb-reading-progress{top:0;z-index:9999;pointer-events:none;background:0 0;width:100%;height:3px;position:fixed;inset-inline-start:0}.kb-reading-progress-fill{background:linear-gradient(90deg, var(--primary), #8b5cf6, #ec4899);will-change:width;border-radius:0 2px 2px 0;height:100%;transition:width .1s linear;box-shadow:0 0 8px #8b5cf680}.kb-back-to-top{bottom:28px;z-index:500;background:var(--bg-card);border:1px solid var(--border);width:44px;height:44px;color:var(--text-muted);cursor:pointer;opacity:0;transition:all .3s var(--ease);pointer-events:none;-webkit-backdrop-filter:blur(8px);border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;inset-inline-end:28px;transform:translateY(20px)scale(.8);box-shadow:0 4px 16px #0003}.kb-back-to-top-visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.kb-back-to-top:hover{color:var(--primary);border-color:var(--primary);box-shadow:0 6px 24px #0000004d, 0 0 16px var(--primary-glow);transform:translateY(-2px)scale(1.05)}.kb-progress-ring{flex-shrink:0}.kb-learning-paths{max-width:1200px;margin:0 auto;padding:0 24px 32px}.kb-paths-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.kb-path-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .35s var(--ease);animation:kbCardReveal .5s var(--ease) both;background:#ffffff08;flex-direction:column;gap:12px;padding:28px 24px;display:flex;position:relative;overflow:hidden}.kb-path-card:before{content:"";border-radius:inherit;background:conic-gradient(from 0deg, transparent 60%, var(--path-color,var(--primary)) 80%, transparent 100%);-webkit-mask-composite:xor;opacity:0;pointer-events:none;padding:1px;transition:opacity .4s;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.kb-path-card:hover:before{opacity:1;animation:3s linear infinite kbGradientSpin}.kb-path-card:hover{box-shadow:0 12px 40px #0000004d, 0 0 20px color-mix(in srgb, var(--path-color,var(--primary)) 20%, transparent);border-color:color-mix(in srgb, var(--path-color,var(--primary)) 40%, transparent);transform:translateY(-6px)}.kb-path-icon{background:color-mix(in srgb, var(--path-color,var(--primary)) 12%, transparent);width:56px;height:56px;color:var(--path-color,var(--primary));transition:transform .3s var(--ease);border-radius:16px;justify-content:center;align-items:center;display:flex}.kb-path-card:hover .kb-path-icon{transform:scale(1.1)rotate(-5deg)}.kb-path-card h4{color:var(--text);margin:0;font-size:1.05rem;font-weight:700}.kb-path-card p{color:var(--text-muted);margin:0;font-size:.84rem;line-height:1.5}.kb-path-categories{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.kb-path-cat-tag{border-radius:var(--radius-full);background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border);padding:3px 10px;font-size:.7rem;transition:all .2s}.kb-path-cat-tag:hover{color:var(--path-color,var(--primary));border-color:var(--path-color,var(--primary))}.kb-path-footer{align-items:center;gap:12px;margin-top:auto;display:flex}.kb-path-progress-bar{background:var(--bg-input);border-radius:2px;flex:1;height:4px;overflow:hidden}.kb-path-progress-fill{background:var(--path-color,var(--primary));border-radius:2px;height:100%;transition:width .6s}.kb-path-stats{color:var(--text-muted);white-space:nowrap;font-size:.72rem;font-weight:600}.kb-path-start-btn{border-radius:var(--radius);border:1px solid var(--path-color,var(--primary));background:color-mix(in srgb, var(--path-color,var(--primary)) 8%, transparent);color:var(--path-color,var(--primary));font-size:.84rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .25s var(--ease);justify-content:center;align-items:center;gap:6px;padding:10px 20px;display:flex}.kb-path-start-btn:hover{background:color-mix(in srgb, var(--path-color,var(--primary)) 18%, transparent);box-shadow:0 0 16px color-mix(in srgb, var(--path-color,var(--primary)) 25%, transparent);transform:translate(-4px)}.kb-progress-dashboard{max-width:1200px;margin:0 auto 24px;padding:0 24px}.kb-progress-dashboard-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:20px;padding:24px;animation:.5s both kbFadeIn;display:flex}.kb-progress-dashboard-info h4{color:var(--text);margin:0 0 4px;font-size:.95rem;font-weight:700}.kb-progress-dashboard-info p{color:var(--text-muted);margin:0;font-size:.82rem}.kb-progress-dashboard-stats{gap:16px;margin-inline-start:auto;display:flex}.kb-progress-stat{color:var(--text-dim);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.kb-progress-mini-rings{-webkit-overflow-scrolling:touch;gap:16px;padding:16px 24px;display:flex;overflow-x:auto}.kb-progress-mini-ring{cursor:pointer;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;transition:transform .2s;display:flex}.kb-progress-mini-ring:hover{transform:scale(1.08)}.kb-progress-mini-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;text-align:center;max-width:60px;font-size:.65rem;overflow:hidden}.kb-progress-suggested{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease);flex-direction:column;gap:4px;margin:0 24px;padding:14px 24px;display:flex}.kb-progress-suggested:hover{border-color:var(--primary);transform:translate(-4px)}.kb-progress-suggested-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;font-size:.72rem;display:flex}.kb-progress-suggested-title{color:var(--text);font-size:.9rem;font-weight:600}.kb-progress-suggested-cat{color:var(--text-muted);font-size:.72rem}.kb-hero-particle{background:var(--primary);opacity:0;pointer-events:none;z-index:0;width:3px;height:3px;animation:kbSawdust var(--duration,8s) var(--delay,0s) ease-in-out infinite;border-radius:50%;position:absolute}.kb-hero-particle:nth-child(odd){background:#f59e0b;border-radius:1px;width:2px;height:4px}.kb-hero-stats{z-index:1;gap:32px;margin-top:24px;display:flex;position:relative}.kb-hero-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.kb-hero-stat-number{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800;line-height:1.1}.kb-hero-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.72rem}.kb-glass{-webkit-backdrop-filter:blur(16px);background:#ffffff08;border:1px solid #ffffff0f}[data-theme=light] .kb-glass{background:#ffffffb3;border-color:#0000000f}.kb-gradient-text{background:linear-gradient(135deg, var(--primary), #8b5cf6, #ec4899);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;animation:4s infinite kbGradientShift}.kb-wood-bg{position:relative}.kb-wood-bg:after{content:"";pointer-events:none;z-index:0;border-radius:inherit;background:repeating-linear-gradient(90deg,#0000,#0000 40px,#8b5c2e08 40px 42px);position:absolute;inset:0}.kb-blueprint-bg{position:relative}.kb-blueprint-bg:after{content:"";pointer-events:none;z-index:0;border-radius:inherit;background-color:#0000;background-image:linear-gradient(#3b82f60a 1px,#0000 1px),linear-gradient(90deg,#3b82f60a 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:20px 20px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0}.kb-glow{box-shadow:0 0 20px var(--primary-glow), 0 0 40px #6366f114}.kb-shimmer{position:relative;overflow:hidden}.kb-shimmer:after{content:"";background:linear-gradient(90deg,#0000,#ffffff0a,#0000);animation:2s infinite kbShimmer;position:absolute;inset:0;transform:translate(-100%)}.kb-reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(24px)}.kb-reveal.kb-visible{opacity:1;transform:translateY(0)}.kb-category-card{transform-style:preserve-3d;perspective:1000px}.kb-article-card:before{transition:height .3s var(--ease), background .3s ease}.kb-article-card:hover:before{opacity:.08;height:100%}.kb-article-card-bookmark{transition:transform .2s var(--ease)}.kb-article-card-bookmark:hover{transform:scale(1.3)}@keyframes kbStarBurst{0%{transform:scale(1)}30%{transform:scale(1.4)}60%{transform:scale(.9)}to{transform:scale(1)}}.kb-bookmark-burst{animation:.4s kbStarBurst}.kb-search-results-header{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:8px 24px 16px;display:flex}.kb-search-results-header h3{color:var(--text-dim);margin:0;font-size:.9rem;font-weight:600}.kb-search-clear-btn{color:var(--primary);cursor:pointer;font-size:.82rem;font-family:var(--font);background:0 0;border:none;transition:opacity .2s}.kb-search-clear-btn:hover{opacity:.7}@keyframes kbGradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes kbGradientSpin{0%{--angle:0deg;transform:rotate(0)}to{--angle:360deg;transform:rotate(360deg)}}@keyframes kbShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes kbSawdust{0%{opacity:0;transform:translate3d(var(--x,0px), 100%, 0) rotate(0deg)}10%{opacity:.4}90%{opacity:.2}to{opacity:0;transform:translate3d(calc(var(--x,0px) + 40px), -20%, 0) rotate(360deg)}}@keyframes kbBounceIn{0%{opacity:0;transform:scale(.3)translateY(20px)}50%{opacity:1;transform:scale(1.05)translateY(-4px)}70%{transform:scale(.97)translateY(1px)}to{transform:scale(1)translateY(0)}}@keyframes kbSlideInStart{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes kbSlideInEnd{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes kbPulseGlow{0%,to{box-shadow:0 0 8px var(--glow-color,var(--primary-glow))}50%{box-shadow:0 0 20px var(--glow-color,var(--primary-glow)), 0 0 40px var(--glow-color,#6366f11a)}}@keyframes kbRipple{0%{opacity:.4;transform:scale(0)}to{opacity:0;transform:scale(4)}}@keyframes kbCountUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kb-difficulty.beginner{position:relative}.kb-difficulty.advanced{background:linear-gradient(135deg,#ef444426,#ef444414);box-shadow:0 0 8px #ef444426}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.kb-hero-particle,.kb-hero-float-icon{display:none!important}}@media (width<=1024px){.kb-paths-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.kb-paths-grid{grid-template-columns:1fr}.kb-progress-dashboard-header{flex-wrap:wrap;gap:12px;padding:16px}.kb-progress-dashboard-stats{justify-content:center;width:100%;margin-inline-start:0}.kb-hero-stats{gap:20px}.kb-hero-stat-number{font-size:1.4rem}.kb-learning-paths{padding:0 16px 24px}.kb-back-to-top{bottom:16px;inset-inline-end:16px}}@media (width<=480px){.kb-hero-stats{gap:16px}.kb-path-card{padding:20px 16px}}.kbs{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font);overflow-x:hidden}.kbs-prog{top:0;z-index:9999;pointer-events:none;width:100%;height:3px;position:fixed;inset-inline-start:0}.kbs-prog:after{content:"";height:100%;width:var(--w,0%);background:linear-gradient(90deg,#d97706,#f59e0b,#fbbf24);transition:width 80ms linear;display:block;box-shadow:0 0 16px #f59e0b99}.kbs-hero{align-items:flex-end;min-height:100svh;display:flex;position:relative;overflow:hidden}.kbs-hero-img{z-index:0;background-position:50%;background-size:cover;transition:transform 8s;animation:20s ease-in-out infinite alternate kbsZoom;position:absolute;inset:0;transform:scale(1.05)}@keyframes kbsZoom{0%{transform:scale(1)}to{transform:scale(1.08)}}.kbs-hero-overlay{z-index:1;background:linear-gradient(#00000026 0%,#0000004d 30%,#0009 60%,#000000eb 100%);position:absolute;inset:0}.kbs-hero-inner{z-index:2;width:100%;max-width:1100px;margin:0 auto;padding:32px 40px 64px;position:relative}.kbs-back{color:#ffffffb3;font-size:.82rem;font-family:var(--font);cursor:pointer;-webkit-backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #fff3;border-radius:40px;align-items:center;gap:8px;margin-bottom:40px;padding:10px 20px;transition:all .3s;display:inline-flex}.kbs-back:hover{color:#fff;background:#ffffff26;border-color:#fff6}.kbs-hero-text{max-width:700px}.kbs-hero-badges{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.kbs-badge{background:color-mix(in srgb, var(--badge-bg,#f59e0b) 25%, transparent);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid color-mix(in srgb, var(--badge-bg,#f59e0b) 35%, transparent);border-radius:24px;align-items:center;gap:5px;padding:6px 16px;font-size:.78rem;font-weight:600;display:inline-flex}.kbs-badge-muted{color:#ffffff80;border:1px solid #ffffff1a;border-radius:24px;align-items:center;gap:5px;padding:6px 16px;font-size:.78rem;display:inline-flex}.kbs-h1{color:#fff;letter-spacing:-.02em;margin:0 0 20px;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.15}.kbs-hero-summary{color:#ffffffa6;max-width:600px;margin:0;font-size:clamp(.95rem,1.8vw,1.15rem);line-height:1.8}.kbs-scroll-hint{color:#ffffff4d;justify-content:center;margin-top:48px;display:flex}.kbs-bounce{animation:2s ease-in-out infinite kbsBounce}@keyframes kbsBounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.kbs-section{padding:80px 0}.kbs-section-dark{background:var(--bg)}.kbs-section-accent{background:color-mix(in srgb, var(--accent,#d97706) 6%, var(--bg));border-top:1px solid color-mix(in srgb, var(--accent,#d97706) 15%, transparent);border-bottom:1px solid color-mix(in srgb, var(--accent,#d97706) 15%, transparent)}.kbs-container{max-width:900px;margin:0 auto;padding:0 32px}.kbs-overline{text-transform:uppercase;letter-spacing:2px;color:#f59e0b;margin-bottom:12px;font-size:.72rem;font-weight:700;display:block}.kbs-overline-light{color:#ffffff80}.kbs-h2{color:var(--text);letter-spacing:-.01em;margin:0 0 40px;font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;line-height:1.2}.kbs-h2-light{color:#fff}.kbs-big-text{color:var(--text-dim);max-width:720px;margin:0;font-size:clamp(1rem,2vw,1.25rem);line-height:2}.kbs-reveal{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(32px)}.kbs-vis{opacity:1;transform:translateY(0)}.kbs-takeaway{color:var(--text);align-items:flex-start;gap:24px;padding:40px 0;display:flex}.kbs-takeaway svg{color:var(--accent,#f59e0b);flex-shrink:0;margin-top:4px}.kbs-takeaway p{margin:0;font-size:clamp(1.1rem,2vw,1.4rem);font-weight:500;line-height:1.8}.kbs-split{grid-template-columns:1fr 1fr;align-items:center;gap:48px;max-width:1100px;margin:0 auto;padding:0 32px;display:grid}.kbs-split-content{flex-direction:column;display:flex}.kbs-specs{flex-direction:column;gap:0;display:flex}.kbs-spec{border-bottom:1px solid var(--border);align-items:baseline;gap:16px;padding:18px 0;display:flex}.kbs-spec:first-child{border-top:1px solid var(--border)}.kbs-spec-val{color:var(--text);direction:ltr;min-width:100px;font-family:Courier New,monospace;font-size:1.3rem;font-weight:800}.kbs-spec-lbl{color:var(--text-muted);font-size:.88rem}.kbs-split-img{aspect-ratio:4/3;border-radius:20px;overflow:hidden}.kbs-split-img img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.kbs-split-img:hover img{transform:scale(1.04)}.kbs-timeline{flex-direction:column;gap:0;display:flex;position:relative}.kbs-tl-item{align-items:flex-start;gap:24px;padding:24px 0;display:flex;position:relative}.kbs-tl-num{color:#fff;width:44px;height:44px;box-shadow:0 0 0 6px var(--bg), 0 4px 16px #0003;z-index:2;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:800;display:flex}.kbs-tl-line{inset-inline-start:21px;background:var(--border);z-index:1;width:2px;position:absolute;top:68px;bottom:-24px}.kbs-tl-item:last-child .kbs-tl-line{display:none}.kbs-tl-text{flex:1;padding-top:10px}.kbs-tl-text p{color:var(--text-dim);margin:0;font-size:1.05rem;line-height:1.8}.kbs-pc-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.kbs-pc{border-radius:20px;flex-direction:column;gap:16px;padding:32px;display:flex}.kbs-pc-pro{background:linear-gradient(160deg,#22c55e0f 0%,#16a34a05 100%);border:1px solid #22c55e26}.kbs-pc-con{background:linear-gradient(160deg,#ef44440f 0%,#dc262605 100%);border:1px solid #ef444426}.kbs-pc-head{color:#22c55e;border-bottom:1px solid #22c55e26;align-items:center;gap:12px;padding-bottom:16px;display:flex}.kbs-pc-head-con{color:#ef4444;border-color:#ef444426}.kbs-pc-head h3{margin:0;font-size:1.1rem;font-weight:700}.kbs-pc-item{color:var(--text-dim);align-items:flex-start;gap:12px;font-size:.92rem;line-height:1.7;display:flex}.kbs-pc-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:8px}.kbs-pc-dot-pro{background:#22c55e}.kbs-pc-dot-con{background:#ef4444}.kbs-section-tips{background-position:50%;background-size:cover;background-attachment:fixed;padding:100px 0;position:relative}@supports (-webkit-touch-callout:none){.kbs-section-tips{background-attachment:scroll}}.kbs-tips-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000d1;position:absolute;inset:0}.kbs-tips-inner{z-index:1;position:relative}.kbs-tips-list{flex-direction:column;gap:16px;display:flex}.kbs-tip{-webkit-backdrop-filter:blur(8px);background:#ffffff0d;border:1px solid #ffffff14;border-radius:16px;align-items:flex-start;gap:20px;padding:24px 28px;transition:all .3s;display:flex}.kbs-tip:hover{background:#ffffff17;border-color:#f59e0b4d;transform:translate(-6px)}.kbs-tip-idx{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.88rem;font-weight:800;display:flex}.kbs-tip p{color:#fffc;margin:0;padding-top:6px;font-size:.95rem;line-height:1.75}.kbs-actions-bar{justify-content:center;gap:12px;margin-bottom:48px;display:flex}.kbs-act{border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:.88rem;font-weight:600;font-family:var(--font);cursor:pointer;border-radius:48px;align-items:center;gap:8px;padding:14px 28px;transition:all .25s;display:flex}.kbs-act:hover{color:#f59e0b;border-color:#f59e0b;box-shadow:0 0 24px #f59e0b1a}.kbs-act-done{color:#22c55e;background:#22c55e14;border-color:#22c55e}.kbs-act-fav{color:#f59e0b;border-color:#f59e0b66}.kbs-next{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:16px;align-items:center;gap:16px;margin-bottom:40px;padding:24px 32px;transition:all .3s;display:flex}.kbs-next:hover{border-color:#f59e0b;transform:translate(-8px);box-shadow:0 8px 32px #00000026}.kbs-next-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:.72rem}.kbs-next-title{color:var(--text);flex:1;font-size:1.1rem;font-weight:700}.kbs-next svg{color:var(--text-muted);flex-shrink:0}.kbs-related-title{color:var(--text-dim);margin:0 0 16px;font-size:.85rem;font-weight:600}.kbs-related-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;display:grid}.kbs-related-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:4px;padding:16px 20px;transition:all .2s;display:flex}.kbs-related-card:hover{border-color:var(--primary);transform:translateY(-2px)}.kbs-related-name{color:var(--text);font-size:.88rem;font-weight:600}.kbs-related-cat{color:var(--text-muted);font-size:.72rem}.kbs-top{bottom:28px;z-index:500;background:var(--bg-card);border:1px solid var(--border);width:48px;height:48px;color:var(--text-muted);cursor:pointer;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex;position:fixed;inset-inline-end:28px;transform:translateY(16px);box-shadow:0 4px 20px #00000040}.kbs-top-show{opacity:1;pointer-events:auto;transform:translateY(0)}.kbs-top:hover{color:#f59e0b;border-color:#f59e0b;transform:translateY(-2px)}@media (width<=768px){.kbs-hero-inner{padding:20px 20px 48px}.kbs-h1{font-size:1.8rem}.kbs-section{padding:56px 0}.kbs-container{padding:0 20px}.kbs-split{grid-template-columns:1fr;gap:32px;padding:0 20px}.kbs-split-img{max-height:300px}.kbs-pc-grid{grid-template-columns:1fr}.kbs-actions-bar{flex-wrap:wrap}.kbs-act{padding:12px 20px;font-size:.82rem}.kbs-section-tips{background-attachment:scroll}.kbs-next{flex-direction:column;align-items:flex-start;gap:8px}.kbs-tl-num{width:36px;height:36px;font-size:.88rem}}@media (width<=480px){.kbs-hero-inner{padding:16px 16px 40px}.kbs-h1{font-size:1.5rem}.kbs-section{padding:40px 0}.kbs-container{padding:0 16px}.kbs-spec-val{min-width:80px;font-size:1rem}.kbs-pc{border-radius:14px;padding:24px 20px}.kbs-tip{padding:18px 16px}.kbs-back{padding:8px 16px;font-size:.78rem}}[data-theme=light] .kbs-section-dark{background:#fafafa}[data-theme=light] .kbs-section-accent{background:color-mix(in srgb, var(--accent,#d97706) 4%, #fafafa)}[data-theme=light] .kbs-big-text{color:#444}[data-theme=light] .kbs-tl-text p{color:#555}[data-theme=light] .kbs-spec-card{box-shadow:0 2px 8px #0000000a}[data-theme=light] .kbs-pc-pro{background:#22c55e08}[data-theme=light] .kbs-pc-con{background:#ef444408}[data-theme=light] .kbs-tip{background:#0009}[data-theme=light] .kbs-next{box-shadow:0 2px 8px #0000000d}@media print{.kbs-prog,.kbs-top,.kbs-actions-bar,.kbs-scroll-hint{display:none!important}.kbs-hero{height:auto;min-height:auto}.kbs-hero-img,.kbs-hero-overlay{display:none}.kbs-hero-inner{padding:20px}.kbs-h1{color:#000;font-size:1.6rem}.kbs-hero-summary{color:#333}.kbs-section{padding:20px 0}.kbs-reveal{opacity:1!important;transform:none!important}.kbs-section-tips{background-image:none!important}.kbs-tips-overlay{display:none}.kbs-tip{background:#f5f5f5;border-color:#ddd}.kbs-tip p{color:#333}}@media (prefers-reduced-motion:reduce){.kbs-hero-img{animation:none}.kbs-reveal{opacity:1;transition:none;transform:none}.kbs-bounce{animation:none}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font:"Heebo", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--primary:#3b82f6;--primary-hover:#60a5fa;--primary-glow:#3b82f633;--primary-subtle:#3b82f612;--primary-muted:#3b82f61f;--accent:#f59e0b;--accent-subtle:#f59e0b14;--success:#22c55e;--success-subtle:#22c55e14;--danger:#ef4444;--danger-subtle:#ef444414;--bg:#121417;--bg-sidebar:#1a1d21;--bg-card:#22262b;--bg-input:#16181c;--bg-overlay:#121417e6;--bg-glass:#1a1d21b3;--border:#2e3238;--border-light:#3d4249;--border-row:#2e323899;--text:#e8eaed;--text-dim:#9aa0a6;--text-muted:#6b7280;--radius-xs:4px;--radius-sm:6px;--radius:8px;--radius-lg:10px;--radius-xl:12px;--radius-full:9999px;--shadow-sm:0 1px 2px #00000040;--shadow:0 2px 8px #0000004d;--shadow-lg:0 6px 16px #00000059;--shadow-xl:0 12px 32px #0006;--ease:cubic-bezier(.4, 0, .2, 1);--ease-bounce:cubic-bezier(.68, -.55, .265, 1.55);--duration-fast:.15s;--duration-normal:.3s;--duration-slow:.5s;--gradient-primary:linear-gradient(135deg, #2563eb, #3b82f6);--gradient-cta:linear-gradient(135deg, #2563eb, #1d4ed8);--logo-text-grd:linear-gradient(135deg, #93c5fd, #bfdbfe)}:root[data-theme=light]{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-glow:#2563eb1f;--primary-subtle:#2563eb0d;--primary-muted:#2563eb1a;--accent:#d97706;--accent-subtle:#d977060f;--success:#16a34a;--success-subtle:#16a34a0f;--danger:#dc2626;--danger-subtle:#dc26260f;--bg:#f3f4f6;--bg-sidebar:#fff;--bg-card:#f9fafb;--bg-input:#e5e7eb;--bg-overlay:#fffffff2;--bg-glass:#fffc;--border:#d1d5db;--border-light:#9ca3af;--border-row:#d1d5db80;--text:#111827;--text-dim:#4b5563;--text-muted:#6b7280;--shadow-sm:0 1px 2px #0000000d;--shadow:0 2px 6px #00000012;--shadow-lg:0 6px 16px #00000017;--shadow-xl:0 12px 24px #0000001a;--gradient-primary:linear-gradient(135deg, #2563eb, #1d4ed8);--gradient-cta:linear-gradient(135deg, #2563eb, #1e40af);--logo-text-grd:linear-gradient(135deg, #1e40af, #1d4ed8)}html,body{height:100%}:is(body:has(.landing-page),body:has(.dash-page),body:has(.kb-page)){overflow:auto}body:not(:has(.landing-page)):not(:has(.dash-page)):not(:has(.kb-page)){overflow:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{height:100vh;display:flex}.step{animation:stepIn .4s var(--ease);display:none}.step.active{display:block}@keyframes stepIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.step-title{align-items:center;gap:8px;margin-bottom:18px;font-size:1.1rem;font-weight:700;display:flex}.type-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.type-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:all .25s var(--ease);flex-direction:column;align-items:center;gap:10px;padding:22px 14px 16px;display:flex}.type-card:hover{border-color:var(--border-light);transform:translateY(-3px);box-shadow:0 8px 24px #0000004d}.type-card.selected{border-color:var(--primary);box-shadow:0 0 12px var(--primary-glow), inset 0 0 0 1px #3b82f61f;background:#3b82f614}.type-icon{background:#3b82f61a;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.type-card.selected .type-icon{background:#3b82f633}.type-icon svg{width:26px;height:26px;color:var(--primary-hover)}.type-name{font-size:.95rem;font-weight:700}.type-desc{color:var(--text-muted);font-size:.72rem}.comp-list{flex-direction:column;gap:6px;display:flex}.comp-item{background:var(--bg-card);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease);border:1px solid #0000;align-items:center;gap:12px;padding:12px 14px;display:flex}.comp-item:hover{border-color:var(--border)}.comp-check{flex-shrink:0;position:relative}.comp-check input{display:none}.checkbox-ui{border:2px solid var(--border-light);background:var(--bg-input);width:22px;height:22px;transition:all .2s var(--ease);border-radius:6px;justify-content:center;align-items:center;display:flex}.checkbox-ui svg{color:#fff;opacity:0;width:14px;height:14px;transition:opacity .15s}.comp-check input:checked+.checkbox-ui{background:var(--primary);border-color:var(--primary);box-shadow:0 0 8px var(--primary-glow)}.comp-check input:checked+.checkbox-ui svg{opacity:1}.comp-icon{background:#3b82f614;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.comp-icon svg{width:18px;height:18px;color:var(--text-dim)}.comp-info{flex:1;min-width:0}.comp-name{font-size:.88rem;font-weight:600;display:block}.comp-desc{color:var(--text-muted);font-size:.7rem;display:block}.comp-count{align-items:center;gap:2px;display:flex}.count-btn{background:var(--bg-input);border:1px solid var(--border);width:30px;height:30px;color:var(--text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;transition:all .15s;display:flex}.count-btn:hover{background:var(--primary);border-color:var(--primary)}.count-input{text-align:center;width:40px;color:var(--text);font-size:.95rem;font-weight:700;font-family:var(--font);background:0 0;border:none}.count-input::-webkit-inner-spin-button{display:none}.door-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-family:var(--font);cursor:pointer;padding:6px 12px;font-size:.8rem}.door-select:focus{border-color:var(--primary);outline:none}.comp-item.custom{cursor:default}.custom-input{color:var(--text);font-size:.85rem;font-family:var(--font);background:0 0;border:none;flex:1}.custom-input:focus{outline:none}.custom-input::placeholder{color:var(--text-muted)}.dim-section{margin-bottom:22px}.dim-header{color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;margin-bottom:14px;font-size:.8rem;font-weight:700;display:flex}.dim-header-icon{display:flex}.dim-header-icon svg{width:16px;height:16px;color:var(--primary-hover)}.dim-grid{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.dim-field label{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;font-weight:500;display:block}.dim-input-wrap{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.dim-input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.dim-input-wrap input{width:100%;color:var(--text);font-size:.95rem;font-family:var(--font);text-align:center;background:0 0;border:none;flex:1;padding:10px 12px}.dim-input-wrap input:focus{outline:none}.dim-input-wrap input::-webkit-inner-spin-button{display:none}.dim-unit{color:var(--text-muted);border-right:1px solid var(--border);background:#ffffff08;align-self:stretch;align-items:center;padding:0 10px;font-size:.7rem;display:flex}.dim-preview{justify-content:center;margin-top:20px;display:flex}.mini-box{border:2px solid var(--primary);width:160px;height:120px;transition:all .4s var(--ease);background:#3b82f60f;border-radius:4px;position:relative;transform:perspective(400px)rotateY(-8deg)rotateX(4deg)}.mini-label{color:var(--primary-hover);background:var(--bg-sidebar);border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:700;position:absolute}.mini-label.top{top:-10px;left:50%;transform:translate(-50%)}.mini-label.side{top:50%;right:-36px;transform:translateY(-50%)}.mini-label.depth{color:var(--text-muted);font-size:.6rem;bottom:-10px;left:50%;transform:translate(-50%)}.view-switcher{background:var(--bg-card);border-radius:var(--radius-sm);gap:4px;margin-bottom:16px;padding:4px;display:flex}.view-btn{color:var(--text-muted);border-radius:var(--radius-xs);cursor:pointer;transition:all .2s var(--ease);font-size:.82rem;font-weight:600;font-family:var(--font);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;display:flex}.view-btn:hover{color:var(--text-dim);background:#ffffff08}.view-btn.active{background:var(--primary);color:#fff;box-shadow:0 2px 12px var(--primary-glow)}.view-icon svg{width:16px;height:16px}.export-buttons{flex-direction:column;gap:8px;display:flex}.export-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;text-align:right;transition:all .25s var(--ease);font-family:var(--font);align-items:center;gap:14px;padding:14px 18px;display:flex}.export-btn:hover{border-color:var(--border-light);transform:translateY(-1px);box-shadow:0 4px 20px #0000004d}.export-btn.primary{background:var(--gradient-cta);border-color:#0000}.export-btn.primary:hover{box-shadow:0 4px 24px var(--primary-glow)}.export-btn strong{font-size:.9rem;display:block}.export-btn small{color:var(--text-dim);opacity:.7;font-size:.7rem;display:block}.export-icon{background:#ffffff14;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.export-icon svg{width:20px;height:20px}.cutlist-wrap{max-height:280px;margin-top:14px;overflow-y:auto}.cutlist-wrap.hidden{display:none}.cutlist-wrap table{border-collapse:collapse;width:100%;font-size:.75rem}.cutlist-wrap th{background:var(--bg-sidebar);text-align:right;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:8px 10px;font-size:.7rem;font-weight:700;position:sticky;top:0}.cutlist-wrap td{border-bottom:1px solid #2a2d4a80;padding:8px 10px}.cutlist-wrap tr:hover td{background:#3b82f60d}.part-color{vertical-align:middle;border-radius:3px;width:10px;height:10px;margin-left:6px;display:inline-block}.viewer{background:var(--bg);flex:1;position:relative;overflow:hidden}.viewer-3d{display:none;position:absolute;inset:0}.viewer-3d.active{display:block}.viewer-3d canvas{display:block;width:100%!important;height:100%!important}.viewer-2d{background:var(--bg);display:none;position:absolute;inset:0}.viewer-2d.active{display:block}.viewer-cutlist{background:var(--bg);direction:rtl;padding:24px;display:none;position:absolute;inset:0;overflow-y:auto}.viewer-cutlist.active{display:block}.viewer-cutlist table{border-collapse:collapse;width:100%;max-width:900px;margin:0 auto;font-size:.82rem}.viewer-cutlist .cutlist-title{color:var(--text);text-align:center;margin-bottom:16px;font-size:1.1rem;font-weight:700}.viewer-cutlist th{background:var(--bg-sidebar);text-align:right;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);z-index:1;padding:10px 12px;font-size:.75rem;font-weight:700;position:sticky;top:0}.viewer-cutlist td{border-bottom:1px solid var(--border-row);color:var(--text);padding:10px 12px}.viewer-cutlist tr:hover td{background:var(--primary-subtle)}.viewer-cutlist .part-color{vertical-align:middle;border-radius:3px;width:10px;height:10px;margin-left:6px;display:inline-block}.viewer-cutlist .eb-yes{color:var(--success)}.viewer-cutlist .eb-no{color:var(--text-muted)}.viewer-empty{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.viewer-empty.hidden{display:none}.empty-content{text-align:center}.empty-icon svg{width:80px;height:80px;color:var(--border-light);animation:3s ease-in-out infinite pulse}.empty-content h2{background:linear-gradient(135deg, var(--text-dim), var(--text-muted));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:16px 0 8px;font-size:1.4rem}.empty-content p{color:var(--text-muted);font-size:.88rem}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes loadingBar{0%{width:40px}to{width:120px}}.viewer-toolbar{z-index:10;flex-direction:column;gap:6px;display:flex;position:absolute;top:68px;left:16px}.tool-btn{border-radius:var(--radius-sm);background:var(--bg-overlay);border:1px solid var(--border);width:40px;height:40px;color:var(--text-dim);cursor:pointer;transition:all var(--duration-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;display:flex}.tool-btn:hover{color:var(--text);border-color:var(--primary);background:var(--primary-muted)}.tool-btn svg{width:18px;height:18px}.type-grid-2{grid-template-columns:1fr 1fr}.type-grid-3{grid-template-columns:1fr 1fr 1fr}.wardrobe-section-counter{justify-content:center;align-items:center;gap:18px;margin:8px 0 20px;display:flex}.count-btn:disabled{opacity:.3;pointer-events:none}.wardrobe-section-display{text-align:center;min-width:80px}.wardrobe-section-num{color:var(--primary-hover);font-size:2.4rem;font-weight:800;line-height:1;display:block}.wardrobe-section-label{color:var(--text-muted);margin-top:2px;font-size:.72rem;display:block}.wardrobe-preview-sections{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);gap:4px;height:140px;padding:6px;display:flex;overflow:hidden}.wardrobe-preview-col{border:1px solid var(--border-light);background:#3b82f60a;border-radius:4px;flex-direction:column;flex:1;gap:4px;padding:6px 4px;display:flex;position:relative;overflow:hidden}.wardrobe-preview-rod{background:linear-gradient(90deg,#788fa0,#a8b8c8,#788fa0);border-radius:3px;flex-shrink:0;height:6px;box-shadow:0 1px 4px #0000004d}.wardrobe-preview-shelves{flex-direction:column;flex:1;justify-content:flex-end;gap:6px;display:flex}.wardrobe-preview-shelf{background:#c4956a99;border-radius:2px;height:4px}.wardrobe-preview-col.has-rod{background:#3b82f60f;border-color:#3b82f680}.wardrobe-section-rod-grid{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.wardrobe-rod-toggle{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;min-width:44px;max-width:72px;transition:all .2s var(--ease);font-family:var(--font);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 6px;display:flex}.wardrobe-rod-toggle:hover{border-color:var(--border-light);transform:translateY(-1px)}.wardrobe-rod-toggle.active{border-color:var(--primary);box-shadow:0 0 8px var(--primary-glow);background:#3b82f61a}.wrt-num{color:var(--text-muted);font-size:.68rem;font-weight:700}.wrt-label{font-size:1rem;line-height:1}.wardrobe-front-view{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-input);align-items:stretch;gap:0;height:160px;margin-bottom:0;display:flex;overflow:hidden}.wfv-side{background:#c4956a73;flex-shrink:0;width:10px}.wfv-col{cursor:pointer;transition:background .15s var(--ease);background:#3b82f608;border-right:4px solid #c4956a59;flex-direction:column;flex:1;min-width:0;padding:6px 4px 18px;display:flex;position:relative}.wfv-col:last-child{border-right:none}.wfv-col:hover{background:#3b82f612}.wfv-col.selected{border-right-color:var(--primary);box-shadow:inset 0 0 0 1.5px var(--primary);background:#3b82f61f}.wfv-rod{flex-shrink:0;padding:4px 6px 0}.wfv-rod-bar{background:linear-gradient(90deg,#788fa0,#c0d0dc,#788fa0);border-radius:3px;height:5px;box-shadow:0 1px 4px #00000059}.wfv-drawers{flex-direction:column;gap:3px;padding:4px 4px 2px;display:flex}.wfv-drawer{background:#c4956a40;border:1px solid #c4956a80;border-radius:2px;flex:1;min-height:10px}.wfv-shelves{flex-direction:column;flex:1;justify-content:space-evenly;padding:0 4px;display:flex}.wfv-shelf{background:#c4956a8c;border-radius:2px;height:3px}.wfv-label{color:var(--text-muted);font-size:.65rem;font-weight:800;position:absolute;bottom:3px;left:50%;transform:translate(-50%)}.wardrobe-sec-editor{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.wardrobe-sec-editor-title{color:var(--text-dim);border-bottom:1px solid var(--border);background:#3b82f612;padding:8px 14px;font-size:.82rem;font-weight:700}.wardrobe-sec-editor-grid{flex-direction:column;gap:0;display:flex}.wseg-item{border-bottom:1px solid #2a2d4a66;flex-wrap:wrap;align-items:center;gap:10px;padding:9px 14px;display:flex}.wseg-item:last-child{border-bottom:none}.wseg-label{color:var(--text-dim);flex:1;min-width:100px;font-size:.8rem;font-weight:600}.wardrobe-sec-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.wardrobe-sec-card.has-rod{border-color:#3b82f673}.wardrobe-sec-header{border-bottom:1px solid var(--border);background:#0000000f;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.wardrobe-sec-num{color:var(--text-dim);font-size:.8rem;font-weight:700}.wardrobe-sec-body{flex-wrap:wrap;gap:12px;padding:10px 12px;display:flex}.type-info{align-items:center;gap:var(--space-3);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--primary-subtle);border-radius:var(--radius-sm);border:1px solid var(--primary-muted);display:flex}.type-info .info-badge svg{width:16px;height:16px;color:var(--primary-hover);flex-shrink:0}.type-info span{color:var(--text-dim);font-size:.8rem}.section-divider{background:var(--border);height:1px;margin:18px 0}.sub-title{color:var(--text-dim);align-items:center;gap:8px;margin-bottom:12px;font-size:.85rem;font-weight:700;display:flex}.sub-title svg{width:16px;height:16px;color:var(--primary-hover)}.assembly-options{flex-direction:column;gap:8px;display:flex}.assembly-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease);color:var(--text);font-family:var(--font);align-items:center;gap:12px;padding:14px 16px;display:flex}.assembly-card:hover{border-color:var(--border-light);background:#3b82f60a}.assembly-card.selected{border-color:var(--primary);background:var(--primary-subtle)}.assembly-icon{background:#3b82f61a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.assembly-icon svg{width:18px;height:18px;color:var(--primary-hover)}.assembly-card strong{color:var(--text);font-size:.85rem;display:block}.assembly-card small{color:var(--text-muted);margin-top:2px;font-size:.7rem;display:block}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.steps-container input[type=number],.steps-container input[type=text],.steps-container select,.editor-panel-body input[type=number],.editor-panel-body input[type=text],.editor-panel-body select{font-family:var(--font);color:var(--text);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);outline:none;transition:border-color .2s}.steps-container input[type=number]:focus,.steps-container input[type=text]:focus,.steps-container select:focus,.editor-panel-body input[type=number]:focus,.editor-panel-body input[type=text]:focus,.editor-panel-body select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.material-section{margin-bottom:4px}.material-cards{gap:8px;margin-bottom:12px;display:flex}.material-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:center;transition:all .2s var(--ease);flex:1;padding:14px}.material-card:hover{border-color:var(--border-light)}.material-card.selected{border-color:var(--primary);background:var(--primary-subtle)}.material-card strong{margin-bottom:4px;font-size:.9rem;display:block}.material-card small{color:var(--text-muted);font-size:.7rem}.thickness-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.thickness-row label{color:var(--text);white-space:nowrap;font-size:.85rem}.thickness-row .dim-input-wrap{min-width:160px;max-width:180px}.thickness-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-family:var(--font);cursor:pointer;min-width:100px;padding:8px 14px;font-size:.85rem}.thickness-select.wide{min-width:200px}.thickness-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);outline:none}.catalog-browser{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:14px;padding:14px}.catalog-header{margin-bottom:10px}.catalog-title{color:var(--text);align-items:center;gap:6px;margin:0 0 8px;font-size:.85rem;font-weight:600;display:flex}.catalog-tabs{gap:4px;display:flex}.catalog-tab{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;color:var(--text-muted);transition:all .2s var(--ease);font-size:.75rem;font-weight:600;font-family:var(--font);padding:5px 12px}.catalog-tab:hover{border-color:var(--border-light);color:var(--text)}.catalog-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.catalog-search{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-muted);align-items:center;gap:6px;margin-bottom:10px;padding:6px 10px;display:flex}.catalog-search input{color:var(--text);font-size:.8rem;font-family:var(--font);background:0 0;border:none;outline:none;flex:1}.catalog-search-clear{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:2px;display:flex}.catalog-grid{scrollbar-width:thin;scrollbar-color:var(--border) transparent;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px;max-height:280px;display:grid;overflow-y:auto}.catalog-swatch{background:var(--bg-input);border:2px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;transition:all .15s var(--ease);font-family:var(--font);flex-direction:column;align-items:center;gap:3px;padding:6px 4px;display:flex}.catalog-swatch:hover{border-color:var(--border-light);transform:translateY(-1px)}.catalog-swatch.selected{border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 2px var(--primary-glow)}.swatch-color{border:1px solid #ffffff1f;border-radius:6px;width:36px;height:36px;box-shadow:inset 0 1px 2px #00000026}.swatch-code{color:var(--text);font-size:.65rem;font-weight:700;line-height:1}.swatch-name{color:var(--text-muted);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.58rem;line-height:1.1;overflow:hidden}.catalog-empty{text-align:center;color:var(--text-muted);padding:20px;font-size:.8rem}.preset-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px;margin-bottom:12px;display:grid}.preset-btn{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease);font-family:var(--font);flex-direction:column;align-items:center;gap:5px;padding:10px 6px;display:flex}.preset-btn:hover{border-color:var(--border-light)}.preset-btn.selected{border-color:var(--primary);background:var(--primary-subtle)}.preset-btn small{color:var(--text);font-size:.72rem;font-weight:600}.preset-swatches{gap:3px;display:flex}.preset-dot{border:2px solid #ffffff26;border-radius:6px;width:22px;height:22px}.hw-note{font-size:var(--text-xs);color:var(--accent);margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--accent-subtle);border-radius:var(--radius-xs);border:1px solid #f59e0b33}.hw-note.hidden{display:none}.hw-section{margin-bottom:8px}.hw-cards{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.hw-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease);padding:12px 14px}.hw-card:hover{border-color:var(--border-light)}.hw-card.selected{border-color:var(--primary);background:#3b82f614}.hw-card strong{font-size:.85rem;display:block}.hw-card small{color:var(--text-muted);font-size:.7rem}.hw-options{margin-bottom:12px;overflow:hidden}.hw-options label:not(.hw-toggle){color:var(--text);margin-bottom:6px;font-size:.82rem;display:block}.hw-options h4{color:var(--text-dim);margin-bottom:8px;font-size:.8rem}.hw-toggle{cursor:pointer;align-items:center;gap:10px;padding:8px 0;display:flex}.hw-toggle input{display:none}.hw-toggle>span:last-child{flex:1;min-width:0;font-size:.82rem}.toggle-ui{background:var(--border);border-radius:11px;flex-shrink:0;width:38px;height:22px;transition:background .2s;position:relative}.toggle-ui:after{content:"";background:var(--text-dim);border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;top:3px;left:3px}.hw-toggle input:checked+.toggle-ui{background:var(--primary)}.hw-toggle input:checked+.toggle-ui:after{background:#fff;left:19px}.drawer-type-cards{gap:8px;display:flex}.drawer-type-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:center;transition:all .2s var(--ease);flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 10px;display:flex}.drawer-type-card:hover{border-color:var(--border-light)}.drawer-type-card.selected{border-color:var(--primary);background:var(--primary-subtle)}.drawer-type-card svg{width:24px;height:24px;color:var(--primary-hover)}.drawer-type-card strong{font-size:.82rem}.drawer-type-card small{color:var(--text-muted);font-size:.65rem}.handle-type-cards{gap:8px;display:flex}.handle-type-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:center;transition:all .2s var(--ease);flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px 8px;display:flex}.handle-type-card:hover{border-color:var(--border-light)}.handle-type-card.selected{border-color:var(--primary);background:var(--primary-subtle)}.handle-type-card svg{width:20px;height:20px;color:var(--primary-hover)}.handle-type-card strong{font-size:.8rem}.handle-type-card small{color:var(--text-muted);font-size:.62rem}.handle-type-card.disabled{opacity:.35;pointer-events:none;border-color:var(--border);background:var(--bg-card)}.hinge-pos-cards{gap:8px;display:flex}.hinge-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease);flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;display:flex}.hinge-card:hover{border-color:var(--border-light)}.hinge-card.selected{border-color:var(--primary);background:var(--primary-subtle)}.hinge-card svg{width:18px;height:18px;color:var(--primary-hover)}.hinge-card span:last-child{font-size:.82rem;font-weight:600}.export-mode{background:var(--bg-card);border-radius:var(--radius-xs);gap:16px;margin-top:-4px;padding:8px 14px;display:flex}.export-mode label{color:var(--text-dim);cursor:pointer;align-items:center;gap:6px;font-size:.8rem;display:flex}.export-mode input[type=radio]{accent-color:var(--primary)}.toolbar-separator{background:var(--border);width:24px;height:1px;margin:4px 8px}.materials-summary{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:24px;padding:16px}.materials-summary h3{color:var(--text-dim);margin-bottom:12px;font-size:.9rem;font-weight:500}.part-editor{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);z-index:50;width:340px;max-height:calc(100vh - 120px);transition:opacity .3s var(--ease), transform .3s var(--ease);flex-direction:column;display:flex;position:absolute;top:24px;right:24px;overflow:hidden;box-shadow:0 10px 40px #00000026}.part-editor.hidden{opacity:0;pointer-events:none;transform:translateY(-10px)}.pe-container{flex-direction:column;height:100%;max-height:calc(100vh - 140px);display:flex}.pe-empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:32px 16px;font-size:.85rem;display:flex}.pe-header{background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:8px;padding:12px 14px;display:flex}.pe-header-info{flex:1;min-width:0}.pe-header h3{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 4px;font-size:.9rem;font-weight:700;overflow:hidden}.pe-header-actions{flex-shrink:0;gap:4px;display:flex}.pe-badges{flex-wrap:wrap;gap:4px;display:flex}.pe-badge{border-radius:4px;align-items:center;padding:1px 6px;font-size:.65rem;font-weight:600;display:inline-flex}.pe-badge-type{color:#10b981;background:#10b9811a}.pe-badge-material{color:var(--primary);background:#3b82f61a}.pe-badge-ops{color:#f59e0b;background:#f59e0b1a}.pe-tabs{border-bottom:1px solid var(--border);background:var(--bg);padding:0 6px;display:flex}.pe-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 4px;font-size:.7rem;font-weight:600;transition:all .15s;display:flex}.pe-tab:hover{color:var(--text)}.pe-tab-active{color:var(--primary);border-bottom-color:var(--primary)}.pe-content{scrollbar-width:thin;flex:1;overflow-y:auto}.pe-tab-content{padding:10px 12px}.pe-section{margin-bottom:12px}.pe-section-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:4px;margin-bottom:6px;font-size:.7rem;font-weight:700;display:flex}.pe-section-label{color:var(--text-dim);margin-bottom:4px;font-size:.68rem;font-weight:600;display:block}.pe-fields-row{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.pe-field{flex:1;margin-bottom:4px}.pe-field label{color:var(--text-dim);margin-bottom:2px;font-size:.68rem;font-weight:600;display:block}.pe-field-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);align-items:center;display:flex;overflow:hidden}.pe-field-input input{width:100%;color:var(--text);background:0 0;border:none;flex:1;min-width:0;padding:5px 6px;font-size:.8rem}.pe-field-input input:focus{outline:none}.pe-field-input:focus-within{border-color:var(--primary)}.pe-unit{color:var(--text-dim);flex-shrink:0;padding:0 5px;font-size:.65rem}.pe-field input,.pe-select{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);width:100%;color:var(--text);padding:5px 6px;font-size:.8rem}.pe-toggle{color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:4px 0;font-size:.78rem;display:flex}.pe-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary)}.pe-apply-btn{background:var(--primary);color:#fff;border-radius:var(--radius-xs);cursor:pointer;border:none;justify-content:center;align-items:center;gap:6px;width:100%;margin-top:8px;padding:8px;font-size:.8rem;font-weight:600;transition:background .15s;display:flex}.pe-apply-btn:hover{background:var(--primary-hover)}.pe-icon-btn{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);width:28px;height:28px;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.pe-icon-btn:hover{color:var(--text);background:var(--bg-hover)}.pe-icon-btn:disabled{opacity:.35;cursor:not-allowed}.pe-icon-btn.pe-active{background:var(--primary-subtle);color:var(--primary)}.pe-icon-btn.pe-danger:hover{color:#ef4444;border-color:#ef44444d}.pe-edge-grid{flex-wrap:wrap;gap:4px;display:flex}.pe-edge-badge{border-radius:3px;padding:2px 6px;font-size:.65rem;font-weight:600}.pe-edge-on{color:#10b981;background:#10b9811a}.pe-edge-off{color:#6b7280;background:#6b72801a;text-decoration:line-through}.pe-undo-bar{border-bottom:1px solid var(--border);align-items:center;gap:4px;margin-bottom:8px;padding-bottom:8px;display:flex}.pe-ops-count{color:var(--text-dim);margin-inline-start:auto;font-size:.68rem}.pe-add-menu-wrap{margin-bottom:8px;position:relative}.pe-add-btn{border:1px dashed var(--border);border-radius:var(--radius-xs);width:100%;color:var(--primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:5px;padding:7px;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.pe-add-btn:hover{background:var(--primary-subtle);border-color:var(--primary)}.pe-add-dropdown{z-index:10;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xs);margin-top:2px;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #00000026}.pe-add-option{width:100%;color:var(--text);cursor:pointer;text-align:start;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-size:.8rem;display:flex}.pe-add-option:hover{background:var(--bg-hover)}.pe-operation-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);margin-bottom:6px;transition:border-color .15s;overflow:hidden}.pe-operation-card:hover{border-color:var(--primary)}.pe-op-warning{border-color:#f59e0b66}.pe-op-header{cursor:pointer;justify-content:space-between;align-items:center;gap:6px;padding:7px 10px;display:flex}.pe-op-title{color:var(--text);align-items:center;gap:6px;min-width:0;font-size:.78rem;font-weight:600;display:flex}.pe-op-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.pe-source-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:3px;padding:1px 5px;font-size:.6rem;font-weight:700}.pe-source-auto{color:var(--primary);background:#3b82f61a}.pe-source-manual{color:#10b981;background:#10b9811a}.pe-op-body{border-top:1px solid var(--border);padding:8px 10px}.pe-params-grid{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.pe-validation-errors{margin-bottom:6px}.pe-validation-error{color:#f59e0b;align-items:center;gap:4px;padding:3px 0;font-size:.7rem;display:flex}.pe-reference-section{border-top:1px solid var(--border);margin-top:8px;padding-top:8px}.pe-ops-group{margin-bottom:10px}.pe-ops-group-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;padding-inline-start:2px;font-size:.65rem;font-weight:700}.pe-empty-ops{text-align:center;color:var(--text-muted);padding:20px 12px;font-size:.8rem}.pe-info-grid{flex-direction:column;gap:2px;display:flex}.pe-info-row{border-bottom:1px solid #80808014;justify-content:space-between;padding:5px 0;font-size:.78rem;display:flex}.pe-info-row span:first-child{color:var(--text-dim)}.pe-info-row span:last-child{color:var(--text);font-family:monospace;font-weight:600}.mats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.mat-card{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);flex-direction:column;gap:4px;padding:12px;display:flex}.mat-card strong{color:var(--primary-hover);font-size:.95rem}.mat-card span{color:var(--text);font-size:1.1rem;font-weight:700}.mat-card small{color:var(--text-muted);font-size:.75rem}.mat-badge{border-radius:var(--radius-xs);background:var(--primary-subtle);color:var(--primary);font-size:var(--text-xs);padding:2px 8px;font-weight:600;display:inline-block}@media (width<=900px){.app{flex-direction:column-reverse}.dim-grid{grid-template-columns:1fr 1fr}.type-grid{grid-template-columns:1fr}.viewer-toolbar{top:8px;left:8px}.export-btn{padding:10px 14px}}@media (width<=480px){.app{flex-direction:column-reverse}.part-editor{width:calc(100% - 20px);left:10px;right:10px}}.exit-modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:center;animation:.2s ease-out modalFadeIn;display:flex;position:fixed;inset:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.exit-modal{background:var(--bg-sidebar);border:1px solid var(--border);text-align:center;width:90%;max-width:400px;box-shadow:0 20px 60px #00000080, 0 0 40px var(--primary-glow);animation:modalSlideIn .25s var(--ease);border-radius:18px;padding:36px 32px 28px}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.92)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.exit-modal-icon{width:64px;height:64px;color:var(--danger);background:#ef44441a;border:1px solid #ef444433;border-radius:16px;justify-content:center;align-items:center;margin:0 auto 18px;display:flex}.exit-modal h3{color:var(--text);margin-bottom:8px;font-size:1.2rem;font-weight:800}.exit-modal p{color:var(--text-dim);margin-bottom:24px;font-size:.9rem;line-height:1.6}.exit-modal-actions{flex-direction:column;gap:8px;display:flex}.exit-modal-btn{width:100%;font-family:var(--font);cursor:pointer;transition:all .2s var(--ease);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:.92rem;font-weight:700;display:flex}.exit-save{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;box-shadow:0 2px 12px var(--primary-glow)}.exit-save:hover{box-shadow:0 6px 20px var(--primary-glow);transform:translateY(-1px)}.exit-discard{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.exit-discard:hover{background:#ef44442e}.exit-cancel{color:var(--text-muted);background:0 0}.exit-cancel:hover{color:var(--text);background:#ffffff0a}.save-toast{z-index:10000;background:var(--success);color:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700;font-family:var(--font);animation:toastSlideIn .3s var(--ease), toastSlideOut .3s var(--ease) 1.7s forwards;align-items:center;gap:10px;padding:12px 24px;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 30px #22c55e66}.save-toast svg{flex-shrink:0}.room-position-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);z-index:20;min-width:200px;padding:12px 14px;position:absolute;bottom:60px;right:16px;box-shadow:0 4px 20px #0000004d}[dir=rtl] .room-position-panel{left:16px;right:auto}.room-position-panel h4{color:var(--text);margin:0 0 10px;font-size:.8rem;font-weight:700}.room-pos-field{align-items:center;gap:6px;margin-bottom:6px;display:flex}.room-pos-field label{color:var(--text-muted);flex:0 0 80px;font-size:.72rem}.room-pos-field select,.room-pos-field input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:4px;flex:1;padding:4px 6px;font-size:.78rem}.room-pos-unit{color:var(--text-muted);font-size:.65rem}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-20px)}}.save-name-input{width:100%;font-size:1.05rem;font-weight:600;font-family:var(--font);color:var(--text);background:var(--bg);border:2px solid var(--border);text-align:center;border-radius:12px;outline:none;margin-bottom:20px;padding:14px 18px;transition:border-color .2s,box-shadow .2s}.save-name-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.save-name-input::placeholder{color:var(--text-muted);font-weight:400}.viewer-tip-wrap{display:inline-flex;position:relative}.viewer-tip{white-space:nowrap;color:#fff;pointer-events:none;opacity:0;z-index:500;background:#0f111eeb;border:1px solid #ffffff14;border-radius:7px;padding:5px 10px;font-size:.72rem;font-weight:600;transition:opacity .15s,transform .15s;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%)translate(-4px)}.viewer-tip:after{content:"";border:5px solid #0000;border-right-color:#0f111eeb;position:absolute;top:50%;right:100%;transform:translateY(-50%)}[dir=ltr] .viewer-tip{left:calc(100% + 8px)}.viewer-tip-wrap:hover .viewer-tip{opacity:1;transform:translateY(-50%)translate(0)}.zone-editor{flex-direction:column;gap:12px;display:flex}.zone-editor-toolbar{flex-wrap:wrap;gap:6px;display:flex}.zone-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);font-family:var(--font);cursor:pointer;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;transition:background .15s,border-color .15s;display:flex}.zone-btn:hover:not(:disabled){border-color:var(--accent);background:#3b82f61f}.zone-btn:disabled{opacity:.35;cursor:not-allowed}.zone-editor-canvas-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-surface);justify-content:center;padding:8px;display:flex}.zone-editor-svg{-webkit-user-select:none;user-select:none;max-width:200px;height:auto;display:block}.zone-content-picker{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);flex-direction:column;gap:8px;padding:10px;display:flex}.zone-picker-label{color:var(--text-muted);letter-spacing:.3px;font-size:.75rem;font-weight:700}.zone-content-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px;display:grid}.zone-content-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-surface);color:var(--text);font-family:var(--font);cursor:pointer;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;font-size:.72rem;transition:all .15s;display:flex}.zone-content-btn:hover{border-color:var(--accent);background:#3b82f614}.zone-content-btn.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);background:#3b82f626}.zone-content-icon{font-size:1.1rem}.zone-config-row{align-items:center;gap:8px;font-size:.8rem;display:flex}.zone-config-row label{color:var(--text-muted);white-space:nowrap}.zone-config-row input,.zone-config-row select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-surface);color:var(--text);font-family:var(--font);width:70px;padding:4px 8px;font-size:.8rem}.zone-dimensions-info{color:var(--text-muted);align-items:center;gap:8px;padding:4px 0;font-size:.75rem;display:flex}.step-desc{color:var(--text-muted);margin-bottom:8px;font-size:.82rem;line-height:1.5}.step-desc-small{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;line-height:1.4}.layout-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:10px;padding-bottom:6px;display:flex}.layout-tab{border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;background:var(--bg-surface);color:var(--text-muted);font-family:var(--font);cursor:pointer;border-bottom:none;flex:1;padding:8px 12px;font-size:.8rem;font-weight:600;transition:all .15s}.layout-tab:hover{color:var(--text);background:#3b82f60f}.layout-tab.active{color:var(--accent);background:var(--bg-card);border-color:var(--accent);border-bottom:2px solid var(--accent)}.layout-tab-content{animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.export-validation-modal{max-width:520px}.export-val-body{max-height:60vh;overflow-y:auto;padding:20px 24px!important}.export-val-summary{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;padding:14px 16px}.export-val-summary-row{justify-content:space-between;align-items:center;padding:4px 0;display:flex}.export-val-label{color:var(--text-dim);font-size:.82rem}.export-val-value{color:var(--text);font-size:.85rem;font-weight:600}.export-val-stats{border-top:1px solid var(--border);gap:16px;margin-top:10px;padding-top:10px;display:flex}.export-val-stat{color:var(--text-dim);align-items:center;gap:5px;font-size:.78rem;display:flex}.export-val-stat svg{color:var(--primary)}.export-val-loading{color:var(--text-dim);flex-direction:column;align-items:center;gap:10px;padding:32px 0;display:flex}.export-val-loading p{color:var(--text);font-size:.95rem;font-weight:600}.export-val-loading small{font-size:.78rem}.export-val-spinner{color:var(--primary);animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.export-val-status{border-radius:10px;align-items:center;gap:10px;margin-bottom:12px;padding:12px 16px;font-size:.9rem;font-weight:600;display:flex}.export-val-status.pass{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.export-val-status.warn{color:#eab308;background:#eab3081a;border:1px solid #eab30833}.export-val-status.fail{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.export-val-section{border-radius:10px;margin-bottom:8px;overflow:hidden}.export-val-section.error{background:#ef444408;border:1px solid #ef444433}.export-val-section.warning{background:#eab30808;border:1px solid #eab30833}.export-val-section-header{cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;font-weight:600;transition:background .15s;display:flex}.export-val-section.error .export-val-section-header svg:first-child{color:#ef4444}.export-val-section.warning .export-val-section-header svg:first-child{color:#eab308}.export-val-section-header:hover{background:#ffffff08}.export-val-section-header svg:last-child{color:var(--text-dim);margin-inline-start:auto}.export-val-list{padding:0 14px 10px;list-style:none}.export-val-list li{color:var(--text-dim);text-align:left;direction:ltr;align-items:flex-start;gap:8px;padding:5px 0;font-size:.78rem;line-height:1.4;display:flex}.export-val-section.error .export-val-list li svg{color:#ef4444;flex-shrink:0;margin-top:2px}.export-val-section.warning .export-val-list li svg{color:#eab308;flex-shrink:0;margin-top:2px}.export-val-section.info{border-inline-start:3px solid var(--primary)}.export-val-section.info .export-val-section-header svg:first-child{color:var(--primary)}.export-val-section.info .export-val-list li svg{color:var(--primary);flex-shrink:0;margin-top:2px}.export-val-code{background:var(--surface);color:var(--text-dim);border-radius:4px;margin-inline-end:6px;padding:2px 6px;font-family:monospace;font-size:.7rem}.export-val-part-id{color:var(--text-dim);font-size:.75rem}.export-val-grouped{padding:4px 0}.export-val-category{margin-bottom:6px}.export-val-category-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);padding:4px 16px;font-size:.8rem;font-weight:600}.export-val-all-clear{color:#22c55e;background:#22c55e0f;border:1px solid #22c55e26;border-radius:10px;align-items:center;gap:10px;padding:14px 16px;font-size:.85rem;font-weight:500;display:flex}.export-val-done{color:#22c55e;flex-direction:column;align-items:center;gap:10px;padding:24px 0;display:flex}.export-val-done p{font-size:.95rem;font-weight:600}.export-val-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.export-val-footer .nav-btn.next{align-items:center;gap:6px;display:flex}.export-val-footer .nav-btn.next.disabled{opacity:.4;cursor:not-allowed}[dir=rtl] .export-val-list li{text-align:right;direction:rtl}.landing-page{background:var(--bg);width:100%;min-height:100vh;color:var(--text);font-family:var(--font);scroll-behavior:smooth;overflow:hidden auto}.lp-nav{z-index:1000;transition:all .4s var(--ease);background:0 0;padding:16px 0;position:fixed;top:0;left:0;right:0}.lp-nav.scrolled{-webkit-backdrop-filter:blur(20px)saturate(1.8);background:#0c0e1ad9;border-bottom:1px solid #6366f11a;padding:10px 0;box-shadow:0 4px 30px #0000004d}:root[data-theme=light] .lp-nav.scrolled{background:#f8fafce0;border-bottom:1px solid #4f46e51a;box-shadow:0 4px 20px #0000000f}.lp-nav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 32px;display:flex}.lp-logo{cursor:pointer;align-items:center;gap:10px;transition:transform .2s;display:flex}.lp-logo:hover{transform:scale(1.02)}.lp-logo-img{object-fit:cover;border-radius:10px;width:38px;height:38px}.lp-logo-img-sm{border-radius:8px;width:28px;height:28px}.lp-logo-text{background:var(--logo-text-grd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:800}.lp-nav-links{align-items:center;gap:32px;display:flex}.lp-nav-links a{color:var(--text-dim);cursor:pointer;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s;position:relative}.lp-nav-links a:hover{color:var(--text)}.lp-nav-links a:after{content:"";background:var(--primary);height:2px;transition:transform .3s var(--ease);border-radius:1px;position:absolute;bottom:-4px;left:0;right:0;transform:scaleX(0)}.lp-nav-links a:hover:after{transform:scaleX(1)}.lp-nav-free-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:20px;padding:4px 12px;font-size:.72rem;font-weight:700}.lp-nav-actions{align-items:center;gap:10px;display:flex}.lp-lang-btn{border:1px solid var(--border);color:var(--text-dim);font-family:var(--font);cursor:pointer;background:#ffffff0a;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.lp-lang-btn:hover{border-color:var(--primary);color:var(--text);background:#6366f114}.lp-login-btn{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;font-family:var(--font);cursor:pointer;transition:all .25s var(--ease);box-shadow:0 2px 12px var(--primary-glow);border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:.85rem;font-weight:700;display:flex}.lp-login-btn:hover{box-shadow:0 6px 24px var(--primary-glow);transform:translateY(-1px)}.lp-mobile-menu{border:1px solid var(--border);width:40px;height:40px;color:var(--text);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;display:none}.lp-hero{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:120px 32px 60px;display:flex;position:relative;overflow:hidden}.lp-hero-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.lp-grid-pattern{background-image:linear-gradient(#6366f108 1px,#0000 1px),linear-gradient(90deg,#6366f108 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 30%,#0000 70%);mask-image:radial-gradient(#000 30%,#0000 70%)}.lp-glow{filter:blur(100px);opacity:.5;border-radius:50%;position:absolute}.lp-glow-1{background:radial-gradient(circle,#6366f14d,#0000 70%);width:600px;height:600px;animation:8s ease-in-out infinite glowFloat;top:-200px;right:-100px}.lp-glow-2{background:radial-gradient(circle,#a855f740,#0000 70%);width:500px;height:500px;animation:10s ease-in-out infinite reverse glowFloat;bottom:-150px;left:-100px}.lp-glow-3{background:radial-gradient(circle,#f59e0b26,#0000 70%);width:300px;height:300px;animation:12s ease-in-out infinite glowFloat;top:40%;left:50%}@keyframes glowFloat{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-20px)scale(1.1)}66%{transform:translate(-20px,20px)scale(.95)}}.lp-hero-content{z-index:2;align-items:center;gap:60px;width:100%;max-width:1200px;display:flex;position:relative}[dir=rtl] .lp-hero-content{flex-direction:row-reverse}.lp-hero-text{flex:1;min-width:0}.lp-hero-badge{color:var(--primary-hover);animation:badgeFade .8s var(--ease) both;background:#6366f114;border:1px solid #6366f133;border-radius:50px;align-items:center;gap:8px;margin-bottom:24px;padding:8px 18px;font-size:.82rem;font-weight:600;display:inline-flex}@keyframes badgeFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lp-hero-title{background:linear-gradient(135deg, var(--text) 0%, var(--text-dim) 100%);-webkit-text-fill-color:transparent;animation:titleSlide .8s var(--ease) .1s both;-webkit-background-clip:text;background-clip:text;margin-bottom:20px;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:900;line-height:1.15}@keyframes titleSlide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lp-hero-subtitle{color:var(--text-dim);max-width:540px;animation:titleSlide .8s var(--ease) .25s both;margin-bottom:32px;font-size:1.08rem;line-height:1.7}.lp-hero-actions{animation:titleSlide .8s var(--ease) .4s both;flex-wrap:wrap;gap:14px;display:flex}.lp-btn-primary{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;font-family:var(--font);cursor:pointer;transition:all .3s var(--ease);box-shadow:0 4px 20px var(--primary-glow);border:none;border-radius:12px;align-items:center;gap:10px;padding:14px 28px;font-size:1rem;font-weight:700;display:inline-flex;position:relative;overflow:hidden}.lp-btn-primary:before{content:"";opacity:0;background:linear-gradient(135deg,#ffffff26,#0000);transition:opacity .3s;position:absolute;inset:0}.lp-btn-primary:hover{box-shadow:0 8px 32px var(--primary-glow);transform:translateY(-2px)}.lp-btn-primary:hover:before{opacity:1}.lp-btn-lg{border-radius:14px;padding:18px 36px;font-size:1.1rem}.lp-btn-secondary{border:1.5px solid var(--border-light);color:var(--text);font-family:var(--font);cursor:pointer;transition:all .3s var(--ease);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff08;border-radius:12px;align-items:center;gap:8px;padding:14px 24px;font-size:.95rem;font-weight:600;display:inline-flex}.lp-btn-secondary:hover{border-color:var(--primary);background:#6366f10f;transform:translateY(-1px)}.lp-trust{animation:titleSlide .8s var(--ease) .55s both;flex-wrap:wrap;gap:20px;margin-top:28px;display:flex}.lp-trust-item{color:var(--text-muted);align-items:center;gap:6px;font-size:.8rem;font-weight:500;display:flex}.lp-trust-item svg{color:var(--success);flex-shrink:0}.lp-hero-visual{width:440px;animation:visualFloat .8s var(--ease) .3s both;flex:none}@keyframes visualFloat{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.lp-hero-img-wrapper{box-shadow:0 20px 60px #0006, 0 0 80px var(--primary-glow);transition:transform .5s var(--ease);border:1px solid #6366f126;border-radius:20px;position:relative;overflow:hidden}.lp-hero-img-wrapper:hover{transform:scale(1.02)translateY(-4px)}.lp-hero-img-wrapper img{width:100%;display:block}.lp-hero-img-glow{pointer-events:none;background:linear-gradient(#0000 60%,#6366f11a 100%);position:absolute;inset:0}.lp-scroll-indicator{color:var(--text-muted);cursor:pointer;z-index:2;transition:color .2s;animation:2s ease-in-out infinite scrollBounce;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.lp-scroll-indicator:hover{color:var(--primary)}@keyframes scrollBounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(8px)}}.lp-section-header{text-align:center;margin-bottom:56px}.lp-section-header h2{background:linear-gradient(135deg, var(--text), var(--text-dim));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:900}.lp-section-header p{color:var(--text-muted);max-width:560px;margin:0 auto;font-size:1.05rem}.lp-features{max-width:1200px;margin:0 auto;padding:100px 32px}.lp-features-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.lp-feature-card{background:var(--bg-card);border:1px solid var(--border);transition:all .35s var(--ease);opacity:0;border-radius:16px;padding:32px 24px;position:relative;overflow:hidden;transform:translateY(30px)}.lp-features.animated .lp-feature-card{animation:cardReveal .6s var(--ease) both}@keyframes cardReveal{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.lp-feature-card:before{content:"";background:linear-gradient(90deg, var(--primary), #3b82f6);opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.lp-feature-card:hover:before{opacity:1}.lp-feature-card:hover{box-shadow:0 12px 40px #00000040, 0 0 40px var(--primary-glow);border-color:#6366f14d;transform:translateY(-6px)}.lp-feature-icon{width:52px;height:52px;color:var(--primary-hover);background:linear-gradient(135deg,#6366f11f,#a855f714);border-radius:14px;justify-content:center;align-items:center;margin-bottom:18px;transition:all .3s;display:flex}.lp-feature-card:hover .lp-feature-icon{background:linear-gradient(135deg, var(--primary), #3b82f6);color:#fff;box-shadow:0 4px 20px var(--primary-glow)}.lp-feature-card h3{margin-bottom:8px;font-size:1.05rem;font-weight:700}.lp-feature-card p{color:var(--text-dim);font-size:.88rem;line-height:1.6}.lp-how{max-width:1200px;margin:0 auto;padding:100px 32px;position:relative}.lp-steps-row{justify-content:center;gap:24px;display:flex;position:relative}.lp-step-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;max-width:340px;transition:all .35s var(--ease);opacity:0;border-radius:18px;flex:1;padding:36px 28px;position:relative;transform:translateY(30px)}.lp-how.animated .lp-step-card{animation:cardReveal .6s var(--ease) both}.lp-step-card:hover{border-color:#6366f14d;transform:translateY(-4px);box-shadow:0 10px 30px #0003}.lp-step-num{background:linear-gradient(135deg, var(--primary), #3b82f6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;font-size:2.4rem;font-weight:900;line-height:1}.lp-step-card h3{margin-bottom:10px;font-size:1.1rem;font-weight:700}.lp-step-card p{color:var(--text-dim);font-size:.88rem;line-height:1.6}.lp-step-connector{color:var(--border-light);opacity:.5;position:absolute;top:50%;right:-34px;transform:translateY(-50%)}[dir=rtl] .lp-step-connector{left:-34px;right:auto}.lp-screenshots{max-width:1200px;margin:0 auto;padding:100px 32px}.lp-screenshots-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.lp-screenshot-card{background:var(--bg-card);border:1px solid var(--border);transition:all .35s var(--ease);opacity:0;border-radius:18px;overflow:hidden;transform:translateY(30px)}.lp-screenshots.animated .lp-screenshot-card{animation:cardReveal .6s var(--ease) both}.lp-screenshot-card:hover{box-shadow:0 16px 48px #0000004d, 0 0 40px var(--primary-glow);border-color:#6366f14d;transform:translateY(-6px)}.lp-screenshot-img{aspect-ratio:4/3;position:relative;overflow:hidden}.lp-screenshot-img img{object-fit:cover;width:100%;height:100%;transition:transform .5s var(--ease)}.lp-screenshot-card:hover .lp-screenshot-img img{transform:scale(1.05)}.lp-screenshot-overlay{pointer-events:none;background:linear-gradient(#0000 50%,#0c0e1a99 100%);position:absolute;inset:0}.lp-screenshot-info{padding:20px 24px}.lp-screenshot-info h3{margin-bottom:6px;font-size:1rem;font-weight:700}.lp-screenshot-info p{color:var(--text-dim);font-size:.82rem;line-height:1.5}.lp-pricing{max-width:1200px;margin:0 auto;padding:100px 32px}.lp-billing-toggle{justify-content:center;align-items:center;gap:14px;margin-bottom:48px;display:flex}.lp-billing-toggle>span{color:var(--text-muted);font-size:.9rem;font-weight:600;transition:color .3s}.lp-billing-toggle>span.active{color:var(--text)}.lp-toggle-switch{border:2px solid var(--border-light);background:var(--bg-card);cursor:pointer;width:52px;height:28px;transition:all .3s var(--ease);border-radius:14px;padding:0;position:relative}.lp-toggle-switch.yearly{background:linear-gradient(135deg, var(--primary), #3b82f6);border-color:var(--primary)}.lp-toggle-knob{width:18px;height:18px;transition:transform .3s var(--ease);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.lp-toggle-switch.yearly .lp-toggle-knob{transform:translate(24px)}[dir=rtl] .lp-toggle-switch.yearly .lp-toggle-knob{transform:translate(-24px)}[dir=rtl] .lp-toggle-knob{left:auto;right:3px}.lp-save-badge{color:#fff;animation:badgeFade .4s var(--ease) both;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:20px;padding:4px 12px;font-size:.72rem;font-weight:700}.lp-pricing-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:24px;display:grid}.lp-price-card{background:var(--bg-card);border:1.5px solid var(--border);transition:all .35s var(--ease);opacity:0;border-radius:20px;padding:36px 28px;position:relative;overflow:hidden;transform:translateY(30px)}.lp-pricing.animated .lp-price-card{animation:cardReveal .6s var(--ease) both}.lp-pricing.animated .lp-price-card:nth-child(2){animation-delay:.1s}.lp-pricing.animated .lp-price-card:nth-child(3){animation-delay:.2s}.lp-price-card:hover{border-color:#6366f133;transform:translateY(-6px);box-shadow:0 16px 48px #0003}.lp-price-card.popular{border-color:var(--primary);background:linear-gradient(180deg, #6366f10f 0%, var(--bg-card) 40%);box-shadow:0 0 60px var(--primary-glow), 0 12px 40px #0003;z-index:2;transform:scale(1.04)}.lp-price-card.popular:hover{box-shadow:0 0 80px var(--primary-glow), 0 20px 60px #0000004d;transform:scale(1.04)translateY(-6px)}.lp-popular-badge{text-align:center;background:linear-gradient(135deg, var(--primary), #3b82f6);color:#fff;letter-spacing:.5px;text-transform:uppercase;padding:6px 0;font-size:.75rem;font-weight:700;position:absolute;top:0;left:0;right:0}.lp-price-card-header{text-align:center;margin-bottom:24px}.lp-price-card.popular .lp-price-card-header{margin-top:20px}.lp-price-icon{border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 14px;transition:all .3s;display:flex}.lp-price-icon.free{color:#22c55e;background:#22c55e1a}.lp-price-icon.pro{color:var(--primary-hover);background:linear-gradient(135deg,#6366f126,#a855f71a)}.lp-price-icon.power{color:#f59e0b;background:#f59e0b1a}.lp-price-card-header h3{margin-bottom:6px;font-size:1.3rem;font-weight:800}.lp-price-desc{color:var(--text-muted);font-size:.82rem;line-height:1.5}.lp-price-amount{justify-content:center;align-items:baseline;gap:2px;margin-bottom:4px;display:flex}.lp-price-currency{color:var(--text-dim);align-self:flex-start;margin-top:8px;font-size:1.4rem;font-weight:700}.lp-price-number{background:linear-gradient(135deg, var(--text), var(--text-dim));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:3.2rem;font-weight:900;line-height:1}.lp-price-period{color:var(--text-muted);font-size:.88rem;font-weight:500}.lp-price-yearly{text-align:center;color:var(--text-muted);margin-bottom:8px;font-size:.78rem}.lp-price-features{flex-direction:column;gap:12px;margin:24px 0;padding:0;list-style:none;display:flex}.lp-price-features li{color:var(--text);align-items:center;gap:10px;font-size:.88rem;font-weight:500;display:flex}.lp-price-features li svg{color:#22c55e;flex-shrink:0}.lp-price-features li.disabled{color:var(--text-muted);opacity:.5}.lp-price-features li.disabled svg{color:var(--text-muted)}.lp-price-btn{width:100%;font-family:var(--font);cursor:pointer;transition:all .3s var(--ease);border:none;border-radius:12px;padding:14px 20px;font-size:.95rem;font-weight:700}.lp-price-btn.free{background:var(--bg);color:var(--text);border:1.5px solid var(--border-light)}.lp-price-btn.free:hover{border-color:var(--primary);background:#6366f10f;transform:translateY(-2px)}.lp-price-btn.pro{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;box-shadow:0 4px 20px var(--primary-glow)}.lp-price-btn.pro:hover{box-shadow:0 8px 32px var(--primary-glow);transform:translateY(-2px)}.lp-price-btn.power{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 20px #f59e0b4d}.lp-price-btn.power:hover{transform:translateY(-2px);box-shadow:0 8px 32px #f59e0b66}:root[data-theme=light] .lp-price-card{box-shadow:0 2px 12px #0000000f}:root[data-theme=light] .lp-price-card.popular{box-shadow:0 0 40px #6366f126,0 8px 30px #00000014}.lp-cta{padding:100px 32px;position:relative;overflow:hidden}.lp-cta-bg{pointer-events:none;position:absolute;inset:0}.lp-glow-cta-1{filter:blur(100px);background:radial-gradient(circle,#6366f133,#0000 70%);width:500px;height:500px;top:-150px;left:50%;transform:translate(-50%)}.lp-glow-cta-2{filter:blur(100px);background:radial-gradient(circle,#a855f726,#0000 70%);width:400px;height:400px;bottom:-100px;right:20%}.lp-cta-content{z-index:2;text-align:center;max-width:620px;margin:0 auto;position:relative}.lp-cta-content h2{background:linear-gradient(135deg, var(--text), var(--text-dim));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:14px;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:900}.lp-cta-content p{color:var(--text-muted);margin-bottom:32px;font-size:1.05rem;line-height:1.6}.lp-footer{border-top:1px solid var(--border);padding:40px 32px}.lp-footer-inner{text-align:center;max-width:1200px;margin:0 auto}.lp-footer-logo{align-items:center;gap:8px;margin-bottom:10px;display:inline-flex}.lp-footer-logo span{background:var(--logo-text-grd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:800}.lp-footer-desc{color:var(--text-dim);margin-bottom:6px;font-size:.88rem}.lp-footer-rights{color:var(--text-muted);font-size:.78rem}@media (width<=1024px){.lp-pricing-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}.lp-price-card.popular{order:-1;transform:none}.lp-price-card.popular:hover{transform:translateY(-6px)}.lp-features-grid,.lp-screenshots-grid{grid-template-columns:repeat(2,1fr)}.lp-screenshots-grid .lp-screenshot-card:last-child{grid-column:span 2;max-width:500px;margin:0 auto}.lp-hero-visual{width:360px}}@media (width<=768px){.lp-nav-links{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:transform .4s var(--ease);z-index:999;background:#0c0e1af2;flex-direction:column;gap:16px;padding:24px;position:fixed;top:70px;left:0;right:0;transform:translateY(-120%)}:root[data-theme=light] .lp-nav-links{background:#f8fafcf2}.lp-nav-links.open{transform:translateY(0)}.lp-nav-links a{padding:8px 0;font-size:1.05rem}.lp-mobile-menu{display:flex}.lp-login-btn span{display:none}.lp-login-btn{padding:8px 12px}.lp-hero{padding:100px 20px 60px}.lp-hero-content{text-align:center;flex-direction:column!important}.lp-hero-text{flex-direction:column;align-items:center;display:flex}.lp-hero-subtitle{max-width:100%}.lp-hero-actions,.lp-trust{justify-content:center}.lp-hero-visual{width:100%;max-width:400px}.lp-features-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}.lp-steps-row{flex-direction:column;align-items:center}.lp-step-card{max-width:100%}.lp-step-connector{display:none}.lp-screenshots-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}.lp-screenshots-grid .lp-screenshot-card:last-child{grid-column:span 1;max-width:none}.lp-features,.lp-how,.lp-screenshots,.lp-pricing,.lp-cta{padding:70px 20px}}@media (width<=480px){.lp-hero-title{font-size:2rem}.lp-hero-actions{flex-direction:column;width:100%}.lp-btn-primary,.lp-btn-secondary{justify-content:center;width:100%}.lp-lang-btn span{display:none}}.dash-tip-wrap{display:inline-flex;position:relative}.dash-tip{white-space:nowrap;color:#fff;pointer-events:none;opacity:0;z-index:500;background:#0f111eeb;border:1px solid #ffffff14;border-radius:7px;padding:5px 10px;font-size:.72rem;font-weight:600;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px)}.dash-tip:after{content:"";border:5px solid #0000;border-top-color:#0f111eeb;position:absolute;top:100%;left:50%;transform:translate(-50%)}.dash-tip-wrap:hover .dash-tip{opacity:1;transform:translate(-50%)translateY(0)}.dash-modal-sm{text-align:center;max-width:380px!important}.dash-confirm-icon{margin:8px auto 16px}.dash-confirm-msg{color:var(--text-dim);margin-bottom:4px;font-size:.92rem;line-height:1.6}.dash-confirm-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:20px;display:flex}.dash-confirm-btn{font-family:var(--font);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 22px;font-size:.88rem;font-weight:700;transition:all .2s;display:flex}.dash-confirm-cancel{background:var(--bg);border:1px solid var(--border);color:var(--text-dim)}.dash-confirm-cancel:hover{border-color:var(--primary);color:var(--text)}.dash-confirm-danger{background:linear-gradient(135deg, var(--danger), #dc2626);color:#fff}.dash-confirm-danger:hover{transform:translateY(-1px);box-shadow:0 4px 14px #ef444459}.dash-confirm-ok{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff}.dash-confirm-ok:hover{box-shadow:0 4px 14px var(--primary-glow);transform:translateY(-1px)}.dash-field-error{color:var(--danger);background:#ef44441a;border:1px solid #ef444440;border-radius:8px;align-items:center;gap:8px;margin-top:8px;padding:9px 12px;font-size:.82rem;font-weight:600;display:flex}.dash-field-error button{color:var(--danger);cursor:pointer;background:0 0;border:none;align-items:center;margin-inline-start:auto;display:flex}.dash-page{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font);overflow-y:auto}.dash-nav{z-index:100;-webkit-backdrop-filter:blur(20px)saturate(1.8);border-bottom:1px solid var(--border);background:#0c0e1abf;position:sticky;top:0}:root[data-theme=light] .dash-nav{background:#f8fafcd9}.dash-nav-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:12px 28px;display:flex}.dash-logo{cursor:pointer;align-items:center;gap:10px;transition:opacity .2s;display:flex}.dash-logo:hover{opacity:.85}.dash-logo-img{object-fit:cover;border-radius:9px;width:34px;height:34px}.dash-logo-text{background:var(--logo-text-grd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:800}.dash-version{color:var(--text-muted);-webkit-text-fill-color:var(--text-muted);font-size:.6rem}.dash-nav-actions{align-items:center;gap:8px;display:flex}.dash-quick-nav-btn{border:1px solid var(--primary);color:var(--primary);cursor:pointer;white-space:nowrap;background:#6366f11a;border-radius:8px;align-items:center;gap:5px;padding:6px 14px;font-size:.78rem;font-weight:600;transition:all .2s;display:flex}.dash-quick-nav-btn:hover{background:var(--primary);color:#fff}.dash-icon-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:9px;justify-content:center;align-items:center;transition:all .2s;display:flex}.dash-icon-btn:hover{color:var(--text);border-color:var(--primary);background:#6366f114}.dash-logout-btn:hover{color:var(--danger);border-color:var(--danger);background:#ef444414}.dash-user-pill{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;align-items:center;gap:8px;margin-inline-start:4px;padding:6px 14px 6px 8px;display:flex}.dash-user-avatar{background:linear-gradient(135deg, var(--primary), #3b82f6);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.dash-user-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-size:.82rem;font-weight:600;overflow:hidden}.dash-hero{padding:48px 28px 40px;position:relative;overflow:hidden}.dash-hero-bg{pointer-events:none;position:absolute;inset:0}.dash-hero-glow{filter:blur(40px);background:radial-gradient(#6366f11f,#0000 70%);width:600px;height:300px;position:absolute;top:-100px;left:50%;transform:translate(-50%)}.dash-hero-content{z-index:2;max-width:1100px;margin:0 auto;position:relative}.dash-greeting{align-items:center;gap:12px;margin-bottom:6px;display:flex}.dash-wave{transform-origin:70% 70%;font-size:1.8rem;animation:2s ease-in-out infinite wave;display:inline-block}@keyframes wave{0%,to{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%,to{transform:rotate(0)}}.dash-greeting h1{color:var(--text-dim);font-size:clamp(1.4rem,3vw,1.8rem);font-weight:400}.dash-greeting h1 strong{background:var(--logo-text-grd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.dash-hero-sub{color:var(--text-muted);margin-inline-start:48px;font-size:.92rem}.dash-container{max-width:1100px;margin:0 auto;padding:0 28px 60px}.dash-quick-actions{flex-wrap:wrap;gap:16px;margin-bottom:28px;display:flex}.dash-new-btn{border:2px dashed var(--border-light);cursor:pointer;min-width:200px;transition:all .3s var(--ease);font-family:var(--font);text-align:start;background:linear-gradient(135deg,#6366f10a,#a855f705);border-radius:16px;flex:1;align-items:center;gap:18px;padding:22px 28px;display:flex}.dash-new-btn:hover{border-color:var(--primary);box-shadow:0 8px 30px var(--primary-glow);background:linear-gradient(135deg,#6366f114,#a855f70a);transform:translateY(-2px)}.dash-new-icon{background:linear-gradient(135deg, var(--primary), #3b82f6);color:#fff;width:56px;height:56px;box-shadow:0 4px 16px var(--primary-glow);transition:transform .3s var(--ease);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.dash-new-btn:hover .dash-new-icon{transform:scale(1.05)rotate(3deg)}.dash-new-text{flex-direction:column;gap:2px;display:flex}.dash-new-text strong{color:var(--text);font-size:1.05rem;font-weight:700}.dash-new-text span{color:var(--text-muted);font-size:.82rem}.dash-section{margin-bottom:32px}.dash-section-header{align-items:center;gap:10px;margin-bottom:20px;display:flex}.dash-section-header h2{color:var(--text);align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:flex}.dash-section-header h2 svg{color:var(--primary)}.dash-count-badge{color:var(--primary);background:#6366f11f;border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:700}.dash-empty{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:18px;padding:72px 20px}.dash-empty-icon{color:var(--border-light);opacity:.4;margin-bottom:20px;animation:3s ease-in-out infinite pulse}.dash-empty h3{color:var(--text-dim);margin-bottom:8px;font-size:1.15rem}.dash-empty p{color:var(--text-muted);margin-bottom:24px;font-size:.9rem}.dash-empty-btn{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;font-family:var(--font);cursor:pointer;transition:all .25s var(--ease);box-shadow:0 4px 16px var(--primary-glow);border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 28px;font-size:.95rem;font-weight:700;display:inline-flex}.dash-empty-btn:hover{box-shadow:0 8px 28px var(--primary-glow);transform:translateY(-2px)}.dash-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;display:grid}.dash-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all .3s var(--ease);border-radius:16px;position:relative;overflow:visible}.dash-card:hover{box-shadow:0 12px 36px #0003, 0 0 32px var(--primary-glow);border-color:#6366f166;transform:translateY(-4px)}.dash-card-top{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#6366f10f,#a855f708);border-radius:16px 16px 0 0;justify-content:space-between;align-items:flex-start;padding:18px 18px 14px;display:flex;overflow:visible}.dash-card-icon{width:48px;height:48px;color:var(--primary-hover);background:linear-gradient(135deg,#6366f126,#a855f71a);border-radius:13px;justify-content:center;align-items:center;transition:all .3s;display:flex}.dash-card:hover .dash-card-icon{background:linear-gradient(135deg, var(--primary), #3b82f6);color:#fff;box-shadow:0 4px 16px var(--primary-glow)}.dash-card-actions{opacity:0;z-index:10;gap:4px;transition:opacity .2s;display:flex;position:relative;overflow:visible}.dash-card:hover .dash-card-actions{opacity:1}.dash-card-action{border:1px solid var(--border);background:var(--bg);width:30px;height:30px;color:var(--text-dim);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.dash-card-action:hover{border-color:var(--primary);color:var(--primary);background:#6366f11a}.dash-card-delete:hover{border-color:var(--danger);color:var(--danger);background:#ef44441a}.dash-card-body{padding:16px 18px}.dash-card-body h3{color:var(--text);margin-bottom:8px;font-size:1rem;font-weight:700}.dash-rename{margin-bottom:8px}.dash-rename-input{width:100%;font-size:1rem;font-weight:700;font-family:var(--font);color:var(--text);border:none;border-bottom:2px solid var(--primary);background:0 0;border-radius:0;outline:none;padding:6px 8px}.dash-rename-input:focus{box-shadow:0 2px 0 var(--primary-glow)}.dash-card-meta{gap:14px;margin-bottom:10px;display:flex}.dash-card-meta span{color:var(--text-muted);align-items:center;gap:4px;font-size:.75rem;display:flex}.dash-card-meta svg{flex-shrink:0}.dash-card-badges{flex-wrap:wrap;gap:6px;display:flex}.dash-badge{color:var(--primary);background:#6366f11a;border-radius:6px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.dash-badge-dim{color:var(--text-dim);background:#6366f10f}.dash-card-open{border-top:1px solid var(--border);color:var(--text-muted);opacity:0;transition:all .3s var(--ease);border-radius:0 0 16px 16px;justify-content:flex-end;align-items:center;gap:6px;padding:10px 18px;font-size:.78rem;font-weight:600;display:flex;transform:translate(-6px)}[dir=rtl] .dash-card-open{transform:translate(6px)}.dash-card:hover .dash-card-open{opacity:1;color:var(--primary);transform:translate(0)}.dash-tabs{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;gap:4px;margin-bottom:28px;padding:4px;display:flex}.dash-tab{color:var(--text-muted);font-family:var(--font);cursor:pointer;background:0 0;border:none;border-radius:11px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-size:.88rem;font-weight:600;transition:all .25s;display:flex}.dash-tab:hover{color:var(--text);background:#3b82f60f}.dash-tab.active{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;box-shadow:0 4px 16px var(--primary-glow)}.dash-tab-badge{background:#ffffff26;border-radius:8px;padding:2px 7px;font-size:.7rem;font-weight:700}.dash-tab:not(.active) .dash-tab-badge{color:var(--primary);background:#3b82f61f}.dash-card-share:hover{color:#10b981;background:#10b9811a;border-color:#10b981}.dash-shared-badge{color:#10b981;background:#10b9811a;border-radius:8px;align-items:center;gap:5px;margin-bottom:8px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.dash-shared-outgoing{color:var(--primary);background:#3b82f61a}.dash-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.dash-modal{background:var(--bg-sidebar);border:1px solid var(--border-light);width:100%;max-width:480px;animation:slideUp .3s var(--ease);border-radius:18px;box-shadow:0 24px 80px #0006}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dash-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.dash-modal-header h3{color:var(--text);align-items:center;gap:10px;font-size:1.1rem;font-weight:700;display:flex}.dash-modal-header h3 svg{color:var(--primary)}.dash-modal-close{border:1px solid var(--border);width:32px;height:32px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.dash-modal-close:hover{color:var(--danger);border-color:var(--danger);background:#ef44441a}.dash-modal-body{padding:24px}.dash-modal-body p{color:var(--text-muted);margin-bottom:18px;font-size:.88rem;line-height:1.5}.dash-share-modes{gap:10px;margin-bottom:18px;display:flex}.dash-share-mode{border:2px solid var(--border);background:var(--bg);cursor:pointer;font-family:var(--font);text-align:start;border-radius:12px;flex:1;align-items:flex-start;gap:12px;padding:14px 16px;transition:all .2s;display:flex}.dash-share-mode:hover{border-color:var(--primary)}.dash-share-mode.active{border-color:var(--primary);background:#3b82f60f}.dash-share-mode svg{color:var(--primary);flex-shrink:0;margin-top:2px}.dash-share-mode strong{color:var(--text);margin-bottom:3px;font-size:.88rem;display:block}.dash-share-mode span{color:var(--text-muted);font-size:.75rem;line-height:1.4}.dash-invites{margin-bottom:24px}.dash-invites h3{color:var(--text);align-items:center;gap:8px;margin-bottom:12px;font-size:1rem;font-weight:700;display:flex}.dash-invites h3 svg{color:#f59e0b}.dash-invite-card{background:linear-gradient(135deg,#f59e0b0f,#fb923c08);border:1px solid #f59e0b40;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:16px 20px;display:flex}.dash-invite-info strong{color:var(--text);margin-bottom:2px;font-size:.95rem;display:block}.dash-invite-info span{color:var(--text-muted);font-size:.8rem}.dash-invite-actions{gap:8px;display:flex}.dash-invite-accept,.dash-invite-decline{font-family:var(--font);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:700;transition:all .2s;display:flex}.dash-invite-accept{color:#fff;background:linear-gradient(135deg,#10b981,#059669)}.dash-invite-accept:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.dash-invite-decline{border:1px solid var(--border);color:var(--text-muted);background:0 0}.dash-invite-decline:hover{color:var(--danger);border-color:var(--danger)}.dash-share-input-row{background:var(--bg);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;display:flex}.dash-share-input-row svg{color:var(--text-muted);flex-shrink:0}.dash-share-input{color:var(--text);font-family:var(--font);background:0 0;border:none;outline:none;flex:1;font-size:.92rem}.dash-share-input::placeholder{color:var(--text-muted)}.dash-share-btn{color:#fff;font-family:var(--font);cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.dash-share-btn:disabled{opacity:.4;cursor:not-allowed}.dash-share-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 14px #10b9814d}.dash-share-status{border-radius:10px;align-items:center;gap:8px;margin-bottom:14px;padding:10px 14px;font-size:.85rem;font-weight:600;animation:.3s fadeIn;display:flex}.dash-share-success{color:#10b981;background:#10b9811f}.dash-share-error{color:var(--danger);background:#ef44441f}.dash-shared-list{border-top:1px solid var(--border);margin-top:18px;padding-top:18px}.dash-shared-list h4{color:var(--text-dim);margin-bottom:10px;font-size:.82rem;font-weight:600}.dash-shared-person{background:var(--bg);color:var(--text);border-radius:8px;align-items:center;gap:8px;margin-bottom:6px;padding:8px 12px;font-size:.85rem;display:flex}.dash-shared-person svg{color:var(--text-muted)}.dash-profile-section{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px;display:grid}@media (width<=768px){.dash-profile-section{grid-template-columns:1fr}}.dash-profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:28px}.dash-profile-card h3{color:var(--text);align-items:center;gap:10px;margin-bottom:6px;font-size:1.05rem;font-weight:700;display:flex}.dash-profile-card h3 svg{color:var(--primary)}.dash-profile-desc{color:var(--text-muted);margin-bottom:22px;font-size:.82rem}.dash-profile-field{margin-bottom:20px}.dash-profile-field label{color:var(--text-dim);margin-bottom:8px;font-size:.82rem;font-weight:600;display:block}.dash-profile-input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);font-family:var(--font);border-radius:10px;outline:none;padding:12px 14px;font-size:.92rem;transition:border-color .2s}.dash-profile-input:focus{border-color:var(--primary)}.dash-logo-upload{min-height:120px}.dash-logo-preview{display:inline-block;position:relative}.dash-logo-preview img{border:1px solid var(--border);border-radius:10px;max-width:200px;max-height:100px}.dash-logo-remove{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:absolute;top:-8px;right:-8px}.dash-logo-placeholder{border:2px dashed var(--border-light);color:var(--text-muted);cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:28px;transition:all .2s;display:flex}.dash-logo-placeholder:hover{border-color:var(--primary);color:var(--primary);background:#3b82f60a}.dash-logo-placeholder span{font-size:.82rem;font-weight:500}.dash-profile-save{background:linear-gradient(135deg, var(--primary), #1d4ed8);color:#fff;width:100%;font-family:var(--font);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.92rem;font-weight:700;transition:all .2s;display:flex}.dash-profile-save:hover{box-shadow:0 6px 20px var(--primary-glow);transform:translateY(-1px)}.dash-pdf-preview{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-top:14px;padding:20px}.dash-pdf-header{border-bottom:2px solid #2563eb;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:14px;display:flex}.dash-pdf-logo{border-radius:4px;max-width:50px;max-height:40px}.dash-pdf-header strong{color:#1e293b;font-size:.85rem;display:block}.dash-pdf-header span{color:#94a3b8;font-size:.72rem}.dash-pdf-body{padding-top:4px}.dash-pdf-line{background:#f1f5f9;border-radius:4px;height:8px;margin-bottom:8px}.dash-pdf-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;height:60px;margin-top:12px}.dash-guest-banner{color:var(--text);background:linear-gradient(135deg,#fb923c14,#f973160a);border:1px solid #fb923c4d;border-radius:14px;align-items:center;gap:16px;margin-bottom:24px;padding:18px 24px;display:flex}.dash-guest-banner svg{color:#f97316;flex-shrink:0}.dash-guest-banner strong{margin-bottom:2px;font-size:.92rem;display:block}.dash-guest-banner p{color:var(--text-muted);margin:0;font-size:.82rem}.dash-guest-signin{color:#fff;font-family:var(--font);cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#f97316,#ea580c);border:none;border-radius:10px;margin-inline-start:auto;padding:10px 20px;font-size:.85rem;font-weight:700;transition:all .2s}.dash-guest-signin:hover{transform:translateY(-1px);box-shadow:0 4px 14px #f973164d}.dash-academy-banner{cursor:pointer;transition:all .3s var(--ease);background:linear-gradient(135deg,#3b82f61a,#3b82f60f);border:1.5px solid #3b82f64d;border-radius:16px;align-items:center;gap:20px;margin-bottom:24px;padding:24px 28px;display:flex;position:relative;overflow:hidden}.dash-academy-banner:hover{border-color:#3b82f680;transform:translateY(-2px);box-shadow:0 8px 32px #3b82f626}.dash-academy-banner-glow{pointer-events:none;background:radial-gradient(at 20%,#3b82f61f 0%,#0000 60%);position:absolute;inset:0}.dash-academy-banner-content{z-index:1;flex:1;align-items:center;gap:20px;display:flex;position:relative}.dash-academy-banner-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex;box-shadow:0 4px 16px #3b82f659}.dash-academy-banner-text{flex:1}.dash-academy-banner-text h3{color:var(--text);margin:0 0 4px;font-size:1.05rem;font-weight:700}.dash-academy-banner-text p{color:var(--text-muted);margin:0;font-size:.82rem;line-height:1.5}.dash-academy-banner-stats{flex-shrink:0;gap:16px;display:flex}.dash-academy-banner-stats span{color:#3b82f6;white-space:nowrap;background:#3b82f614;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.78rem;font-weight:600;display:flex}.dash-academy-banner-arrow{color:var(--text-muted);z-index:1;flex-shrink:0;transition:transform .3s;position:relative}[dir=rtl] .dash-academy-banner-arrow{transform:scaleX(-1)}.dash-academy-banner:hover .dash-academy-banner-arrow{color:#2563eb}[dir=rtl] .dash-academy-banner:hover .dash-academy-banner-arrow{transform:scaleX(-1)translate(4px)}.dash-academy-btn{color:#3b82f6!important}.dash-academy-btn:hover{background:#3b82f61a!important}@media (width<=768px){.dash-academy-banner-content{flex-direction:column;align-items:flex-start;gap:12px}.dash-academy-banner-stats{flex-direction:column;gap:8px}}@media (width<=480px){.dash-academy-banner{gap:14px;padding:16px 18px}.dash-academy-banner-icon{border-radius:10px;width:44px;height:44px}.dash-academy-banner-icon svg{width:22px;height:22px}}.dash-nav-actions .dash-tip-wrap .dash-tip{top:calc(100% + 8px);bottom:auto;transform:translate(-50%)translateY(-4px)}.dash-nav-actions .dash-tip-wrap .dash-tip:after{border-top-color:#0000;border-bottom-color:#0f111eeb;top:auto;bottom:100%}.dash-nav-actions .dash-tip-wrap:hover .dash-tip{transform:translate(-50%)translateY(0)}@media (width<=768px){.dash-nav-inner{padding:10px 16px}.dash-user-name{display:none}.dash-hero{padding:32px 16px 24px}.dash-hero-sub{margin-inline-start:0}.dash-container{padding:0 16px 40px}.dash-new-btn{padding:16px 20px}.dash-new-icon{width:44px;height:44px}.dash-grid{grid-template-columns:1fr}.dash-card-actions{opacity:1}.dash-card-open{opacity:1;transform:translate(0)}.dash-tabs,.dash-guest-banner{flex-wrap:wrap}}@media (width<=480px){.dash-greeting h1{font-size:1.2rem}.dash-logo-text{display:none}.dash-tab{padding:10px 12px;font-size:.78rem}}.dash-tree{flex-direction:column;gap:4px;display:flex}.dash-tree-actions{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.dash-tree-add-btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:.84rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .2s var(--ease);border-radius:10px;align-items:center;gap:7px;padding:9px 18px;display:inline-flex}.dash-tree-add-btn:hover{border-color:var(--primary);color:var(--primary);background:linear-gradient(135deg,#3b82f60f,#3b82f608)}.dash-tree-add-quick{color:var(--primary);background:linear-gradient(135deg,#3b82f614,#3b82f60a);border-color:#3b82f64d}.dash-tree-add-quick:hover{box-shadow:0 4px 16px var(--primary-glow);background:linear-gradient(135deg,#3b82f624,#3b82f614)}.dash-tree-node{border-radius:10px}.dash-tree-row{cursor:pointer;transition:all .15s var(--ease);border:1px solid #0000;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.dash-tree-row:hover{background:var(--surface-hover)}.dash-tree-row.expanded{background:#3b82f60a;border-color:#3b82f61a}.dash-tree-row-main{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.dash-tree-chevron{color:var(--text-muted);transition:transform .2s var(--ease);flex-shrink:0}.dash-tree-chevron.open{transform:rotate(90deg)}[dir=rtl] .dash-tree-chevron{transform:scaleX(-1)}[dir=rtl] .dash-tree-chevron.open{transform:scaleX(-1)rotate(90deg)}.dash-tree-icon{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.dash-tree-icon-client{background:linear-gradient(135deg,#10b981,#059669)}.dash-tree-icon-project{background:linear-gradient(135deg,#2563eb,#3b82f6)}.dash-tree-icon-room{background:linear-gradient(135deg,#f59e0b,#d97706)}.dash-tree-info{flex-direction:column;min-width:0;display:flex}.dash-tree-info strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;overflow:hidden}.dash-tree-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.76rem;overflow:hidden}.dash-tree-row-actions{opacity:0;flex-shrink:0;gap:4px;transition:opacity .15s;display:flex}.dash-tree-row:hover .dash-tree-row-actions{opacity:1}.dash-tree-action{background:var(--surface);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border:none;border-radius:7px;justify-content:center;align-items:center;transition:all .15s;display:flex}.dash-tree-action:hover{background:var(--primary);color:#fff}.dash-tree-action-danger:hover{background:var(--danger);color:#fff}.dash-tree-children{border-inline-start:2px solid var(--border);margin-top:2px;margin-bottom:4px;margin-inline-start:24px;padding-inline-start:28px}.dash-tree-empty{padding:8px 16px}.dash-tree-empty-btn{border:1px dashed var(--border-light);color:var(--text-muted);font-size:.8rem;font-weight:600;font-family:var(--font);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;transition:all .2s;display:inline-flex}.dash-tree-empty-btn:hover{border-color:var(--primary);color:var(--primary);background:#3b82f60d}.dash-tree-inline-add{color:var(--text-muted);font-size:.76rem;font-weight:600;font-family:var(--font);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;margin:4px 0 4px 16px;padding:5px 12px;transition:all .15s;display:inline-flex}.dash-tree-inline-add:hover{opacity:1;color:var(--primary);background:#3b82f60f}.dash-tree-designs{padding-top:4px;padding-bottom:4px}.dash-grid-compact{gap:12px!important}.dash-grid-compact .dash-card{min-height:auto}.dash-tree-standalone{border-top:1px solid var(--border);margin-top:24px;padding-top:24px}.dash-section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.dash-section-title{color:var(--text);align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.dash-section-count{color:var(--text-muted);background:var(--surface);border-radius:10px;padding:3px 10px;font-size:.78rem;font-weight:600}.dash-recent-section{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:1.5rem}.dash-recent-scroll{scrollbar-width:thin;gap:1rem;padding:.75rem 0 .5rem;display:flex;overflow-x:auto}.dash-recent-scroll .design-card{flex-shrink:0;min-width:220px}.dash-profile-input{font-family:var(--font)}select.dash-profile-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}[dir=rtl] select.dash-profile-input{background-position:12px;padding-left:32px;padding-right:12px}textarea.dash-profile-input{line-height:1.5}.feedback-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.feedback-header h3{align-items:center;gap:8px;margin:0;font-size:1.1rem;font-weight:700;display:flex}.feedback-list{flex-direction:column;gap:10px;display:flex}.feedback-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s;overflow:hidden}.feedback-item:hover{border-color:var(--border-hover,var(--border))}.feedback-item-header{cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.feedback-item-right{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.feedback-item-info{flex-direction:column;gap:2px;min-width:0;display:flex}.feedback-item-title{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.feedback-item-date{color:var(--text-muted);align-items:center;gap:4px;font-size:.75rem;display:flex}.feedback-item-left{flex-shrink:0;align-items:center;gap:10px;display:flex}.feedback-status-badge{white-space:nowrap;border-radius:10px;align-items:center;padding:2px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.feedback-response-count{color:var(--text-muted);white-space:nowrap;font-size:.72rem}.feedback-item-body{border-top:1px solid var(--border);padding:0 18px 16px}.feedback-item-desc{white-space:pre-wrap;color:var(--text);margin:14px 0 0;font-size:.88rem;line-height:1.6}.feedback-responses{margin-top:16px}.feedback-responses h4{color:var(--text-muted);margin:0 0 10px;font-size:.82rem;font-weight:700}.feedback-response-bubble{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;padding:12px 14px}.feedback-response-meta{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.75rem;display:flex}.feedback-response-meta strong{color:var(--primary)}.feedback-response-meta span{color:var(--text-muted)}.feedback-response-bubble p{margin:0;font-size:.85rem;line-height:1.5}.feedback-modal{width:90vw;max-width:560px}.feedback-form{flex-direction:column;gap:16px;display:flex}.feedback-field{flex-direction:column;gap:6px;display:flex}.feedback-field label{color:var(--text);font-size:.82rem;font-weight:600}.feedback-categories{flex-wrap:wrap;gap:8px;display:flex}.feedback-cat-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:600;font-family:var(--font);border-radius:8px;align-items:center;gap:6px;padding:6px 14px;transition:all .15s;display:inline-flex}.feedback-cat-btn:hover{border-color:var(--text-muted)}.feedback-priorities{gap:8px;display:flex}.feedback-priority-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:600;font-family:var(--font);text-align:center;border-radius:8px;flex:1;padding:6px 12px;transition:all .15s}.feedback-priority-btn:hover{border-color:var(--text-muted)}.feedback-textarea{resize:vertical;min-height:100px;font-family:var(--font)}.feedback-context-note{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:.75rem}.feedback-error{color:var(--danger,#ef4444);font-size:.82rem;font-weight:600}.feedback-submit{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.feedback-admin-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:20px;display:grid}.feedback-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:16px 20px}.feedback-stat-card .stat-value{margin:0;font-size:1.6rem;font-weight:800}.feedback-stat-card .stat-label{color:var(--text-muted);margin-top:2px;font-size:.75rem}.feedback-filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.feedback-filter-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--font);border-radius:8px;padding:5px 14px;transition:all .15s}.feedback-filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.feedback-search-input{border:1px solid var(--border);background:var(--bg);min-width:180px;color:var(--text);font-size:.82rem;font-family:var(--font);border-radius:8px;outline:none;flex:1;padding:6px 14px}.feedback-search-input:focus{border-color:var(--primary)}.feedback-admin-detail{border-top:1px solid var(--border);padding:16px 18px}.feedback-context-panel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px;margin:12px 0;padding:12px 16px;font-size:.78rem;display:grid}.feedback-context-panel dt{color:var(--text-muted);font-size:.72rem;font-weight:700}.feedback-context-panel dd{word-break:break-all;margin:0 0 6px}.feedback-admin-response-box{flex-direction:column;gap:8px;margin-top:14px;display:flex}.feedback-admin-response-box textarea{resize:vertical;border:1px solid var(--border);background:var(--bg);width:100%;min-height:70px;color:var(--text);font-size:.85rem;font-family:var(--font);border-radius:8px;outline:none;padding:10px 14px}.feedback-admin-response-box textarea:focus{border-color:var(--primary)}.feedback-admin-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.feedback-admin-actions label{color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;font-size:.78rem;display:flex}.feedback-admin-actions select{border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.78rem;font-family:var(--font);border-radius:6px;padding:5px 10px}.feedback-user-info{color:var(--text-muted);align-items:center;gap:8px;font-size:.78rem;display:flex}.feedback-user-plan{text-transform:uppercase;border-radius:6px;padding:1px 8px;font-size:.65rem;font-weight:700;display:inline-flex}.feedback-snapshot-summary{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:12px;margin:8px 0;padding:10px 14px;font-size:.78rem;display:flex}.feedback-snapshot-summary .snapshot-details{flex-wrap:wrap;gap:12px;display:flex}.feedback-snapshot-summary .snapshot-detail{align-items:center;gap:4px;display:flex}.feedback-snapshot-summary .snapshot-detail strong{color:var(--text-muted);font-size:.7rem}@media (width<=768px){.dash-tree-children{margin-inline-start:14px;padding-inline-start:14px}.dash-tree-row{padding:10px 12px}.dash-tree-row-actions{opacity:1}.dash-tree-actions{flex-direction:column}}
