@import"https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;padding-bottom:12vh;position:relative;overflow:hidden;background:var(--bg)}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(color-mix(in srgb,var(--border) 35%,transparent) 1px,transparent 1px),linear-gradient(90deg,color-mix(in srgb,var(--border) 35%,transparent) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 100%)}.login-page:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle 2px at center,color-mix(in srgb,var(--accent) 30%,transparent) 0%,transparent 100%);background-size:48px 48px;background-position:-1px -1px;mask-image:radial-gradient(ellipse 50% 45% at 50% 40%,black 0%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 50% 45% at 50% 40%,black 0%,transparent 100%)}.login-container{width:100%;max-width:420px;position:relative;z-index:1}.login-brand{text-align:center;margin-bottom:32px;animation:login-brand-enter .6s cubic-bezier(.22,1,.36,1) both}.login-brand h1{font-family:Instrument Sans,system-ui,sans-serif;font-size:44px;font-weight:700;letter-spacing:-.04em;color:var(--text);line-height:1.1}.login-brand h1 span{color:var(--brand, var(--accent))}.login-brand h1 em{font-style:normal;font-weight:400;color:var(--text-muted)}.login-brand p{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:15px;font-weight:500;letter-spacing:.01em;color:var(--text-muted);margin-top:6px}.login-banner{background:color-mix(in srgb,var(--bg-surface) 80%,transparent);border:1px solid color-mix(in srgb,var(--border) 50%,transparent);border-radius:10px;padding:10px 20px;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:16px;text-align:center;line-height:1.5;white-space:pre-line;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:login-field-enter .4s cubic-bezier(.22,1,.36,1) .1s both}.login-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;padding:36px;position:relative;overflow:hidden;box-shadow:0 1px 2px var(--shadow-ambient),0 8px 32px -8px var(--shadow-direct),0 24px 48px -16px var(--shadow-ambient);animation:login-card-enter .5s cubic-bezier(.22,1,.36,1) .15s both}.login-card:before{content:"";position:absolute;top:0;left:36px;right:36px;height:2px;background:linear-gradient(90deg,transparent,var(--brand) 20%,var(--accent) 80%,transparent);opacity:.7}.login-tabs{display:flex;gap:4px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:4px;margin-bottom:28px}.login-tab{flex:1;padding:10px 16px;font-family:Instrument Sans,system-ui,sans-serif;font-size:13px;font-weight:500;color:var(--text-dim);background:transparent;border:none;border-radius:calc(var(--radius-lg) - 4px);cursor:pointer;transition:color .2s,background .2s,box-shadow .2s;text-align:center}.login-tab:hover:not(.active){color:var(--text);background:var(--bg-hover)}.login-tab.active{background:var(--bg-surface);color:var(--text);font-weight:600;box-shadow:0 1px 3px #00000014,0 0 0 1px var(--border)}.login-form-group{margin-bottom:20px;animation:login-field-enter .4s cubic-bezier(.22,1,.36,1) both}.login-form-group:nth-child(1){animation-delay:.25s}.login-form-group:nth-child(2){animation-delay:.3s}.login-form-group:nth-child(3){animation-delay:.35s}.login-label{display:block;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:8px}.login-input{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1)}.login-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-surface),0 2px 8px color-mix(in srgb,var(--accent) 15%,transparent)}.login-input::placeholder{color:var(--text-dim)}.login-alert{padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:20px;display:flex;align-items:center;gap:8px;animation:login-alert-in .25s cubic-bezier(.22,1,.36,1)}.login-alert-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.login-alert.success{background:var(--green-surface);border:1px solid color-mix(in srgb,var(--green) 20%,transparent);color:var(--green)}.login-alert.success .login-alert-dot{background:var(--green)}.login-alert.error{background:var(--red-surface);border:1px solid color-mix(in srgb,var(--red) 20%,transparent);color:var(--red)}.login-alert.error .login-alert-dot{background:var(--red)}.login-alert.warning{background:var(--orange-surface);border:1px solid color-mix(in srgb,var(--orange) 20%,transparent);color:var(--orange)}.login-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-family:Instrument Sans,system-ui,sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);animation:login-field-enter .4s cubic-bezier(.22,1,.36,1) .4s both}.login-submit:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px color-mix(in srgb,var(--accent) 45%,transparent),0 1px 3px #0003}.login-submit:active:not(:disabled){transform:translateY(0);box-shadow:none}.login-submit:disabled{opacity:.5;cursor:not-allowed}@keyframes login-brand-enter{0%{opacity:0;transform:translateY(20px);filter:blur(4px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}@keyframes login-card-enter{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes login-field-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes login-alert-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.login-page{padding-bottom:20px}.login-brand h1{font-size:32px}.login-card{padding:24px;border-radius:14px}.login-card:before{left:24px;right:24px}}:root,[data-theme=one-dark]{--font-display: "Instrument Sans", system-ui, sans-serif;--font-body: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--bg: #282c34;--bg-surface: #1a1d23;--bg-hover: #2c313a;--bg-input: #1d2026;--border: #3e4452;--border-focus: #4da8f7;--text: #c8ccd4;--text-muted: #959ba5;--text-dim: #6b717d;--accent: #4da8f7;--accent-hover: #6db8fa;--accent-surface: rgba(77, 168, 247, .14);--green: #98c379;--green-surface: rgba(152, 195, 121, .12);--red: #e06c75;--red-surface: rgba(224, 108, 117, .12);--orange: #d19a66;--orange-surface: rgba(209, 154, 102, .12);--brand: var(--accent);--radius: 8px;--radius-lg: 12px;--noise-opacity: .03;--glow-strength: .15;--shadow-ambient: rgba(0, 0, 0, .25);--shadow-direct: rgba(0, 0, 0, .35);--sidebar-bg-top: #181b20;--sidebar-bg-bottom: #14161b;--status-working: #5b8def;--status-failed: #e05545;--status-testing: #e59e2f;--status-production: #36b366;--purple: #c678dd;--cyan: #56b6c2;--yellow: #e5c07b;--gray: #abb2bf;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}[data-theme=github-light]{--bg: #ffffff;--bg-surface: #f6f8fa;--bg-hover: #eaeef2;--bg-input: #f6f8fa;--border: #d0d7de;--border-focus: #0969da;--text: #1b1f24;--text-muted: #4d5560;--text-dim: #6e7681;--accent: #0969da;--accent-hover: #0550ae;--accent-surface: rgba(9, 105, 218, .08);--green: #1a7f37;--green-surface: rgba(26, 127, 55, .08);--red: #cf222e;--red-surface: rgba(207, 34, 46, .08);--orange: #bc4c00;--orange-surface: rgba(188, 76, 0, .08);--shadow: rgba(31, 35, 40, .08);--noise-opacity: .025;--glow-strength: .08;--shadow-ambient: rgba(0, 0, 0, .06);--shadow-direct: rgba(0, 0, 0, .1);--sidebar-bg-top: #2b2f38;--sidebar-bg-bottom: #242830;--status-working: #3b6fcc;--status-failed: #c43d2e;--status-testing: #b87d1a;--status-production: #1e8a4a;--purple: #8250df;--cyan: #0e7c86;--yellow: #9a6700;--gray: #6e7681;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}[data-theme=dracula]{--bg: #282a36;--bg-surface: #21222c;--bg-hover: #343746;--bg-input: #1e1f29;--border: #44475a;--border-focus: #c89dff;--text: #f8f8f2;--text-muted: #b0b0c0;--text-dim: #6272a4;--accent: #c89dff;--accent-hover: #d4adff;--accent-surface: rgba(200, 157, 255, .14);--green: #50fa7b;--green-surface: rgba(80, 250, 123, .12);--red: #ff5555;--red-surface: rgba(255, 85, 85, .12);--orange: #ffb86c;--orange-surface: rgba(255, 184, 108, .12);--radius: 8px;--radius-lg: 12px;--noise-opacity: .03;--glow-strength: .15;--shadow-ambient: rgba(0, 0, 0, .25);--shadow-direct: rgba(0, 0, 0, .35);--sidebar-bg-top: #1e1f29;--sidebar-bg-bottom: #191a24;--status-working: #8be9fd;--status-failed: #ff5555;--status-testing: #f1fa8c;--status-production: #50fa7b;--purple: #ff79c6;--cyan: #8be9fd;--yellow: #f1fa8c;--gray: #6272a4;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}[data-theme=one-light]{--bg: #fafafa;--bg-surface: #f0f0f0;--bg-hover: #e5e5e6;--bg-input: #eaeaeb;--border: #d3d3d5;--border-focus: #4078f2;--text: #2e3038;--text-muted: #555961;--text-dim: #82838a;--accent: #4078f2;--accent-hover: #526fff;--accent-surface: rgba(64, 120, 242, .08);--green: #50a14f;--green-surface: rgba(80, 161, 79, .08);--red: #e45649;--red-surface: rgba(228, 86, 73, .08);--orange: #c18401;--orange-surface: rgba(193, 132, 1, .08);--shadow: rgba(0, 0, 0, .06);--noise-opacity: .025;--glow-strength: .08;--shadow-ambient: rgba(0, 0, 0, .06);--shadow-direct: rgba(0, 0, 0, .1);--sidebar-bg-top: #2e3038;--sidebar-bg-bottom: #282a30;--status-working: #4078f2;--status-failed: #e45649;--status-testing: #c18401;--status-production: #50a14f;--purple: #a626a4;--cyan: #0184bc;--yellow: #c18401;--gray: #82838a;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}[data-theme=tokyo-night]{--bg: #1a1b26;--bg-surface: #16161e;--bg-hover: #24283b;--bg-input: #15151f;--border: #33364a;--border-focus: #6b9cff;--text: #c0caf5;--text-muted: #9aa5ce;--text-dim: #565f89;--accent: #6b9cff;--accent-hover: #85b0ff;--accent-surface: rgba(107, 156, 255, .14);--green: #9ece6a;--green-surface: rgba(158, 206, 106, .12);--red: #f7768e;--red-surface: rgba(247, 118, 142, .12);--orange: #e0af68;--orange-surface: rgba(224, 175, 104, .12);--radius: 8px;--radius-lg: 12px;--noise-opacity: .03;--glow-strength: .15;--shadow-ambient: rgba(0, 0, 0, .3);--shadow-direct: rgba(0, 0, 0, .4);--sidebar-bg-top: #141520;--sidebar-bg-bottom: #10111a;--status-working: #7aa2f7;--status-failed: #f7768e;--status-testing: #e0af68;--status-production: #9ece6a;--purple: #bb9af7;--cyan: #7dcfff;--yellow: #e0af68;--gray: #565f89;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}[data-theme=monokai]{--bg: #272822;--bg-surface: #1e1f1a;--bg-hover: #35362e;--bg-input: #22231d;--border: #464840;--border-focus: #a6e22e;--text: #f8f8f2;--text-muted: #b0b0a4;--text-dim: #75715e;--accent: #a6e22e;--accent-hover: #b5ed4c;--accent-surface: rgba(166, 226, 46, .12);--green: #a6e22e;--green-surface: rgba(166, 226, 46, .12);--red: #f92672;--red-surface: rgba(249, 38, 114, .12);--orange: #fd971f;--orange-surface: rgba(253, 151, 31, .12);--radius: 8px;--radius-lg: 12px;--noise-opacity: .03;--glow-strength: .15;--shadow-ambient: rgba(0, 0, 0, .25);--shadow-direct: rgba(0, 0, 0, .35);--sidebar-bg-top: #1c1d18;--sidebar-bg-bottom: #171813;--status-working: #66d9ef;--status-failed: #f92672;--status-testing: #fd971f;--status-production: #a6e22e;--purple: #ae81ff;--cyan: #66d9ef;--yellow: #e6db74;--gray: #75715e;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}[data-theme=netauto-studio]{--bg: #eaecf1;--bg-surface: #ffffff;--bg-hover: #dce0e8;--bg-input: #f3f5f8;--border: #c4cad4;--border-focus: #2563a8;--text: #1a2332;--text-muted: #475569;--text-dim: #7c8a9a;--accent: #2563a8;--accent-hover: #1d4f8a;--accent-surface: rgba(37, 99, 168, .1);--green: #15803d;--green-surface: rgba(21, 128, 61, .1);--red: #b91c2c;--red-surface: rgba(185, 28, 44, .1);--orange: #b45309;--orange-surface: rgba(180, 83, 9, .1);--brand: #c86d3c;--shadow: rgba(18, 35, 58, .14);--radius: 8px;--radius-lg: 12px;--noise-opacity: .02;--glow-strength: .12;--shadow-ambient: rgba(0, 0, 0, .1);--shadow-direct: rgba(0, 0, 0, .18);--sidebar-bg-top: #1e3550;--sidebar-bg-bottom: #152740;--status-working: #2563a8;--status-failed: #b91c2c;--status-testing: #b45309;--status-production: #15803d;--purple: #7c3aed;--cyan: #0e7490;--yellow: #a16207;--gray: #7c8a9a;--sidebar-text: #adb7c8;--sidebar-text-hover: #dce2ec;--sidebar-text-dim: #6a7588;--sidebar-text-muted: #8a95a8;--sidebar-text-bright: #ffffff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code,pre,.mono{font-family:JetBrains Mono,monospace}button:focus-visible,.btn:focus-visible,a:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible,.nav-link:focus-visible,.tab:focus-visible,.catalog-tab:focus-visible,.catalog-item:focus-visible,.catalog-category-header:focus-visible,.theme-option:focus-visible,.editor-mode-btn:focus-visible,.catalog-sub-toggle-btn:focus-visible,.device-item:focus-visible,.project-card:focus-visible,.project-list-item:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.form-input:focus-visible,.form-textarea:focus-visible,.form-select:focus-visible{outline:none}.editor-mode-toggle{display:flex;gap:2px;background:var(--bg-hover);border-radius:999px;padding:2px}.editor-mode-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:12px;font-weight:600;color:var(--text-muted);background:none;border:none;border-radius:999px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.editor-mode-btn:hover{color:var(--text)}.editor-mode-btn.active{background:var(--bg-surface);color:var(--accent);box-shadow:0 1px 3px #00000026}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w, 260px);background:linear-gradient(180deg,var(--sidebar-bg-top) 0%,var(--sidebar-bg-bottom) 100%);border-right:1px solid color-mix(in srgb,var(--sidebar-bg-top) 70%,var(--border));padding:16px 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10;overflow:hidden;box-shadow:1px 0 20px -4px #0003}.sidebar-resize-handle{position:absolute;top:0;right:-3px;bottom:0;width:6px;cursor:col-resize;z-index:20}.sidebar-resize-handle:after{content:"";position:absolute;top:0;right:2px;bottom:0;width:2px;background:transparent;transition:background .15s;border-radius:1px}.sidebar-resize-handle:hover:after,.sidebar.is-resizing .sidebar-resize-handle:after{background:var(--accent)}.sidebar.is-resizing,.sidebar.is-resizing~.main-content{transition:none!important}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:4px 14px 14px 20px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:4px}.sidebar-brand-text{flex:1;min-width:0}.sidebar-brand h1{font-family:Instrument Sans,system-ui,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--sidebar-text-bright)}.sidebar-brand h1 span{color:var(--brand);text-shadow:0 0 12px color-mix(in srgb,var(--brand) 25%,transparent)}.sidebar-brand h1 em{font-style:normal;font-weight:500;color:var(--sidebar-text-muted)}.sidebar-brand p{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:11.5px;font-weight:600;color:var(--sidebar-text-dim);margin-top:3px;letter-spacing:.04em;text-transform:uppercase;text-transform:none}.sidebar-nav{flex:1;padding:0 10px;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);color:var(--sidebar-text);text-decoration:none;font-size:14px;font-weight:500;transition:all .15s;letter-spacing:-.01em;position:relative;margin-bottom:2px}.nav-link:hover{background:#ffffff14;color:var(--sidebar-text-hover)}.nav-link.active{background:#ffffff24;color:var(--sidebar-text-bright);font-weight:700;border-left:3px solid var(--brand);padding-left:9px;border-radius:0 var(--radius) var(--radius) 0;box-shadow:inset 4px 0 12px -6px color-mix(in srgb,var(--brand) 35%,transparent)}.nav-section-label{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--sidebar-text-dim);padding:14px 12px 6px;border-top:1px solid rgba(255,255,255,.06);margin-top:4px}.nav-section-label.first{border-top:none;margin-top:0;padding-top:8px}.nav-link-nested{padding-left:20px;font-size:13px}.nav-link-nested.active{padding-left:17px}.nav-project-label{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:11px;font-weight:600;color:var(--brand);padding:8px 12px 4px 16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-project-group .nav-link{padding-left:20px}.nav-project-group .nav-link.active{padding-left:17px}.main-content{margin-left:var(--sidebar-w, 260px);flex:1;padding:32px;max-width:1200px;min-width:0}.main-content:has(.two-col){max-width:none}.main-content:has(.workshop-page){max-width:none;padding:0}.page-header{margin-bottom:28px;animation:page-enter .35s cubic-bezier(.22,1,.36,1) both;position:relative}.page-header:after{content:"";position:absolute;bottom:-12px;left:0;width:80px;height:3px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:2px}.page-header h2{font-family:Instrument Sans,system-ui,sans-serif;font-size:28px;font-weight:700;letter-spacing:-.03em}.page-header p{color:var(--text-dim);font-size:13px;margin-top:4px}.page-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:2px;margin-bottom:12px}.breadcrumb-item{display:inline-flex;align-items:center;gap:2px}.breadcrumb-sep{color:var(--text-dim);margin:0 4px;flex-shrink:0}.breadcrumb-link{font-size:12px;font-weight:500;color:var(--text-dim);text-decoration:none;letter-spacing:.01em;transition:color .15s}.breadcrumb-link:hover{color:var(--accent)}.breadcrumb-current{font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.01em}.breadcrumb-muted{font-family:JetBrains Mono,monospace;font-size:11.5px;color:var(--text-muted);font-weight:500;background:var(--bg-hover);padding:2px 7px;border-radius:var(--radius)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 2px var(--shadow-ambient),0 0 0 1px color-mix(in srgb,var(--border) 50%,transparent)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-header h3{font-size:16px;font-weight:700;letter-spacing:-.01em}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.project-card{cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.project-card:hover{border-color:color-mix(in srgb,var(--accent) 60%,var(--border));transform:translateY(-2px);box-shadow:0 8px 24px -8px color-mix(in srgb,var(--accent) 20%,transparent),0 2px 8px var(--shadow-ambient)}.project-card h3{font-size:16px;font-weight:700;margin-bottom:6px;letter-spacing:-.01em}.project-card .desc{font-size:13px;color:var(--text-muted);margin-bottom:12px}.project-card .meta{display:flex;gap:16px;font-size:12px;color:var(--text-dim);flex-wrap:wrap;align-items:center}.project-card-actions{opacity:0;transition:opacity .1s}.project-card:hover .project-card-actions{opacity:1}.project-card-stats{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--text-muted);margin-bottom:8px}.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.view-toggle .btn{border-radius:0;border:none;padding:6px 10px}.view-toggle .btn.active{background:var(--accent-surface);color:var(--accent)}.project-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.project-list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.project-list-item:last-child{border-bottom:none}.project-list-item:hover{background:var(--bg-hover)}.project-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-list-name{font-size:14px;font-weight:600;display:flex;align-items:center}.project-list-desc{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-list-meta{font-size:12px;color:var(--text-dim);white-space:nowrap;min-width:70px}.project-list-dates,.project-card-dates{display:flex;flex-direction:column;gap:2px;text-align:right}.project-date{font-size:12px;color:var(--text-dim);white-space:nowrap}.date-label{color:var(--text-muted);margin-right:4px}.project-list-actions{display:flex;gap:4px;opacity:0;transition:opacity .1s}.project-list-item:hover .project-list-actions{opacity:1}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-pulse{animation:btn-pulse-anim .5s ease-in-out 3}@keyframes btn-pulse-anim{0%,to{transform:scale(1);box-shadow:none}50%{transform:scale(1.08);box-shadow:0 0 12px var(--accent)}}.btn-primary{background:var(--accent);color:#fff;font-weight:700}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px color-mix(in srgb,var(--accent) 40%,transparent)}.btn-secondary{background:var(--bg-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.btn-ghost{background:none;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--bg-hover)}.btn-danger{background:var(--red-surface);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-danger-ghost:hover{color:var(--red)!important;background:var(--red-surface)!important}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:12px 24px;font-size:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin-bottom:8px}.form-input,.form-textarea,.form-select{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .15s}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-surface)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{opacity:.4;cursor:not-allowed}.form-textarea{min-height:80px;resize:vertical}.form-select{cursor:pointer}.form-input-sm,.form-select-sm{font-size:12px;padding:5px 8px}.section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim)}.prompt-input{min-height:120px;font-size:15px;line-height:1.6}.automation-builder-layout{display:grid;grid-template-columns:220px 1fr;gap:20px}.ab-file-tree{width:240px;flex-shrink:0}@media(max-width:900px){.automation-builder-layout{grid-template-columns:1fr}.ab-code-preview{flex-direction:column}.ab-file-tree{width:100%!important;border-right:none!important;border-bottom:1px solid var(--border)}}.code-editor{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;min-width:0}.code-editor-body{flex:1;min-height:0;display:flex;flex-direction:column}.code-editor .cm-editor{flex:1;min-height:0}.code-editor .cm-scroller{min-height:80px;max-height:70vh;overflow:auto}.code-editor-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-hover);border-bottom:1px solid var(--border);font-size:13px;color:var(--text-muted)}.code-editor-suggestions{min-width:min(280px,90vw);max-width:min(420px,90vw)}.code-editor-header-custom{padding:0;background:none}.code-editor-header-custom>*{border-bottom:none}.code-editor-header-custom>.workshop-toolbar{flex:none}.code-editor-header-custom>.editor-action-bar{flex:1;min-width:0}.code-editor-header .btn-ghost{color:var(--text-muted)}.code-editor-header .btn-ghost:hover{color:var(--text);background:var(--bg-hover)}.code-editor-refine{display:flex;flex-direction:column;gap:6px;padding:8px 12px;background:var(--accent-surface);border-bottom:1px solid var(--border)}.code-editor-refine-row{display:flex;align-items:center;gap:6px;width:100%}.code-editor-external-banner{display:flex;align-items:center;gap:8px;padding:6px 12px;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:12px;color:var(--text-muted);background:var(--bg-hover);border-bottom:1px solid var(--border)}.code-editor-external-banner span{flex:1}.code-editor-inline-result{padding:10px 12px;border-bottom:1px solid var(--border);font-size:12px;max-height:200px;overflow-y:auto}.code-editor-inline-result.valid{background:var(--green-surface)}.code-editor-inline-result.invalid{background:var(--red-surface)}.code-editor .cm-editor,.code-editor .cm-editor.cm-focused{outline:none}.file-panel{display:flex;flex-direction:column;padding:0}.panel-tabs{display:flex;gap:3px;padding:6px;background:var(--bg-hover);border-bottom:1px solid var(--border)}.panel-tabs button{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:5px;padding:5px 8px;white-space:nowrap;border:none;background:none;color:var(--text-dim);font-size:12px;font-weight:500;cursor:pointer;border-radius:var(--radius);transition:color .15s,background .15s}.panel-tabs button svg{flex-shrink:0}.panel-tabs button:hover{color:var(--text);background:var(--bg-surface)}.panel-tabs button.active{color:var(--text);background:var(--bg-surface);font-weight:600;box-shadow:0 1px 3px #00000014,0 0 0 1px var(--border)}.file-panel-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border)}.file-panel-toolbar>div{flex-shrink:0}.file-tree{padding:4px 0;flex:1}.file-tree-dir{display:flex;align-items:center;gap:6px;padding:5px 8px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text);border-radius:var(--radius);margin:0 4px}.file-tree-dir:hover{background:var(--bg-hover)}.file-tree-dir-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-tree-dir-count{font-size:10px;font-weight:500;color:var(--text-dim);background:var(--bg-hover);padding:1px 6px;border-radius:8px;flex-shrink:0}.file-tree-item{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:13px;cursor:pointer;border-radius:var(--radius);color:var(--text-muted);transition:all .1s;overflow:hidden;min-width:0;margin:0 4px}.file-tree-item .mono{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.file-tree-item .file-name-clickable{cursor:text;border-radius:3px;padding:0 2px;margin:0 -2px}.file-tree-item .file-name-clickable:hover{background:#5b6abf14}.file-tree-item:hover{background:var(--bg-hover);color:var(--text)}.file-tree-item:hover .file-tree-actions{opacity:1}.file-tree-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .1s}.file-tree-item.active{background:var(--accent-surface);color:var(--accent)}.file-tree-item.active .file-tree-actions{opacity:1}.badge{display:inline-flex;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-green{background:var(--green-surface);color:var(--green)}.badge-red{background:var(--red-surface);color:var(--red)}.badge-orange{background:var(--orange-surface);color:var(--orange)}.badge-accent{background:var(--accent-surface);color:var(--accent)}.validation-results{margin-top:12px;padding:12px;border-radius:var(--radius)}.validation-results.valid{background:var(--green-surface);border:1px solid rgba(74,222,128,.2)}.validation-results.invalid{background:var(--red-surface);border:1px solid rgba(248,113,113,.2)}.validation-item{font-size:13px;padding:4px 0;display:flex;gap:8px;align-items:flex-start}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:10px 16px;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:14px;font-weight:700;color:var(--text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.template-card{cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border-left:3px solid var(--card-category-color, var(--border));position:relative;overflow:hidden}.template-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--card-category-color, transparent) 0%,transparent 60%);opacity:0;transition:opacity .25s;pointer-events:none}.template-card:hover{border-color:var(--border);border-left-color:var(--card-category-color, var(--accent));transform:translateY(-3px);box-shadow:0 8px 24px -6px color-mix(in srgb,var(--card-category-color, var(--accent)) 20%,transparent),0 2px 8px var(--shadow-ambient)}.template-card:hover:before{opacity:.06}.template-card h4{font-size:15px;font-weight:700;margin-bottom:4px;letter-spacing:-.01em}.template-card p{font-size:13px;color:var(--text-muted);line-height:1.4}.template-card .platforms{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card-grid .template-card{animation:cardSlideIn .35s cubic-bezier(.22,1,.36,1) backwards}.library-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;padding:0 6px;font-size:11px;font-weight:700;background:var(--accent-surface);color:var(--accent);border-radius:999px;margin-left:6px}[data-category=configuration]{--card-category-color: #61afef}[data-category=routing]{--card-category-color: #56b6c2}[data-category=services]{--card-category-color: #c678dd}[data-category=security]{--card-category-color: #e06c75}[data-category=operations]{--card-category-color: #d19a66}[data-category=compliance]{--card-category-color: #7c8cf5}[data-category=reporting]{--card-category-color: #e88abf}[data-category=maintenance]{--card-category-color: #e5c07b}[data-category=provisioning]{--card-category-color: #98c379}[data-category=patterns]{--card-category-color: #6b717d}[data-category=setup]{--card-category-color: #98c379}[data-category=interfaces]{--card-category-color: #56b6c2}[data-category=vlans]{--card-category-color: #c678dd}[data-category=custom]{--card-category-color: #d19a66}[data-theme=github-light] [data-category=configuration]{--card-category-color: #0969da}[data-theme=github-light] [data-category=routing]{--card-category-color: #0e7c86}[data-theme=github-light] [data-category=services]{--card-category-color: #8250df}[data-theme=github-light] [data-category=security]{--card-category-color: #cf222e}[data-theme=github-light] [data-category=operations]{--card-category-color: #bc4c00}[data-theme=github-light] [data-category=compliance]{--card-category-color: #5a4fcf}[data-theme=github-light] [data-category=reporting]{--card-category-color: #bf3989}[data-theme=github-light] [data-category=maintenance]{--card-category-color: #9a6700}[data-theme=github-light] [data-category=provisioning]{--card-category-color: #1a7f37}[data-theme=github-light] [data-category=patterns]{--card-category-color: #6e7681}[data-theme=github-light] [data-category=custom]{--card-category-color: #bc4c00}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%) translateY(2px);padding:4px 8px;background:var(--bg);color:var(--text);font-size:11px;font-weight:500;letter-spacing:.02em;white-space:nowrap;border-radius:5px;border:1px solid var(--border);box-shadow:0 4px 12px -2px var(--shadow-ambient);opacity:0;pointer-events:none;transition:opacity .1s;z-index:100}[data-tooltip]:hover:after{opacity:1;transform:translate(-50%) translateY(0)}[data-tooltip-pos=below][data-tooltip]:after{bottom:auto;top:calc(100% + 6px);transform:translate(-50%) translateY(-2px)}[data-tooltip-pos=below][data-tooltip]:hover:after{transform:translate(-50%) translateY(0)}[data-tooltip-anchor=end][data-tooltip]:after{left:auto;right:-4px;transform:translate(0) translateY(2px)}[data-tooltip-anchor=end][data-tooltip]:hover:after{transform:translate(0) translateY(0)}[data-tooltip-pos=below][data-tooltip-anchor=end][data-tooltip]:after{transform:translate(0) translateY(-2px)}[data-tooltip-pos=below][data-tooltip-anchor=end][data-tooltip]:hover:after{transform:translate(0) translateY(0)}[data-tooltip][disabled]:after,[data-tooltip]:disabled:after{display:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:modal-fade-in .15s ease-out}.modal{background:color-mix(in srgb,var(--bg-surface) 92%,transparent);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid color-mix(in srgb,var(--border) 60%,transparent);border-radius:16px;padding:28px;width:100%;max-width:560px;max-height:80vh;overflow-y:auto;animation:modal-scale-in .2s cubic-bezier(.4,0,.2,1);box-shadow:0 24px 48px -12px var(--shadow-direct),0 0 0 1px color-mix(in srgb,var(--border) 30%,transparent)}.modal h3{font-family:Instrument Sans,system-ui,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:16px}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes modal-scale-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}.cmd-overlay.cmd-closing{animation:modal-fade-out .15s ease-in forwards}.cmd-closing .cmd-palette{animation:modal-scale-out .15s ease-in forwards}.modal-overlay.modal-closing{animation:modal-fade-out .15s ease-in forwards}.modal-closing .modal{animation:modal-scale-out .15s ease-in forwards}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.device-list{display:grid;gap:8px}.device-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .1s}.device-item:hover{border-color:var(--accent);background:var(--accent-surface)}.device-item .name{font-weight:700;font-size:14px}.device-item .info{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:11px;color:var(--text-muted)}.skip-to-content{position:fixed;top:-100%;left:16px;z-index:300;padding:12px 24px;background:var(--accent);color:#fff;border-radius:var(--radius);font-weight:600;font-size:14px;text-decoration:none;transition:top .2s}.skip-to-content:focus{top:16px}.cmd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:min(20vh,160px);z-index:200;animation:modal-fade-in .15s ease-out}.cmd-palette{width:min(560px,calc(100vw - 32px));background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 24px 48px -12px var(--shadow-direct),0 0 0 1px color-mix(in srgb,var(--border) 30%,transparent);animation:modal-scale-in .15s cubic-bezier(.4,0,.2,1);overflow:hidden;display:flex;flex-direction:column}.cmd-input-row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border)}.cmd-search-icon{color:var(--text-muted);flex-shrink:0}.cmd-input{flex:1;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:15px;background:none;border:none;color:var(--text);outline:none}.cmd-input::placeholder{color:var(--text-muted)}.cmd-kbd{font-family:JetBrains Mono,monospace;font-size:10px;padding:2px 6px;background:var(--bg-hover);border:1px solid var(--border);border-radius:4px;color:var(--text-dim);flex-shrink:0}.cmd-list{max-height:320px;overflow-y:auto;padding:6px}.cmd-section{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;padding:8px 10px 4px}.cmd-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;color:var(--text);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:13px;cursor:pointer;border-radius:var(--radius);text-align:left}.cmd-item:hover,.cmd-item.selected{background:var(--accent-surface);color:var(--accent)}.cmd-item-label{flex:1}.cmd-item-arrow{opacity:0;color:var(--text-dim);transition:opacity .1s}.cmd-item.selected .cmd-item-arrow{opacity:1;color:var(--accent)}.cmd-empty{padding:24px;text-align:center;color:var(--text-dim);font-size:13px}.cmd-footer{display:flex;gap:16px;padding:8px 16px;border-top:1px solid var(--border);font-size:11px;color:var(--text-dim)}.cmd-trigger{border:none;cursor:pointer;text-align:left}.cmd-shortcut{font-family:JetBrains Mono,monospace;font-size:10px;padding:1px 5px;background:var(--bg-hover);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);margin-left:auto}.cmd-footer kbd{font-family:JetBrains Mono,monospace;font-size:10px;padding:1px 4px;background:var(--bg-hover);border:1px solid var(--border);border-radius:3px;margin-right:4px}.loading{display:flex;align-items:center;gap:8px;color:var(--text-dim);font-size:13px;padding:20px}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;animation:emptyFadeIn .4s ease}.empty-state-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,var(--bg-hover),color-mix(in srgb,var(--accent) 8%,var(--bg-hover)));color:var(--text-dim);margin-bottom:16px;box-shadow:0 0 20px -4px color-mix(in srgb,var(--accent) 12%,transparent)}.empty-state h3{font-size:15px;font-weight:600;color:var(--text);margin:0 0 6px}.empty-state p{font-size:13px;color:var(--text-muted);margin:0;max-width:320px}@keyframes emptyFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.two-col{display:grid;grid-template-columns:320px 1fr;gap:20px}.two-col>*{min-width:0}.explanation{background:var(--accent-surface);border:1px solid rgba(91,106,191,.2);border-radius:var(--radius);padding:16px;margin-top:12px;font-size:14px;line-height:1.7}.share-link{display:flex;gap:8px;align-items:center;margin-top:8px}.share-link input{flex:1}.sidebar-toggle{padding:6px;color:var(--sidebar-text)}.sidebar-toggle:hover{color:var(--sidebar-text-bright);background:#ffffff14}.sidebar .btn-ghost{color:var(--sidebar-text)}.sidebar .btn-ghost:hover{color:var(--sidebar-text-bright);background:#ffffff14}.sidebar-brand .sidebar-toggle{flex-shrink:0;margin-left:4px}.sidebar-collapsed .sidebar{width:var(--sidebar-w, 60px)}.sidebar-collapsed .sidebar-brand{justify-content:center;padding:4px 0 12px}.sidebar-collapsed .sidebar-brand .sidebar-toggle{margin-left:0}.sidebar-collapsed .sidebar-nav{padding:0 8px}.sidebar-collapsed .nav-link{justify-content:center;padding:10px;gap:0}.sidebar-collapsed .nav-link-nested{padding-left:10px}.sidebar-collapsed .nav-label{display:none}.sidebar-collapsed .sidebar-bottom{padding:0 8px}.sidebar-collapsed .sidebar-user{justify-content:center}.sidebar-collapsed .main-content{margin-left:var(--sidebar-w, 60px)}.sidebar{transition:width .2s ease}.main-content{transition:margin-left .2s ease}.mobile-header,.mobile-overlay{display:none}.mobile-only{display:none!important}@media(max-width:900px){.app-layout{display:flex;flex-direction:column}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:90}.mobile-brand{font-family:Instrument Sans,system-ui,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.02em}.mobile-brand span{color:var(--accent)}.mobile-brand em{font-style:normal;font-weight:500;color:var(--text-muted)}.mobile-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:100;width:260px!important;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex}.sidebar.mobile-open{transform:translate(0)}.sidebar-collapsed .sidebar{transform:translate(-100%);width:260px!important}.sidebar-collapsed .sidebar.mobile-open{transform:translate(0)}.desktop-only{display:none!important}.mobile-only{display:flex!important}.main-content,.sidebar-collapsed .main-content{margin-left:0!important;padding:16px;max-width:100%}.two-col{grid-template-columns:1fr}.page-header-row{flex-direction:column;gap:12px}.page-header h2{font-size:20px}div[style*=grid-template-columns]{display:flex!important;flex-direction:column!important}.btn{font-size:13px}.modal-overlay{padding:16px}.modal-overlay:before{content:"×";position:absolute;top:12px;right:16px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fffc;background:#ffffff1a;border-radius:50%;z-index:101;cursor:pointer;line-height:1}.modal{max-width:calc(100vw - 32px)!important;padding:20px}.card table,.admin-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.form-input,.form-select,.form-textarea{max-width:100%;box-sizing:border-box}.code-editor-header{flex-wrap:wrap;gap:8px}.code-editor-header .dropdown-menu{min-width:min(280px,90vw)!important;max-width:90vw!important}.testlab-sidebar{position:static!important;max-height:none!important}.regex-text-container{min-height:200px!important}.code-editor,.cm-editor{max-width:100%}.cm-scroller{max-width:calc(100vw - 32px)}.two-col[style*=grid-template-columns],.two-col div[style*=grid-template-columns]{display:flex!important;flex-direction:column!important}.card table thead th,.card table tbody td{white-space:nowrap}.automation-builder-layout,.inventory-layout{grid-template-columns:1fr!important}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;flex-shrink:0}.card-grid{grid-template-columns:1fr!important}.card{overflow:hidden;max-width:100%}.library-list-item{overflow:hidden}.btn-sm,.btn-ghost{min-height:44px;min-width:44px}.nav-link{padding:12px;min-height:44px}.toast-container{top:auto;bottom:16px;left:16px;right:16px;max-width:none}.toast{width:100%}.ee-catalog-item{flex-direction:column;align-items:flex-start;gap:12px}.device-item .info{word-break:break-word}.ai-setup-banner,.setup-banner{flex-direction:column;text-align:center;gap:12px;padding:16px}.tester-splitter{display:none}.filter-bar-search{max-width:none;min-width:0;flex-basis:100%}}.ai-setup-banner,.setup-banner{display:flex;align-items:center;gap:16px;padding:20px 24px;background:var(--orange-surface);border:1px solid rgba(251,146,60,.25);border-radius:var(--radius-lg);color:var(--orange);margin-bottom:20px}.settings-return-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--accent-surface);border:1px solid var(--accent-border);border-radius:var(--radius);color:var(--text-muted);font-size:13px;margin-bottom:16px}.settings-return-banner strong{color:var(--text)}.file-tree-item.selected{background:var(--accent-surface);color:var(--accent)}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#5b6abf14;border:2px dashed var(--accent);border-radius:var(--radius-lg);color:var(--accent);pointer-events:none}.two-col.drop-active{outline:none}.inventory-layout{display:grid;grid-template-columns:200px 1fr 1fr;gap:16px}.inv-host-ip{width:140px}@media(max-width:1200px){.inventory-layout{grid-template-columns:1fr}}@media(max-width:900px){.inv-host-ip{width:100%!important}}.inventory-tree-item{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:13px;cursor:pointer;border-radius:var(--radius);color:var(--text-muted);transition:all .1s}.inventory-tree-item:hover{background:var(--bg-hover);color:var(--text)}.inventory-tree-item.active{background:var(--accent-surface);color:var(--accent)}.host-card{padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius)}.var-list{display:flex;flex-direction:column;gap:2px}.var-item{display:flex;align-items:center;gap:8px;padding:3px 8px;border-radius:4px;background:var(--bg-input);font-size:12px}.var-key{color:var(--accent);min-width:80px}.var-value{color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-platform-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:var(--accent-surface);color:var(--accent);font-weight:600;letter-spacing:.3px;white-space:nowrap}.inventory-preset-menu{position:absolute;right:0;top:100%;z-index:10;min-width:200px;padding:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000004d}.inventory-preset-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;font-size:12px;color:var(--text-muted);background:none;border:none;border-radius:4px;cursor:pointer;text-align:left}.inventory-preset-item:hover{background:var(--bg-hover);color:var(--text)}.tmpl-tester{display:flex;flex-direction:column;gap:24px}.tmpl-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.tmpl-header-left h2{font-family:Instrument Sans,system-ui,sans-serif;font-size:28px;font-weight:700;letter-spacing:-.02em;margin:4px 0 0}.tmpl-header-left p{font-size:14px;color:var(--text-muted);margin:4px 0 0}.tmpl-header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.tmpl-auto-toggle{font-size:13px;display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--text-muted);white-space:nowrap}.tmpl-editors{display:grid;grid-template-columns:.33fr 12px .67fr;gap:0}.tmpl-editors>*{min-width:0}.tmpl-editors.tmpl-editors-animate{transition:grid-template-columns .25s cubic-bezier(.4,0,.2,1)}.tmpl-scroll-hint{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:6px;background:var(--bg);border:none;color:var(--text-dim);font-size:12px;cursor:pointer;transition:color .15s;position:sticky;top:0;z-index:10}.tmpl-scroll-hint:hover{color:var(--accent)}.tmpl-rendering-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dash-pulse 1s ease-in-out infinite;flex-shrink:0}.tmpl-output-flash{animation:output-flash .6s ease-out}@keyframes output-flash{0%{box-shadow:0 0 0 2px var(--accent),0 0 12px color-mix(in srgb,var(--accent) 30%,transparent)}to{box-shadow:none}}@media(max-width:900px){.tmpl-editors{grid-template-columns:1fr!important}.tmpl-header{flex-direction:column;align-items:flex-start}}.file-picker-dropdown{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:4px;margin-bottom:8px;max-height:200px;overflow-y:auto}.diff-viewer{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.diff-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-hover);border-bottom:1px solid var(--border);font-size:13px}.diff-stats{display:flex;gap:8px;font-size:12px;font-weight:600}.diff-stat-add{color:var(--green)}.diff-stat-remove{color:var(--red)}.diff-content{overflow-x:auto;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.7}.diff-line{display:flex;min-width:fit-content}.diff-line-context{background:transparent}.diff-line-add{background:#4ade8014}.diff-line-remove{background:#f8717114}.diff-line-num{display:inline-block;width:40px;text-align:right;padding:0 6px;color:var(--text-dim);flex-shrink:0;-webkit-user-select:none;user-select:none}.diff-line-num-old{border-right:1px solid var(--border)}.diff-line-marker{display:inline-block;width:20px;text-align:center;flex-shrink:0;-webkit-user-select:none;user-select:none}.diff-line-add .diff-line-marker{color:var(--green);font-weight:700}.diff-line-remove .diff-line-marker{color:var(--red);font-weight:700}.diff-line-text{padding-right:16px;white-space:pre}.diff-line-add .diff-line-text{color:var(--green)}.diff-line-remove .diff-line-text{color:var(--red);text-decoration:line-through;opacity:.7}.diff-result{padding:16px;margin:0;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.7;color:var(--text);overflow-x:auto;white-space:pre}.chat-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.sidebar-bottom{margin-top:auto;padding:4px 10px 8px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-user{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 6px;margin-top:2px}.sidebar-user-avatar{width:30px;height:30px;border-radius:8px;background:var(--accent-surface);color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:Instrument Sans,system-ui,sans-serif;font-size:13px;font-weight:700;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:700;color:var(--sidebar-text-hover);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-username{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:10px;color:var(--sidebar-text-dim)}.nautobot-status{display:flex;align-items:center;gap:6px;padding:8px 12px;margin:0 12px 12px;border-radius:var(--radius);font-size:11px;font-weight:500}.nautobot-status.connected{background:var(--green-surface);color:var(--green)}.nautobot-status.disconnected{background:var(--bg-hover);color:var(--text-dim)}.dot{width:6px;height:6px;border-radius:50%;background:currentColor}.toast-container{position:fixed;top:16px;right:16px;z-index:200;display:flex;flex-direction:column;gap:8px;max-width:420px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;pointer-events:auto;border-radius:var(--radius);font-size:14px;animation:toast-in .2s ease-out;box-shadow:0 4px 12px #0000004d}.toast-error{background:var(--red-surface);border:1px solid rgba(248,113,113,.3);color:var(--red)}.toast-success{background:var(--green-surface);border:1px solid rgba(74,222,128,.3);color:var(--green)}.toast-info{background:var(--accent-surface);border:1px solid rgba(91,106,191,.3);color:var(--accent)}.toast span{flex:1}.toast-action{background:none;border:1px solid currentColor;color:inherit;cursor:pointer;padding:2px 10px;border-radius:var(--radius);font-size:12px;font-weight:600;font-family:Plus Jakarta Sans,system-ui,sans-serif;opacity:.9;flex-shrink:0}.toast-action:hover{opacity:1;background:#ffffff1a}.toast-close{background:none;border:none;color:inherit;cursor:pointer;padding:2px;opacity:.7}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}.toast.toast-exiting{animation:toast-out .15s ease-in forwards}.onboarding-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;max-width:960px}.onboarding-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;cursor:pointer;transition:all .15s;text-align:center}.onboarding-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.onboarding-icon{margin-bottom:12px}.onboarding-card h3{font-size:16px;font-weight:700;margin-bottom:6px}.onboarding-card p{font-size:13px;color:var(--text-muted);line-height:1.5}.dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px;min-width:200px;z-index:50;box-shadow:0 4px 12px #0000004d}.dropdown-item{display:block;width:100%;padding:8px 12px;font-size:13px;color:var(--text-muted);background:none;border:none;border-radius:4px;cursor:pointer;text-align:left;transition:all .1s}.dropdown-item:hover{background:var(--bg-hover);color:var(--text)}.category-header{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);cursor:pointer;border-radius:var(--radius);transition:all .1s;-webkit-user-select:none;user-select:none}.category-header:hover{color:var(--text-muted);background:var(--bg-hover)}.category-count{margin-left:auto;font-size:10px;font-weight:600;color:var(--text-dim);background:var(--bg-hover);padding:1px 6px;border-radius:999px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 32px;border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .15s;color:var(--text-muted);font-size:14px;font-weight:500}.theme-option:hover{border-color:var(--accent);color:var(--text)}.theme-option.active{border-color:var(--accent);background:var(--accent-surface);color:var(--accent)}.flow-view{display:flex;flex-direction:column;gap:24px}.flow-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--text-dim);font-size:14px;text-align:center}.flow-play{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.flow-play-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--accent-surface);border-bottom:1px solid var(--border);color:var(--accent)}.flow-play-name{font-size:15px;font-weight:600;color:var(--text)}.flow-play-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.flow-play-meta strong{color:var(--text)}.flow-section{padding:16px 20px;border-top:1px solid var(--border)}.flow-section.handlers{background:var(--bg-hover)}.flow-section-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.flow-task-list{display:flex;flex-direction:column;gap:2px}.flow-connector{display:flex;justify-content:center;padding:4px 0;color:var(--text-dim)}.flow-node{padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);transition:border-color .15s}.flow-node:hover{border-color:var(--border-focus)}.flow-node[data-type=block]{border-left:3px solid var(--accent)}.flow-node[data-type=include],.flow-node[data-type=role]{border-left:3px solid var(--orange)}.flow-node-header{display:flex;align-items:center;gap:8px}.flow-node-icon{display:flex;align-items:center;color:var(--text-muted);flex-shrink:0}.flow-node[data-type=block] .flow-node-icon{color:var(--accent)}.flow-node[data-type=include] .flow-node-icon,.flow-node[data-type=role] .flow-node-icon{color:var(--orange)}.flow-node-name{font-size:13px;font-weight:500;color:var(--text)}.flow-node-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.flow-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 8px;border-radius:10px;font-size:11px;font-family:var(--font-mono, monospace)}.flow-badge.module{background:var(--accent-surface);color:var(--accent)}.flow-badge.condition{background:var(--orange-surface);color:var(--orange)}.flow-badge.loop{background:var(--green-surface);color:var(--green)}.flow-badge.register{background:var(--bg-hover);color:var(--text-muted)}.flow-badge.notify{background:var(--orange-surface);color:var(--orange)}.flow-badge.tags{background:var(--bg-hover);color:var(--text-dim)}.flow-badge.delegate,.flow-badge.become{background:var(--red-surface);color:var(--red)}.flow-block-container{margin-top:6px;margin-left:16px;border-left:2px solid var(--border);padding-left:12px}.flow-block-section{margin-bottom:8px}.flow-block-section.rescue{border-left:2px solid var(--orange);padding-left:10px;margin-left:-14px}.flow-block-section.always{border-left:2px solid var(--green);padding-left:10px;margin-left:-14px}.flow-block-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:6px}.flow-block-label.rescue{color:var(--orange)}.flow-block-label.always{color:var(--green)}.builder-page-content{max-width:680px;margin:0 auto}.builder-section-label{font-size:12px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding-left:2px}.builder-start-options{display:flex;flex-direction:column;gap:8px;width:100%}.builder-start-option{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;transition:all .15s;color:var(--text)}.builder-start-option:hover:not(:disabled){border-color:var(--accent);background:var(--accent-surface)}.builder-start-option:disabled,.builder-start-option.disabled{opacity:.45;cursor:not-allowed}.builder-start-option.active{border-color:var(--accent);background:var(--accent-surface)}.builder-start-option-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border-radius:var(--radius);flex-shrink:0;color:var(--accent)}.builder-start-option-text{flex:1;display:flex;flex-direction:column;gap:2px}.builder-start-option-text strong{font-size:14px;font-weight:600}.builder-start-option-text span{font-size:12px;color:var(--text-muted)}.builder-start-option-arrow{color:var(--text-dim);flex-shrink:0}.builder-start-describe{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:12px}.builder-start-describe .form-textarea{font-size:13px;resize:vertical;min-height:72px}.builder-start-describe .btn{align-self:flex-end}.builder-generating-inline{display:flex;align-items:center;gap:10px;align-self:flex-end;font-size:13px;color:var(--accent);font-weight:500;padding:6px 0}.library-list{display:flex;flex-direction:column;gap:2px}.library-list-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius);cursor:pointer;background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--card-category-color, var(--border));transition:all .15s;animation:cardSlideIn .3s cubic-bezier(.22,1,.36,1) backwards}.library-list-item:hover{background:var(--bg-hover);border-left-color:var(--card-category-color, var(--accent));box-shadow:0 2px 8px var(--shadow-ambient)}.library-list-name{font-weight:500;font-size:13px;white-space:nowrap;min-width:180px}.library-list-desc{flex:1;font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-list-badges{display:flex;gap:4px;flex-shrink:0}.regex-text-container{position:relative;resize:vertical;overflow:hidden;min-height:150px}.regex-text-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;padding:10px 12px;font-size:12px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;overflow:auto;color:transparent;pointer-events:none;border:1px solid transparent;border-radius:var(--radius)}.regex-text-input{position:relative;width:100%;height:100%;min-height:400px;background:transparent!important;resize:none}.regex-highlight{background:color-mix(in srgb,var(--green) 30%,transparent);border-radius:2px;color:transparent;border-bottom:2px solid var(--green)}.ee-catalog-item{display:flex;align-items:center;gap:16px;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);transition:background .15s}.ee-catalog-item:hover{background:var(--bg-hover)}.filebrowser-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;font-size:13px;color:var(--text);border-bottom:1px solid var(--border)}.filebrowser-item:last-child{border-bottom:none}.filebrowser-item:hover{background:var(--bg-hover)}.filebrowser-file.selected{background:var(--accent-surface)}.snippet-platform-tabs{display:flex;align-items:center;gap:2px;padding:2px;background:var(--bg-hover);border-radius:var(--radius);margin-bottom:8px;border:1px solid var(--border)}.snippet-platform-tab{position:relative;padding:5px 14px;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--text-dim);background:transparent;border:none;border-radius:calc(var(--radius) - 2px);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.snippet-platform-tab:hover{color:var(--text);background:var(--bg-card)}.snippet-platform-tab.active{color:var(--text);background:var(--bg-card);box-shadow:0 1px 3px #00000026}.snippet-platform-tab.has-error{color:var(--red)}.snippet-platform-tab.has-error .snippet-platform-dot{background:var(--red);opacity:1}.snippet-platform-tab.has-content .snippet-platform-dot{background:var(--green)}.snippet-platform-dot{width:5px;height:5px;border-radius:50%;background:var(--text-dim);opacity:.5}.snippet-platform-tab.active .snippet-platform-dot{opacity:1}.snippet-variant-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--accent);background:var(--accent-surface);padding:2px 8px;border-radius:10px;letter-spacing:.3px}.snippet-variant-badge .variant-dot{width:5px;height:5px;border-radius:50%;background:var(--green)}[data-density=compact] .card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}[data-density=compact] .card.template-card{padding:12px}[data-density=compact] .template-card h4{font-size:13px;margin-bottom:2px}[data-density=compact] .template-card p{font-size:11px}[data-density=compact] .template-card .platforms{margin-top:6px}[data-density=compact] .library-list-item{padding:6px 10px;gap:8px}[data-density=compact] .library-list-name{font-size:12px;min-width:140px}[data-density=compact] .library-list-desc{font-size:11px}[data-density=spacious] .card-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}[data-density=spacious] .card.template-card{padding:28px}[data-density=spacious] .template-card h4{font-size:18px;margin-bottom:6px}[data-density=spacious] .template-card p{font-size:14px}[data-density=spacious] .template-card .platforms{margin-top:14px}[data-density=spacious] .library-list-item{padding:14px 18px;gap:16px}[data-density=spacious] .library-list-name{font-size:15px;min-width:220px}[data-density=spacious] .library-list-desc{font-size:13px}.vault-actions-col{width:140px}@media(max-width:900px){.vault-actions-col{width:auto}}.testlab-layout{display:grid;gap:0;align-items:stretch}.testlab-editor-panel{min-width:0}.testlab-sidebar{min-width:0;position:sticky;top:20px;max-height:calc(100vh - 40px);overflow-y:auto}.tester-splitter{cursor:col-resize;position:relative;z-index:2;display:flex;align-items:stretch;justify-content:center}.tester-splitter-line{width:1px;background:var(--border);transition:width .15s,background .15s,box-shadow .15s}.tester-splitter:hover .tester-splitter-line{width:3px;background:var(--accent);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 20%,transparent)}.tester-splitter:active .tester-splitter-line{width:3px;background:var(--accent-hover);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 30%,transparent)}@media(max-width:900px){.testlab-layout{display:flex!important;flex-direction:column!important}}.testlab-sidebar-section{padding-top:16px;margin-top:16px;border-top:1px solid var(--border)}.testlab-sidebar-section:first-child{padding-top:0;margin-top:0;border-top:none}.testlab-section-label{font-family:Instrument Sans,system-ui,sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:10px;display:flex;align-items:center;gap:4px}.testlab-run{width:100%;padding:12px 20px;font-size:14px;font-weight:600;font-family:Instrument Sans,system-ui,sans-serif;letter-spacing:-.01em;border:none;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;background:var(--accent);box-shadow:0 1px 2px #00000026,0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent),inset 0 1px #ffffff1f;transition:all .2s}.testlab-run:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 35%,transparent),0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent),inset 0 1px #ffffff26;transform:translateY(-1px)}.testlab-run:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px color-mix(in srgb,var(--accent) 25%,transparent),inset 0 1px 3px #00000026}.testlab-run:disabled{opacity:.5;cursor:not-allowed}.testlab-run-footer{padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0}.testlab-running-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);background:var(--accent-surface);border:1px solid color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent);font-size:13px;font-weight:500;margin-bottom:12px}.testlab-running-spinner{width:18px;height:18px;border:2px solid color-mix(in srgb,var(--accent) 20%,transparent);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes page-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:page-enter .35s cubic-bezier(.22,1,.36,1) both}.animate-in-delay-1{animation:page-enter .35s cubic-bezier(.22,1,.36,1) .06s both}.animate-in-delay-2{animation:page-enter .35s cubic-bezier(.22,1,.36,1) .12s both}.animate-in-delay-3{animation:page-enter .35s cubic-bezier(.22,1,.36,1) .18s both}.btn-primary:active,.btn-danger:active,.btn-secondary:active{transform:translateY(.5px);box-shadow:0 1px 4px var(--shadow-ambient)}.cab-preview-content h1{font-size:1.4em;font-weight:700;margin:0 0 12px;border-bottom:1px solid var(--border);padding-bottom:8px}.cab-preview-content h2{font-size:1.15em;font-weight:600;margin:20px 0 8px;color:var(--accent)}.cab-preview-content h3{font-size:1em;font-weight:600;margin:16px 0 6px}.cab-preview-content p{margin:6px 0}.cab-preview-content hr{border:none;border-top:1px solid var(--border);margin:16px 0}.cab-preview-content table{width:100%;border-collapse:collapse;margin:8px 0 16px;font-size:13px}.cab-preview-content th{text-align:left;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--border);font-weight:600;white-space:nowrap}.cab-preview-content td{padding:6px 12px;border:1px solid var(--border);vertical-align:top}.cab-preview-content tr:hover td{background:var(--bg-hover)}.cab-preview-content code{font-family:var(--font-mono);font-size:.9em;background:var(--bg-surface);padding:2px 5px;border-radius:3px}.cab-preview-content ul,.cab-preview-content ol{margin:6px 0;padding-left:24px}.cab-preview-content li{margin:2px 0}.cab-preview-content em{color:var(--text-muted)}.cab-preview-content strong{font-weight:600}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.workbench-tabs{display:flex;gap:4px;margin-bottom:24px;padding:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.workbench-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:none;background:none;color:var(--text-dim);font-size:13px;font-weight:500;cursor:pointer;border-radius:calc(var(--radius-lg) - 4px);transition:color .2s,background .2s,box-shadow .2s}.workbench-tab:hover{color:var(--text);background:var(--bg-hover)}.workbench-tab.active{color:var(--text);background:var(--bg);font-weight:600;box-shadow:0 1px 3px #00000014,0 0 0 1px var(--border)}@keyframes workbench-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.workbench-content{animation:workbench-fade-in .25s ease both;overflow:hidden}.diagnose-trigger{flex:none!important;justify-content:center!important;color:var(--text-dim);border:1px solid var(--border);border-radius:calc(var(--radius-lg) - 4px);padding:6px 12px!important}.diagnose-trigger:hover{color:var(--accent);border-color:var(--accent);background:color-mix(in oklch,var(--accent) 8%,transparent)}.diagnose-trigger.active{color:var(--accent);border-color:var(--accent);background:color-mix(in oklch,var(--accent) 12%,transparent)}.diagnose-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;animation:diagnose-backdrop-in .2s ease both}@keyframes diagnose-backdrop-in{0%{opacity:0}to{opacity:1}}.diagnose-overlay{position:fixed;top:0;right:0;bottom:0;width:min(520px,calc(100vw - 32px));background:var(--bg);border-left:1px solid var(--border);box-shadow:-8px 0 32px #00000026;display:flex;flex-direction:column;z-index:1001;animation:diagnose-slide-in .25s cubic-bezier(.16,1,.3,1) both}@keyframes diagnose-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.diagnose-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px;color:var(--text);flex-shrink:0}.diagnose-overlay-body{flex:1;overflow-y:auto;padding:20px}.live-test-steps{display:flex;align-items:center;justify-content:space-between;position:relative;margin-bottom:28px;padding:20px 24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow-x:auto}.live-test-track{position:absolute;left:48px;right:48px;top:50%;height:2px;background:var(--border);transform:translateY(-1px);z-index:0}.live-test-track-fill{position:absolute;left:48px;top:50%;height:2px;background:var(--green);transform:translateY(-1px);z-index:1;transition:width .4s cubic-bezier(.22,1,.36,1)}.live-test-step{display:flex;flex-direction:column;align-items:center;gap:8px;padding:4px 8px;border:none;background:none;cursor:pointer;white-space:nowrap;font-size:12px;color:var(--text-dim);transition:color .2s;flex-shrink:0;position:relative;z-index:2}.live-test-step:hover:not(:disabled){color:var(--text)}.live-test-step:disabled{cursor:default;opacity:.45}.live-test-step.active{color:var(--accent);font-weight:600}.live-test-step.completed{color:var(--green)}.live-test-step-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--bg-surface);flex-shrink:0;transition:border-color .2s,background .2s,transform .2s}.live-test-step-num{font-size:12px;font-weight:700;font-family:var(--font-mono, monospace)}.live-test-step.active .live-test-step-icon{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--bg-surface));transform:scale(1.1);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 10%,transparent)}.live-test-step.completed .live-test-step-icon{border-color:var(--green);background:color-mix(in srgb,var(--green) 15%,var(--bg-surface))}.live-test-step-label{display:none}@media(min-width:700px){.live-test-step-label{display:inline}}.live-test-content{min-height:300px}.live-test-log{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;max-height:400px;overflow-y:auto;font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:12px;line-height:1.6}.live-test-log-line{padding:1px 0;white-space:pre-wrap;word-break:break-all}.live-test-log-line.log-task{color:var(--accent);font-weight:600;margin-top:4px}.live-test-log-line.log-ok{color:var(--green)}.live-test-log-line.log-changed{color:var(--orange)}.live-test-log-line.log-fatal{color:var(--red)}.live-test-log-line.log-skipped{color:var(--text-dim)}.live-test-log-line.log-recap{color:var(--text);font-weight:600;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}[data-density=compact] .live-test-steps{padding:12px 16px;margin-bottom:16px}[data-density=compact] .live-test-step{gap:4px;font-size:11px}[data-density=compact] .live-test-step-icon{width:22px;height:22px}[data-density=compact] .workbench-tab{padding:7px 12px;font-size:12px}[data-density=compact] .diagnose-trigger{padding:5px 10px!important;font-size:12px}[data-density=compact] .diagnose-overlay-header{padding:12px 16px}[data-density=compact] .diagnose-overlay-body{padding:16px}[data-density=spacious] .diagnose-trigger{padding:8px 16px!important;font-size:14px}[data-density=spacious] .diagnose-overlay-header{padding:20px 24px}[data-density=spacious] .diagnose-overlay-body{padding:24px}[data-density=spacious] .live-test-steps{padding:24px 32px;margin-bottom:32px}[data-density=spacious] .live-test-step{gap:10px;font-size:13px}[data-density=spacious] .live-test-step-icon{width:32px;height:32px}[data-density=spacious] .workbench-tab{padding:12px 20px;font-size:14px}@media(max-width:900px){.live-test-steps{padding:14px 12px}.live-test-track,.live-test-track-fill{left:24px;right:24px}.workbench-tabs{gap:2px}.workbench-tab{padding:8px;font-size:12px;gap:5px}.workbench-tab span,.diagnose-trigger span{display:none}.diagnose-overlay{width:100vw}}
