@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--transition-fast:.12s ease;--transition-normal:.2s ease;--transition-dropdown:.15s ease-out;--font-primary:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--text-page-title-size:24px;--text-page-title-weight:600;--text-page-title-lh:32px;--text-section-title-size:16px;--text-section-title-weight:600;--text-section-title-lh:24px;--text-body-size:14px;--text-body-weight:400;--text-body-lh:20px;--text-label-size:12px;--text-label-weight:500;--text-label-lh:16px;--text-caption-size:11px;--text-caption-weight:400;--text-caption-lh:14px;--text-small-size:13px;--text-small-weight:400;--text-small-lh:18px;--text-stat-size:28px;--text-stat-weight:600;--text-stat-lh:36px;--text-code-size:13px;--text-code-weight:400;--text-code-lh:18px;--btn-height:36px;--btn-height-sm:28px;--btn-height-xs:24px;--topbar-height:48px;--sidebar-width:240px;--sidebar-collapsed:56px;--detail-panel-width:280px}[data-theme=dark],:root{--bg-base:#111113;--bg-surface:#1a1a1d;--bg-elevated:#242428;--bg-hover:#2a2a2e;--border:#2e2e32;--border-subtle:#232326;--text-primary:#ececec;--text-secondary:#9c9ca5;--text-muted:#606068;--accent:#aec3b0;--accent-hover:#96ab98;--accent-subtle:#aec3b01f;--accent-text:#1a2e1c;--warning:#f59e0b;--danger:#ef4444;--danger-subtle:#ef44441a;--info:#3b82f6;--info-subtle:#3b82f61a;--success:#10b981;--success-subtle:#10b9811a;--shadow-sm:0 1px 2px #0003;--shadow-md:0 2px 8px #0000004d;--shadow-lg:0 4px 16px #0006}[data-theme=light]{--bg-base:#f5f5f7;--bg-surface:#fff;--bg-elevated:#eeeef0;--bg-hover:#e4e4e7;--border:#ccccd0;--border-subtle:#d8d8dc;--text-primary:#1a1a1a;--text-secondary:#555;--text-muted:#888;--accent:#aec3b0;--accent-hover:#96ab98;--accent-subtle:#aec3b01a;--accent-text:#1a2e1c;--warning:#f59e0b;--danger:#ef4444;--danger-subtle:#ef444414;--info:#3b82f6;--info-subtle:#3b82f614;--success:#10b981;--success-subtle:#10b98114;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 2px 8px #0000001f;--shadow-lg:0 4px 16px #00000029}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}body{font-family:var(--font-primary);font-size:var(--text-body-size);font-weight:var(--text-body-weight);line-height:var(--text-body-lh);color:var(--text-primary);background:var(--bg-base);min-height:100vh}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}.app-shell{min-height:100vh;display:flex}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);padding:0 var(--space-md);z-index:100;align-items:center;gap:var(--space-md);display:flex;position:fixed;top:0;left:0;right:0}.topbar__brand{align-items:center;gap:var(--space-sm);font-weight:600;font-size:var(--text-section-title-size);color:var(--text-primary);white-space:nowrap;display:flex}.topbar__brand-logo{width:auto;height:22px;display:block}.topbar__brand-accent{color:var(--accent)}.topbar__spacer{flex:1}.topbar__actions{align-items:center;gap:var(--space-xs);display:flex}.sidebar{top:var(--topbar-height);width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border-subtle);transition:width var(--transition-normal);z-index:90;flex-direction:column;display:flex;position:fixed;bottom:0;left:0;overflow-x:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar__nav{padding:var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar__section-label{font-size:var(--text-caption-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-md)var(--space-sm)var(--space-xs)}.sidebar--collapsed .sidebar__section-label{display:none}.sidebar__item{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-sm);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-body-size);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;text-decoration:none;display:flex;position:relative}.sidebar__item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__item--active{background:var(--accent-subtle);color:var(--text-primary)}.sidebar__item--active:before{content:"";left:0;top:var(--space-xs);bottom:var(--space-xs);background:var(--accent);border-radius:var(--radius-full);width:2px;position:absolute}.sidebar__icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.sidebar__item--active .sidebar__icon{color:var(--accent)}.sidebar__label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar--collapsed .sidebar__label{display:none}.sidebar__footer{padding:var(--space-sm);border-top:1px solid var(--border-subtle)}.main-content{margin-left:var(--sidebar-width);margin-top:var(--topbar-height);padding:var(--space-xl);transition:margin-left var(--transition-normal);min-height:calc(100vh - var(--topbar-height));flex:1}.sidebar--collapsed~.main-content,.main-content--expanded{margin-left:var(--sidebar-collapsed)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-lg)}.card--selected{border-color:var(--accent)}.card--active{border-left:2px solid var(--accent)}.btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-xs)var(--space-md);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:var(--text-body-size);cursor:pointer;transition:all var(--transition-fast);font-weight:500;line-height:var(--text-body-lh);height:var(--btn-height);white-space:nowrap;border:1px solid #0000;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn--secondary{color:var(--text-primary);border-color:var(--border);background:0 0}.btn--secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.btn--ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn--danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn--danger:hover:not(:disabled){background:var(--danger-subtle)}.btn--sm{height:var(--btn-height-sm);font-size:var(--text-label-size);padding:var(--space-xs)var(--space-sm)}.btn--xs{height:var(--btn-height-xs);font-size:var(--text-caption-size);padding:2px var(--space-sm);border-radius:var(--radius-sm)}.btn--accent-ghost{color:var(--accent);background:0 0;border-color:#0000}.btn--accent-ghost:hover:not(:disabled){background:var(--accent-subtle);color:var(--accent-hover)}.btn--icon{width:var(--btn-height);padding:0}.btn--icon.btn--sm{width:var(--btn-height-sm)}.input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;padding:var(--space-xs)var(--space-sm);font-family:var(--font-primary);font-size:var(--text-body-size);color:var(--text-primary);height:var(--btn-height);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);display:block}.input--sm{height:var(--btn-height-sm);font-size:var(--text-label-size)}.input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #aec3b02e}.input--error{border-color:var(--danger)}.input--error:focus{box-shadow:0 0 0 2px var(--danger-subtle)}textarea.input{resize:vertical;height:auto;min-height:80px}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23888890' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-sm)center;padding-right:var(--space-xl)}select option{background-color:var(--bg-elevated);color:var(--text-primary)}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-secondary)}.form-hint{font-size:var(--text-caption-size);color:var(--text-muted)}.form-error{font-size:var(--text-caption-size);color:var(--danger)}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border)}.table td{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border-subtle);color:var(--text-primary);vertical-align:middle}.table tr:hover td{background:var(--bg-elevated)}.table tr:nth-child(2n) td{background:#2424284d}[data-theme=light] .table tr:nth-child(2n) td{background:#00000005}.status-dot{border-radius:var(--radius-full);flex-shrink:0;width:6px;height:6px;display:inline-block}.status-dot--muted{background:var(--text-muted)}.status-dot--accent{background:var(--accent)}.status-dot--warning{background:var(--warning)}.status-dot--success{background:var(--success)}.status-dot--danger{background:var(--danger)}.status-badge{align-items:center;gap:var(--space-xs);font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-secondary);display:inline-flex}.page-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.page-title{font-size:var(--text-page-title-size);font-weight:var(--text-page-title-weight);line-height:var(--text-page-title-lh);color:var(--text-primary)}.page-subtitle{font-size:var(--text-body-size);color:var(--text-secondary);margin-top:var(--space-xs)}.section-title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight);line-height:var(--text-section-title-lh);color:var(--text-primary);margin-bottom:var(--space-md)}.empty-state{padding:var(--space-2xl);text-align:center;color:var(--text-muted);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.empty-state__icon{width:48px;height:48px;color:var(--text-muted);opacity:.5}.empty-state__title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight);color:var(--text-secondary)}.empty-state__description{font-size:var(--text-body-size);color:var(--text-muted);max-width:320px}.toast{bottom:var(--space-lg);right:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm)var(--space-md);box-shadow:var(--shadow-lg);font-size:var(--text-body-size);color:var(--text-primary);z-index:1000;animation:.3s forwards toast-in;position:fixed}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.divider{border:none;border-top:1px solid var(--border-subtle);margin:var(--space-lg)0}.code{font-family:var(--font-mono);font-size:var(--text-code-size);line-height:var(--text-code-lh);background:var(--bg-elevated);padding:1px var(--space-xs);border-radius:var(--radius-sm)}.skeleton{background:var(--bg-elevated);border-radius:var(--radius-sm);animation:1.5s ease-in-out infinite skeleton-pulse}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.auth-page{min-height:100vh;padding:var(--space-xl);background:var(--bg-base);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;max-width:400px;padding:var(--space-2xl);box-shadow:var(--shadow-md)}.auth-card__logo{text-align:center;margin-bottom:var(--space-xl)}.auth-card__brand-logo{width:auto;height:56px;margin:0 auto;display:block}.auth-card__title{font-size:var(--text-page-title-size);font-weight:var(--text-page-title-weight);text-align:center;margin-bottom:var(--space-xs)}.auth-card__subtitle{text-align:center;color:var(--text-secondary);font-size:var(--text-body-size);margin-bottom:var(--space-xl)}.auth-card__form{gap:var(--space-md);flex-direction:column;display:flex}.auth-card__divider{align-items:center;gap:var(--space-md);color:var(--text-muted);font-size:var(--text-label-size);display:flex}.auth-card__divider:before,.auth-card__divider:after{content:"";border-top:1px solid var(--border-subtle);flex:1}.auth-card__footer{text-align:center;margin-top:var(--space-lg);font-size:var(--text-body-size);color:var(--text-secondary)}.auth-link-sent{text-align:center;align-items:center;gap:var(--space-md);padding:var(--space-md)0;flex-direction:column;display:flex}.auth-link-sent__icon{border-radius:var(--radius-full);background:var(--accent-subtle);width:64px;height:64px;color:var(--accent);justify-content:center;align-items:center;animation:2s ease-in-out infinite auth-pulse;display:flex}@keyframes auth-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.05)}}.auth-link-sent__spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);width:32px;height:32px;animation:.8s linear infinite auth-spin}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-link-sent__hint{font-size:var(--text-small-size);color:var(--text-muted);max-width:280px}.auth-link-sent__actions{gap:var(--space-sm);margin-top:var(--space-md);flex-direction:column;display:flex}.setup-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;max-width:560px;padding:var(--space-2xl);box-shadow:var(--shadow-md)}.setup-card__header{text-align:center;margin-bottom:var(--space-xl)}.setup-card__header .auth-card__brand-logo{margin-bottom:var(--space-md)}.setup-card__form{gap:var(--space-md);flex-direction:column;display:flex}.setup-card__row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.setup-card__row--single{grid-template-columns:1fr;max-width:50%}@media (max-width:560px){.setup-card{padding:var(--space-lg)}.setup-card__row{grid-template-columns:1fr}.setup-card__row--single{max-width:100%}}.setup-toggle{font-size:var(--text-caption-size);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;display:inline-flex}.setup-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.setup-toggle__label{white-space:nowrap}.otp-input{text-align:center;letter-spacing:10px;padding:var(--space-md);font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:28px;font-weight:600}.otp-input::placeholder{letter-spacing:10px;opacity:.3}.upgrade-prompt{z-index:9999;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);padding:var(--space-sm)var(--space-md);background:#1e190af2;border:1px solid #ffb42866;width:calc(100% - 32px);max-width:560px;animation:.3s ease-out upgradeSlideIn;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080}@keyframes upgradeSlideIn{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.upgrade-prompt-icon{flex-shrink:0;font-size:20px}.upgrade-prompt-msg{color:#ffc83cf2;margin:0;font-size:13px;line-height:1.4}.upgrade-prompt-close{color:#fff6;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:18px;transition:color .15s}.upgrade-prompt-close:hover{color:#fffc}.error-boundary{justify-content:center;align-items:center;gap:var(--space-md);text-align:center;min-height:400px;padding:var(--space-xl);flex-direction:column;display:flex}.error-boundary__icon{font-size:48px}.error-boundary__title{color:var(--text-primary);margin:0;font-size:20px;font-weight:600}.error-boundary__msg{color:var(--text-muted);max-width:400px;margin:0;font-size:13px;line-height:1.5}.dialog-backdrop{-webkit-backdrop-filter:blur(4px);z-index:200;padding:var(--space-xl);background:#0009;justify-content:center;align-items:center;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.dialog{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);animation:.2s dialog-in}@keyframes dialog-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dialog__header{padding:var(--space-lg)var(--space-lg)0;justify-content:space-between;align-items:center;display:flex}.dialog__title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight)}.dialog__body{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.dialog__footer{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:0 var(--space-lg)var(--space-lg);display:flex}.wizard-toggle{font-size:var(--text-label-size);color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;display:flex}.wizard-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.dropdown{position:relative}.dropdown__menu{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);padding:var(--space-xs);z-index:50;display:none;position:absolute;top:100%;right:0}.dropdown:focus-within .dropdown__menu{display:block}.dropdown__item{width:100%;padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:var(--text-body-size);color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;text-decoration:none;display:block}.dropdown__item:hover{background:var(--bg-hover)}.dropdown__item--danger{color:var(--danger)}.dropdown__item--danger:hover{background:var(--danger-subtle)}.project-card{gap:var(--space-md);transition:border-color var(--transition-fast),transform .15s ease,box-shadow .15s ease;flex-direction:column;display:flex}.project-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000002e}.project-card--demo{background:linear-gradient(135deg,var(--bg-surface),#f59e0b08)}.project-card--completed{opacity:.7;border-color:var(--info)}.project-card--deleted{opacity:.5;border-color:var(--danger)}.project-card__grace{font-size:var(--text-label-size);color:var(--danger);font-weight:500}.project-card__header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);display:flex}.project-card__title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight);color:var(--text-primary);line-height:var(--text-section-title-lh);text-decoration:none}.project-card__title:hover{color:var(--accent)}.project-card__client{font-size:var(--text-body-size);color:var(--text-secondary)}.project-card__stats{gap:var(--space-lg);display:flex}.project-card__stat{flex-direction:column;gap:2px;display:flex}.project-card__stat-value{font-size:var(--text-section-title-size);color:var(--text-primary);font-weight:600}.project-card__stat-label{font-size:var(--text-caption-size);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.project-card__footer{padding-top:var(--space-sm);border-top:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.project-card__date{font-size:var(--text-caption-size);color:var(--text-muted)}.project-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.filter-tabs{margin-bottom:var(--space-lg);border-bottom:1px solid var(--border-subtle);gap:2px;display:flex}.filter-tab{padding:var(--space-sm)var(--space-md);font-family:var(--font-primary);font-size:var(--text-body-size);color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:500}.filter-tab:hover{color:var(--text-secondary)}.filter-tab--active{color:var(--text-primary);border-bottom-color:var(--accent)}.tier-bar{padding:var(--space-md)var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.tier-bar__count{color:var(--text-muted);margin-left:var(--space-sm)}.stat-grid{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg);gap:var(--space-xs);flex-direction:column;display:flex}.stat-card__label{font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.stat-card__value{font-size:var(--text-stat-size);font-weight:var(--text-stat-weight);line-height:var(--text-stat-lh);color:var(--text-primary)}.stat-card__hint{font-size:var(--text-caption-size);color:var(--text-muted)}.breadcrumb-link{align-items:center;gap:var(--space-xs);font-size:var(--text-body-size);color:var(--text-muted);transition:color var(--transition-fast);text-decoration:none;display:inline-flex}.breadcrumb-link:hover{color:var(--accent)}.card--hoverable{transition:border-color var(--transition-normal),box-shadow var(--transition-normal),transform var(--transition-normal)}.card--hoverable:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.setup-banner{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-body-size);margin-bottom:var(--space-lg)}.setup-banner--locked{background:var(--warning);color:var(--accent-text);font-weight:500}.lock-badge{font-size:var(--text-label-size);margin-left:var(--space-xs);vertical-align:middle}.setup-list{flex-direction:column;gap:2px;display:flex}.setup-list__row{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-md);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:background var(--transition-fast);display:flex}.setup-list__row:hover{background:var(--bg-elevated)}.setup-list__arrows{flex-direction:column;gap:0;display:flex}.setup-list__content{align-items:center;gap:var(--space-md);flex:1;min-width:0;display:flex}.setup-list__name{color:var(--text-primary);font-weight:500}.setup-list__meta{font-size:var(--text-caption-size);color:var(--text-muted)}.setup-list__actions{gap:var(--space-xs);flex-shrink:0;display:flex}.setup-table{border:1px solid var(--border);border-radius:var(--radius-md);overflow:visible}.setup-table__header{padding:var(--space-sm)var(--space-md);background:var(--bg-elevated);border-bottom:1px solid var(--border);font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-md)var(--radius-md)0 0;align-items:center;display:flex}.setup-table__row{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);align-items:center;display:flex}.setup-table__row:last-child{border-radius:0 0 var(--radius-md)var(--radius-md);border-bottom:none}.setup-table__row:hover{background:var(--bg-hover)}.setup-table__row--muted{opacity:.5}.setup-table__col{align-items:center;gap:var(--space-xs);display:flex}.setup-table__col--code{flex:0 0 120px}.setup-table__col--name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.setup-table__col--cat{color:var(--text-secondary);font-size:var(--text-label-size);flex:0 0 120px}.setup-table__col--marker{color:var(--text-muted);font-size:var(--text-label-size);flex:0 0 80px}.setup-table__col--design{font-size:var(--text-label-size);flex:0 0 120px}.setup-table__col--status{flex:0 0 100px}.setup-table__col--actions{flex:0 0 40px;justify-content:flex-end}.setup-table__divider{padding:var(--space-sm)var(--space-md);font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-elevated);border-bottom:1px solid var(--border);border-top:1px solid var(--border)}.status-badge--active{background:var(--success-subtle);color:var(--success);padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-caption-size);font-weight:500}.status-badge--muted{background:var(--bg-elevated);color:var(--text-muted);padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-caption-size);font-weight:500}.status-badge--warning{color:var(--warning);padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-caption-size);background:#f59e0b1a;font-weight:500}.status-badge--info{background:var(--info-subtle);color:var(--info);padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-caption-size);font-weight:500}.status-badge--danger{background:var(--danger-subtle);color:var(--danger);padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-caption-size);font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;padding:var(--space-xl);background:#0009;justify-content:center;align-items:center;animation:.15s fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);padding:var(--space-xl);animation:.2s dialog-in}.modal__title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight);color:var(--text-primary);margin-bottom:var(--space-lg)}.modal__actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);display:flex}.modal-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-lg);padding:var(--space-lg);animation:.2s dialog-in}.modal-card__title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight);color:var(--text-primary);margin:0 0 var(--space-xs)0}.modal-card__desc{font-size:var(--text-caption-size);color:var(--text-muted);margin:0 0 var(--space-md)0}.modal-card__fields{gap:var(--space-sm);flex-direction:column;display:flex}.modal-card__field{align-items:center;gap:var(--space-sm);display:flex}.modal-card__field label{min-width:50px;font-size:var(--text-body-size);color:var(--text-secondary);font-weight:500}.modal-card__field input,.modal-card__field select{padding:var(--space-xs)var(--space-sm);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-body-size);flex:1}.modal-card__field input:focus,.modal-card__field select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #6366f133}.modal-card__actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-md);display:flex}.dropdown-menu{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);padding:var(--space-xs);z-index:50;position:absolute;top:100%}.dropdown-menu--right{right:0}.dropdown-menu__item{width:100%;padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:var(--text-body-size);color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;display:block}.dropdown-menu__item:hover{background:var(--bg-hover)}.dropdown-menu__item--danger{color:var(--danger)}.dropdown-menu__item--danger:hover{background:var(--danger-subtle)}.form-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.input-group{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-direction:column;display:flex}.input-label{font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-secondary)}.error-banner{padding:var(--space-sm)var(--space-md);background:var(--danger-subtle);color:var(--danger);border-radius:var(--radius-sm);font-size:var(--text-body-size);margin-bottom:var(--space-md)}.success-banner{padding:var(--space-sm)var(--space-md);background:var(--success-subtle);color:var(--success);border-radius:var(--radius-sm);font-size:var(--text-body-size);margin-bottom:var(--space-md)}.btn--icon-sm{justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:10px;line-height:1;display:inline-flex}.revision-tag-row{padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.revision-tag-row:hover{background:var(--bg-elevated)}.revision-tag-row--locked{opacity:.6}.revision-tag-row__info{flex-direction:column;gap:2px;display:flex}.revision-tag-row__label{align-items:center;gap:var(--space-sm);font-weight:600;font-size:var(--text-section-title-size);color:var(--text-primary);display:flex}.revision-tag-row__desc{font-size:var(--text-body-size);color:var(--text-secondary)}.readonly-banner{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-body-size);margin-bottom:var(--space-lg);background:#33669926;border:1px solid #4080bf4d;display:flex}.readonly-banner--danger{background:#99333326;border-color:#bf40404d}.completion-modal{max-width:520px}.completion-modal__warning{gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg);font-size:var(--text-body-size);background:#e6a21a1a;border:1px solid #d99d2640;line-height:1.5;display:flex}.completion-modal__warning svg{flex-shrink:0;margin-top:2px}.completion-modal__checklist{margin-bottom:var(--space-lg)}.completion-modal__checklist-title{font-size:var(--text-label-size);color:var(--text-primary);margin-bottom:var(--space-sm);font-weight:600}.completion-modal__check-item{align-items:center;gap:var(--space-sm);padding:var(--space-xs)0;font-size:var(--text-body-size);color:var(--text-secondary);cursor:pointer;display:flex}.completion-modal__check-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.modal__actions{justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border);display:flex}.canvas-page{background:#1a1a1a;flex-direction:column;height:100vh;display:flex;overflow:hidden}.canvas-page--loading,.canvas-page--error{justify-content:center;align-items:center;gap:var(--space-md);color:#aaa;background:#1a1a1a;flex-direction:column;height:100vh;display:flex}.canvas-topbar{height:42px;padding:0 var(--space-sm);z-index:10;align-items:center;gap:var(--space-sm);background:#2b2b2b;border-bottom:1px solid #3a3a3a;flex-shrink:0;display:flex}.canvas-topbar__back{color:#bbb;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:4px 8px;font-size:.8rem}.canvas-body{flex:1;display:flex;overflow:hidden}.canvas-viewport{cursor:default;background:#1a1a1a;flex:1;position:relative;overflow:hidden}.drawing-canvas,.annotation-canvas{position:absolute;top:0;left:0}.annotation-canvas{pointer-events:none}.canvas-empty-state{color:#666;text-align:center;padding:var(--space-xl);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.zoom-indicator{color:#aaa;pointer-events:none;font-size:.7rem;font-family:var(--font-mono);background:#0009;border-radius:3px;padding:3px 8px;position:absolute;bottom:10px;right:10px}.canvas-toolbar__btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:3px;flex-direction:column;align-items:center;gap:1px;padding:3px 6px;font-size:.65rem;transition:all .15s;display:flex}.canvas-toolbar__btn--toggle.canvas-toolbar__btn--active{background:#5a5a2a;border-color:#7a7a3a}.canvas-toolbar__btn-label{opacity:.7;font-size:.5rem;line-height:1}.canvas-toolbar__view-controls,.canvas-toolbar__slider-group{align-items:center;gap:4px;display:flex}.canvas-toolbar__slider-group label{color:#777;text-transform:uppercase;font-size:.6rem}.canvas-toolbar__slider{appearance:none;cursor:pointer;background:#3a3a3a;border-radius:2px;outline:none;width:60px;height:4px}.canvas-toolbar__slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#4a6fa5;border-radius:50%;width:10px;height:10px}.canvas-toolbar__select:focus{outline:1px solid #4a6fa5}.canvas-toolbar__export-group{border-left:1px solid #3a3a3a;align-items:center;gap:4px;margin-left:6px;padding-left:8px;display:flex}.canvas-toolbar__select--sm{height:22px;padding:1px 3px;font-size:.65rem}.canvas-toolbar__range{appearance:none;cursor:pointer;background:#3a3a3a;border-radius:2px;outline:none;width:70px;height:4px}.canvas-toolbar__range::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#4a6fa5;border:1px solid #5a8fc5;border-radius:50%;width:12px;height:12px}.canvas-toolbar__range::-moz-range-thumb{cursor:pointer;background:#4a6fa5;border:1px solid #5a8fc5;border-radius:50%;width:12px;height:12px}.canvas-toolbar__range-label{color:#aaa;text-align:right;min-width:30px;font-size:.65rem}.canvas-toolbar__btn--export{color:#fff;background:#3a7bd5;border-color:#4a8be5;font-weight:600}.canvas-toolbar__btn--export:hover:not(:disabled){background:#4a8be5}.canvas-toolbar__btn--export:disabled{opacity:.7;background:#2a4a6a}.canvas-toolbar__zoom-btn{color:#ccc;cursor:pointer;background:#333;border:1px solid #444;border-radius:3px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:.85rem;display:flex}.canvas-toolbar__zoom-level{color:#aaa;font-size:.7rem;font-family:var(--font-mono);text-align:center;min-width:36px}.canvas-toolbar__count{color:#888;white-space:nowrap;font-size:.7rem}.sign-picker{background:#252525;border-right:1px solid #3a3a3a;flex-direction:column;flex-shrink:0;width:220px;height:100%;min-height:0;display:flex;overflow:hidden}.sign-picker__header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:10px 12px 6px;display:flex}.sign-picker__title{color:#aaa;text-transform:uppercase;letter-spacing:1px;margin:0;font-size:.7rem;font-weight:600}.sign-picker__add-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #555;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;font-weight:600;line-height:1;transition:all .15s;display:flex}.sign-picker__add-btn:hover{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.sign-picker__search{border-bottom:1px solid #333;padding:6px 10px}.sign-picker__input{color:#ccc;background:#1e1e1e;border:1px solid #3a3a3a;border-radius:3px;outline:none;width:100%;padding:5px 8px;font-size:.75rem}.sign-picker__input:focus{border-color:#4a6fa5}.sign-picker__list{flex:1;padding:4px 0;overflow-y:auto}.sign-picker__cat-header{color:#888;cursor:pointer;text-transform:uppercase;letter-spacing:.3px;background:0 0;border:none;align-items:center;gap:6px;width:100%;padding:6px 12px;font-size:.7rem;font-weight:600;display:flex}.sign-picker__cat-header:hover{color:#bbb;background:#2e2e2e}.sign-picker__cat-arrow{width:12px;font-size:.6rem}.sign-picker__cat-count{color:#555;margin-left:auto;font-size:.6rem}.sign-picker__codes{padding:0 6px}.sign-picker__code{color:#ccc;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:3px;align-items:center;gap:8px;width:100%;padding:5px 10px;font-size:.75rem;display:flex}.sign-picker__code:hover{background:#333}.sign-picker__code--active{background:#4a6fa533;border:1px solid #4a6fa5}.sign-picker__swatch{border-radius:2px;flex-shrink:0;width:10px;height:10px}.sign-picker__code-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sign-picker__code-id{color:var(--accent-primary,#4a90d9);font-family:var(--font-mono);opacity:.8;margin-right:4px;font-size:.65rem}.sign-picker__code-row{align-items:center;display:flex;position:relative}.sign-picker__code-row .sign-picker__code{flex:1;min-width:0}.sign-picker__edit-btn{background:var(--bg-tertiary,#2a2a2a);border:1px solid var(--border,#444);color:var(--text-secondary,#aaa);cursor:pointer;opacity:0;border-radius:3px;justify-content:center;align-items:center;width:20px;height:20px;padding:0;font-size:13px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:50%;right:2px;transform:translateY(-50%)}.sign-picker__code-row:hover .sign-picker__edit-btn{opacity:1}.sign-picker__edit-btn:hover{background:var(--accent-primary,#4a90d9);color:#fff;border-color:var(--accent-primary,#4a90d9)}.sign-picker__empty{color:#555;text-align:center;padding:20px 12px;font-size:.75rem}.canvas-right-panel{background:#252525;border-left:1px solid #3a3a3a;flex-direction:column;flex-shrink:0;width:260px;display:flex;overflow:hidden}.sign-detail{border-bottom:2px solid #3a3a3a;flex-direction:column;display:flex;overflow-y:auto}.sign-detail__header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:10px 12px 6px;display:flex}.sign-detail__title{color:#aaa;text-transform:uppercase;letter-spacing:1px;margin:0;font-size:.7rem;font-weight:600}.sign-detail__close{color:#666;cursor:pointer;background:0 0;border:none;border-radius:2px;padding:2px 4px;font-size:.9rem}.sign-detail__close:hover{color:#fff;background:#3a3a3a}.sign-detail__section{border-bottom:1px solid #2e2e2e;padding:10px 12px}.sign-detail__code-info{align-items:center;gap:10px;display:flex}.sign-detail__swatch{border-radius:3px;flex-shrink:0;width:20px;height:20px}.sign-detail__code-name{color:#eee;font-size:.85rem;font-weight:600}.sign-detail__code-cat{color:#777;font-size:.7rem}.sign-detail__code-id{color:var(--accent-primary,#4a90d9);font-size:.7rem;font-family:var(--font-mono);letter-spacing:.3px}.sign-detail__size-row{align-items:center;gap:6px;display:flex}.sign-detail__size-field{flex:1;align-items:center;gap:4px;display:flex}.sign-detail__size-prefix{color:#666;text-transform:uppercase;font-size:.65rem;font-weight:600}.sign-detail__size-input{color:#ccc;width:100%;font-size:.75rem;font-family:var(--font-mono);background:#1e1e1e;border:1px solid #3a3a3a;border-radius:3px;padding:4px 6px}.sign-detail__size-input:focus{border-color:#4a6fa5;outline:none}.sign-detail__size-sep{color:#555;font-size:.75rem}.sign-detail__label{color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.65rem;font-weight:600;display:block}.sign-detail__row{gap:var(--space-md);display:flex}.sign-detail__coord{color:#aaa;font-size:.75rem;font-family:var(--font-mono)}.sign-detail__field{margin-bottom:8px}.sign-detail__field--checkbox label{color:#ccc;text-transform:none;letter-spacing:0;cursor:pointer;align-items:center;gap:6px;font-size:.75rem;display:flex}.sign-detail__field--checkbox input[type=checkbox]{accent-color:var(--accent-primary)}.sign-detail__field label{color:#777;text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;font-size:.65rem;display:block}.sign-detail__select,.sign-detail__input,.sign-detail__textarea{color:#ccc;background:#1e1e1e;border:1px solid #3a3a3a;border-radius:3px;width:100%;padding:5px 8px;font-family:inherit;font-size:.75rem}.sign-detail__textarea{resize:vertical}.sign-detail__select:focus,.sign-detail__input:focus,.sign-detail__textarea:focus{border-color:#4a6fa5;outline:none}.sign-detail__actions{gap:var(--space-sm);flex-direction:column;padding:12px;display:flex}.placed-signs-panel{flex-direction:column;flex:1;display:flex;overflow:hidden}.placed-signs-panel__header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:10px 12px 6px;display:flex}.placed-signs-panel__title{color:#777;text-transform:uppercase;letter-spacing:1px;font-size:.65rem;font-weight:600}.placed-signs-panel__badge{color:#aaa;background:#3a3a3a;border-radius:8px;padding:1px 6px;font-size:.65rem;font-weight:600}.placed-signs-panel__item{cursor:pointer;border-radius:0;align-items:center;gap:8px;padding:5px 12px;transition:background .1s;display:flex}.placed-signs-panel__item--selected{background:#4a6fa522;border-left:2px solid #4a6fa5}.placed-signs-panel__code{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.75rem;font-weight:500;overflow:hidden}.placed-signs-panel__delete{color:#555;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:2px;padding:2px 4px;font-size:.65rem;transition:opacity .15s}.placed-signs-panel__delete:hover{color:#ef4444;background:#3a3a3a}.sign-picker__list::-webkit-scrollbar{width:4px}.sign-detail::-webkit-scrollbar{width:4px}.placed-signs-panel__list::-webkit-scrollbar{width:4px}.sign-picker__list::-webkit-scrollbar-thumb{background:#444;border-radius:2px}.sign-detail::-webkit-scrollbar-thumb{background:#444;border-radius:2px}.placed-signs-panel__list::-webkit-scrollbar-thumb{background:#444;border-radius:2px}.sign-picker__list::-webkit-scrollbar-track{background:0 0}.sign-detail::-webkit-scrollbar-track{background:0 0}.placed-signs-panel__list::-webkit-scrollbar-track{background:0 0}.canvas-page{color:#eee;background:#1a1a1a;flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.canvas-page--loading,.canvas-page--error{flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.canvas-loading{color:#888;flex:1;justify-content:center;align-items:center;font-size:.9rem;display:flex}.canvas-topbar{z-index:10;background:#222;border-bottom:1px solid #333;flex-shrink:0;align-items:center;gap:1rem;min-height:48px;padding:.4rem .75rem;display:flex}.canvas-secondary-toolbar{z-index:9;background:#1e1e1e;border-bottom:1px solid #333;flex-shrink:0;align-items:center;gap:.75rem;min-height:38px;padding:.25rem .75rem;display:flex}.canvas-toolbar__nudge-dpad .canvas-toolbar__btn{background:#333;border:1px solid #444;border-radius:4px}.canvas-toolbar__nudge-dpad .canvas-toolbar__btn:hover{background:#444;border-color:#555}.canvas-topbar__back{color:#aaa;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:.85rem;display:flex}.canvas-topbar__back:hover{color:#fff;background:#333}.canvas-topbar__uploading{color:var(--color-primary,#3b82f6);margin-left:auto;font-size:.8rem;animation:1s infinite pulse}.canvas-toolbar-full{flex:1;align-items:center;gap:.25rem .75rem;display:flex}.canvas-toolbar-full::-webkit-scrollbar{display:none}.canvas-toolbar__section{border-right:1px solid #333;align-items:center;gap:4px;height:36px;padding:0 6px;display:flex}.canvas-toolbar__section:last-child{border-right:none}.canvas-toolbar__row-break{flex-basis:100%;height:0;margin:0;padding:0}.canvas-toolbar__group-label{color:#666;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;margin-right:2px;font-size:.55rem}.canvas-toolbar__tools{gap:2px;display:flex}.canvas-toolbar__btn{color:#999;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;min-width:36px;height:32px;padding:2px 6px;transition:all .15s;display:flex}.canvas-toolbar__btn:hover{color:#fff;background:#333}.canvas-toolbar__btn--active{color:#fff;background:#3b82f6;border-color:#3b82f6}.canvas-toolbar__btn--calibrating{animation:1.2s infinite pulse}.canvas-toolbar__btn:disabled{opacity:.3;cursor:not-allowed}.canvas-toolbar__btn--upload{cursor:pointer}.canvas-toolbar__btn--add-floor{min-width:28px;font-size:1.1rem;font-weight:700}.canvas-toolbar__icon{font-size:1rem;line-height:1}.canvas-toolbar__btn-label{letter-spacing:.03em;font-size:.55rem;line-height:1}.canvas-toolbar__scale-label{color:#10b981;white-space:nowrap;background:#10b9811a;border-radius:3px;padding:2px 6px;font-size:.7rem}.canvas-toolbar__slider-group{align-items:center;gap:4px;display:flex}.canvas-toolbar__slider-group label{color:#888;white-space:nowrap;font-size:.6rem}.canvas-toolbar__slider{appearance:none;background:#444;border-radius:2px;outline:none;width:60px;height:3px}.canvas-toolbar__slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#3b82f6;border-radius:50%;width:10px;height:10px}.canvas-toolbar__view-controls{align-items:center;gap:4px;display:flex}.canvas-toolbar__select{color:#ddd;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:3px;padding:2px 4px;font-size:.75rem}.canvas-toolbar__zoom{align-items:center;gap:2px;display:flex}.canvas-toolbar__zoom-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #444;border-radius:3px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.9rem;display:flex}.canvas-toolbar__zoom-btn:hover{color:#fff;background:#333}.canvas-toolbar__zoom-level{color:#888;text-align:center;width:40px;font-size:.7rem}.canvas-toolbar__section--count{gap:6px}.canvas-toolbar__count{color:#888;font-size:.75rem}.canvas-side-tools{border-right:1px solid var(--border);background:#1e1e1e;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:44px;height:100%;min-height:0;padding:6px 4px;display:flex}.canvas-side-tools__group{border-bottom:1px solid #ffffff0f;flex-direction:column;align-items:center;gap:2px;width:100%;padding:4px 0;display:flex}.canvas-side-tools__group:last-child{border-bottom:none}.canvas-side-tools__label{color:#666;letter-spacing:.05em;text-transform:uppercase;margin-bottom:2px;font-size:.5rem}.canvas-side-tools__btn{color:#999;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:1px;width:34px;height:34px;transition:all .15s;display:flex}.canvas-side-tools__btn:hover{color:#fff;background:#2a2a2a}.canvas-side-tools__btn--active{background:var(--accent,#3b82f6);color:#fff;border-color:var(--accent,#3b82f6)}.canvas-side-tools__btn--small{width:30px;height:28px}.canvas-side-tools__icon{font-size:14px;line-height:1}.canvas-side-tools__shortcut{opacity:.6;font-size:.55rem;line-height:1}.canvas-side-tools__info{color:#10b981;white-space:nowrap;text-overflow:ellipsis;background:#10b9811a;border-radius:2px;max-width:40px;padding:1px 4px;font-size:.55rem;overflow:hidden}.canvas-side-tools__select{color:#ddd;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:3px;width:100%;padding:1px 2px;font-size:.6rem}.canvas-side-tools__btn--calibrating{animation:1.2s infinite pulse}.canvas-toolbar__nudge-input{color:#ddd;text-align:center;background:#2a2a2a;border:1px solid #444;border-radius:3px;outline:none;width:36px;padding:2px 4px;font-size:.7rem}.canvas-toolbar__nudge-input:focus{border-color:#3b82f6}.canvas-body{flex:1;min-height:0;display:flex;position:relative}.canvas-viewport{background:#1a1a1a;flex:1;position:relative;overflow:hidden}.canvas-viewport.cursor-grab{cursor:grab}.canvas-viewport.cursor-grab:active{cursor:grabbing}.canvas-viewport.cursor-crosshair{cursor:crosshair}.canvas-viewport.cursor-default{cursor:default}.canvas-viewport--drag-over{outline-offset:-3px;outline:3px dashed #3b82f6}.drawing-container{transform-origin:0 0;position:absolute;top:0;left:0}.drawing-canvas,.annotation-canvas,.sheet-canvas,.template-canvas{position:absolute;top:0;left:0}.template-canvas{z-index:3;pointer-events:none}.sheet-canvas{z-index:4;pointer-events:none}.drawing-canvas{z-index:1}.annotation-canvas{z-index:2;pointer-events:none}.canvas-toolbar__btn--sheet-toggle.canvas-toolbar__btn--active{color:var(--accent,#3b82f6);background:#3b82f640;border-color:#3b82f680}.canvas-toolbar__sheet-hint{color:#f59e0b;white-space:nowrap;text-overflow:ellipsis;background:#f59e0b14;border:1px solid #f59e0b26;border-radius:3px;max-width:240px;padding:2px 6px;font-size:.6rem;font-style:italic;overflow:hidden}.canvas-toolbar__artboard-controls{align-items:center;gap:4px;display:flex}.canvas-toolbar__artboard-dropdown{min-width:60px;font-size:.7rem}.canvas-toolbar__artboard-input{color:#ddd;text-align:center;background:#2a2a2a;border:1px solid #444;border-radius:3px;outline:none;width:50px;padding:2px 4px;font-size:.7rem}.canvas-toolbar__artboard-input:focus{border-color:#3b82f6}.canvas-toolbar__artboard-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.canvas-toolbar__artboard-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.canvas-toolbar__artboard-unit{color:#888;font-size:.6rem}.zoom-indicator{color:#888;pointer-events:none;background:#000000a6;border-radius:3px;padding:2px 8px;font-size:.7rem;position:absolute;bottom:12px;right:12px}.canvas-legend-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-md);color:var(--text-primary);-webkit-user-select:none;user-select:none;background:#141418eb;border:1px solid #ffffff14;font-size:.75rem;overflow:hidden;box-shadow:0 8px 30px #0006}.canvas-legend-panel__header{background:#ffffff0a;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.canvas-legend-panel__title{align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.canvas-legend-panel__count{color:var(--text-muted);font-size:.7rem;font-weight:400}.canvas-legend-panel__toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:.65rem;transition:background .15s}.canvas-legend-panel__toggle:hover{color:var(--text-primary);background:#ffffff14}.canvas-legend-panel__body{max-height:300px;padding:6px 0;overflow-y:auto}.canvas-legend-panel__empty{text-align:center;color:var(--text-muted);padding:16px 12px;font-size:.7rem;font-style:italic}.canvas-legend-panel__table{border-collapse:collapse;width:100%}.canvas-legend-panel__table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid #ffffff0f;padding:4px 10px;font-size:.65rem;font-weight:500}.canvas-legend-panel__table td{white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid #ffffff08;max-width:120px;padding:5px 10px;font-size:.72rem;overflow:hidden}.canvas-legend-panel__table tr:hover td{background:#ffffff08}.canvas-legend-panel__swatch{vertical-align:middle;border-radius:50%;width:10px;height:10px;display:inline-block}.canvas-legend-panel__code{font-weight:600;font-family:var(--font-mono,monospace);font-size:.7rem}.canvas-legend-panel__name{color:var(--text-secondary)}.canvas-legend-panel__mounting{color:var(--text-muted);font-size:.68rem}.canvas-empty-state{color:#888;z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex;position:absolute;inset:0}.canvas-empty-state__icon{opacity:.5;font-size:3rem}.canvas-empty-state h3{color:#ccc;margin:0;font-size:1.2rem}.canvas-empty-state p{color:#777;margin:0;font-size:.9rem}.canvas-empty-state__cta{color:#fff;cursor:pointer;background:#3b82f6;border-radius:6px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.6rem 1.5rem;font-size:.9rem;transition:background .2s;display:inline-flex}.canvas-empty-state__cta:hover{background:#2563eb}.canvas-empty-state__hint{color:#555;font-size:.75rem}.canvas-drag-overlay{z-index:20;pointer-events:none;background:#3b82f626;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.canvas-drag-overlay__content{color:#3b82f6;flex-direction:column;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;display:flex}.canvas-drag-overlay__icon{font-size:2.5rem}.calibration-overlay{z-index:15;pointer-events:none;position:absolute;top:12px;left:50%;transform:translate(-50%)}.calibration-overlay__msg{color:#fff;white-space:nowrap;background:#3b82f6e6;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1.5rem;font-size:.85rem;font-weight:500;display:flex;box-shadow:0 2px 12px #0000004d}.calibration-overlay__hint{opacity:.7;font-size:.7rem}.calibration-modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.calibration-modal{background:#2a2a2a;border:1px solid #444;border-radius:10px;width:360px;max-width:90vw;padding:1.5rem 2rem;box-shadow:0 8px 32px #00000080}.calibration-modal__title{color:#fff;margin:0 0 .5rem;font-size:1.1rem}.calibration-modal__desc{color:#aaa;margin:0 0 1rem;font-size:.85rem}.calibration-modal__row{gap:.5rem;margin-bottom:.75rem;display:flex}.calibration-modal__input{color:#fff;background:#1a1a1a;border:1px solid #444;border-radius:6px;outline:none;flex:1;padding:.5rem .75rem;font-size:.95rem}.calibration-modal__input:focus{border-color:#3b82f6}.calibration-modal__unit{color:#fff;background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:.5rem;font-size:.85rem}.calibration-modal__info{color:#666;margin-bottom:1rem;font-size:.75rem}.calibration-modal__actions{justify-content:flex-end;gap:.5rem;display:flex}.canvas-right-panel{background:#222;border-left:1px solid #333;flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow-y:auto}.placed-signs-panel{flex-direction:column;flex:1;display:flex}.placed-signs-panel__header{justify-content:space-between;align-items:center;padding:.75rem 1rem .5rem;display:flex}.placed-signs-panel__title{letter-spacing:.1em;color:#888;font-size:.65rem}.placed-signs-panel__badge{color:#aaa;background:#333;border-radius:8px;padding:1px 6px;font-size:.7rem}.placed-signs-panel__list{flex:1;padding:0 .5rem .5rem;overflow-y:auto}.placed-signs-panel__empty{color:#555;text-align:center;padding:1rem;font-size:.8rem}.placed-signs-panel__item{cursor:pointer;border-radius:4px;align-items:center;gap:.4rem;padding:.35rem .5rem;font-size:.8rem;transition:background .15s;display:flex}.placed-signs-panel__item:hover{background:#2a2a2a}.placed-signs-panel__item--selected{background:#333}.placed-signs-panel__dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.placed-signs-panel__code{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.placed-signs-panel__delete{color:#555;cursor:pointer;opacity:0;background:0 0;border:none;padding:0;font-size:.7rem;transition:opacity .15s}.placed-signs-panel__item:hover .placed-signs-panel__delete{opacity:1}.placed-signs-panel__delete:hover{color:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.color-group-tabs{gap:4px;margin-bottom:8px;display:flex}.color-group-tab{color:#aaa;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:0 0;border:1px solid #444;border-radius:4px;padding:4px 10px;font-size:.7rem;font-weight:500;transition:all .15s}.color-group-tab:hover{color:#fff;border-color:#666}.color-group-tab--active{background:var(--accent);border-color:var(--accent);color:var(--accent-text)}.color-swatches{background:#0003;border:1px solid #333;border-radius:6px;grid-template-columns:repeat(auto-fill,minmax(24px,1fr));gap:3px;max-height:120px;padding:4px;display:grid;overflow-y:auto}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:4px;width:24px;height:24px;padding:0;transition:all .12s}.color-swatch:hover{z-index:1;border-color:#ffffff80;transform:scale(1.2)}.color-swatch--active{box-shadow:0 0 0 2px var(--accent);border-color:#fff;transform:scale(1.15)}.activity-log{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.activity-log__header{padding:var(--space-md)var(--space-lg);border-bottom:1px solid var(--border-subtle)}.activity-log__filters{padding:var(--space-sm)var(--space-lg);border-bottom:1px solid var(--border-subtle);gap:2px;display:flex;overflow-x:auto}.activity-log__filter-tab{padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none}.activity-log__filter-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.activity-log__filter-tab--active{color:var(--accent);background:var(--accent-subtle)}.activity-log__timeline{padding:var(--space-sm)0;max-height:480px;overflow-y:auto}.activity-log__entry{align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm)var(--space-lg);transition:background var(--transition-fast);display:flex}.activity-log__entry:hover{background:var(--bg-hover)}.activity-log__icon{text-align:center;flex-shrink:0;width:20px;font-size:14px;line-height:20px}.activity-log__content{align-items:baseline;gap:var(--space-sm);flex-wrap:wrap;flex:1;min-width:0;display:flex}.activity-log__text{font-size:var(--text-body-size);color:var(--text-primary);line-height:var(--text-body-lh)}.activity-log__time{font-size:var(--text-caption-size);color:var(--text-muted);white-space:nowrap;flex-shrink:0}.activity-log__load-more{width:100%;margin-top:var(--space-xs);border-top:1px solid var(--border-subtle);border-radius:0}.activity-log__loading{padding:var(--space-sm)0}.activity-log__skeleton{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-lg);display:flex}.boq-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.boq-stat-card{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)var(--space-md);text-align:center;transition:border-color var(--transition-fast)}.boq-stat-card:hover{border-color:var(--color-primary)}.boq-stat-value{color:var(--text-primary);font-size:28px;font-weight:700;font-family:var(--font-mono);line-height:1.2}.boq-stat-label{font-size:var(--text-caption-size);color:var(--text-secondary);margin-top:var(--space-xs);text-transform:uppercase;letter-spacing:.5px}.boq-toolbar{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.boq-toolbar__left{align-items:center;gap:var(--space-sm);flex:1;display:flex}.boq-toolbar__right{align-items:center;gap:var(--space-sm);display:flex}.boq-preset-select{max-width:180px}.boq-search{max-width:200px}.boq-table-wrap{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-elevated);overflow-x:auto}.boq-table{border-collapse:collapse;width:100%;font-size:var(--text-body-size)}.boq-th{text-align:left;padding:var(--space-sm)var(--space-md);background:var(--bg-surface);border-bottom:2px solid var(--border-color);font-size:var(--text-caption-size);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;z-index:2;font-weight:600;position:sticky;top:0}.boq-th--num{text-align:center;width:40px}.boq-th--floor{text-align:center;min-width:50px}.boq-td{padding:var(--space-xs)var(--space-md);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.boq-td--num{text-align:center;color:var(--text-muted);font-size:var(--text-caption-size)}.boq-td--floor{text-align:center;font-family:var(--font-mono);font-size:var(--text-caption-size)}.boq-row--alt{background:var(--bg-subtle)}.boq-color-dot{border-radius:var(--radius-full);border:1px solid #fff3;flex-shrink:0;width:10px;height:10px;display:inline-block}.boq-category-header td{background:var(--bg-surface);padding:var(--space-sm)var(--space-md);border-bottom:2px solid var(--border-color);font-weight:600}.boq-category-label{font-size:var(--text-body-size);color:var(--text-primary);font-weight:600}.boq-category-count{margin-left:var(--space-sm);font-size:var(--text-caption-size);color:var(--text-secondary);font-weight:400}.boq-subtotal-row td{background:var(--bg-subtle);border-bottom:2px solid var(--border-color);font-size:var(--text-caption-size);color:var(--text-secondary);padding:var(--space-xs)var(--space-md)}.boq-grand-total td{background:var(--bg-surface);border-top:2px solid var(--border-color);padding:var(--space-sm)var(--space-md);font-size:var(--text-body-size)}.boq-skeleton{gap:var(--space-sm);padding:var(--space-lg);flex-direction:column;display:flex}.skeleton-row{background:var(--bg-subtle);border-radius:var(--radius-md);height:36px;animation:1.5s ease-in-out infinite skeleton-pulse}@media (max-width:768px){.boq-summary-grid{grid-template-columns:repeat(2,1fr)}.boq-toolbar{flex-direction:column;align-items:stretch}.boq-toolbar__left,.boq-toolbar__right{width:100%}.boq-preset-select,.boq-search{max-width:100%}}.designer-toolbar{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.designer-toolbar__left{align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.designer-toolbar__right{color:var(--text-secondary);font-size:var(--text-caption-size);white-space:nowrap}.designer-toolbar__group{align-items:center;gap:var(--space-xs);display:flex}.designer-toolbar__label{font-size:var(--text-caption-size);color:var(--text-secondary);white-space:nowrap}.designer-toolbar__select{min-width:120px;font-size:var(--text-body-size)}.designer-toolbar__search{min-width:180px;max-width:240px}.designer-group{margin-bottom:var(--space-md);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-primary);overflow:hidden}.designer-group__header{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm)var(--space-md);background:var(--bg-secondary);cursor:pointer;font-size:var(--text-body-size);color:var(--text-primary);text-align:left;border:none;font-weight:600;transition:background .15s;display:flex}.designer-group__header:hover{background:var(--bg-tertiary)}.designer-group__chevron{color:var(--text-muted);font-size:.8em;transition:transform .2s;display:inline-block}.designer-group__chevron--open{transform:rotate(90deg)}.designer-group__title{flex:1}.designer-group__count{font-size:var(--text-caption-size);color:var(--text-muted);font-weight:400}.designer-group__body{padding:var(--space-sm);gap:var(--space-sm);flex-direction:column;display:flex}.designer-card{border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);background:var(--bg-primary);transition:box-shadow .15s,border-color .15s}.designer-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #00000014}.designer-card__header{justify-content:space-between;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);display:flex}.designer-card__identity{align-items:center;gap:var(--space-sm);min-width:0;display:flex}.designer-card__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.designer-card__code{font-family:var(--font-mono);font-weight:600;font-size:var(--text-body-size);white-space:nowrap}.designer-card__name{color:var(--text-secondary);font-size:var(--text-caption-size);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.designer-card__badges{gap:var(--space-xs);flex-shrink:0;display:flex}.designer-card__badge{border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);white-space:nowrap;padding:1px 6px;font-size:11px}.designer-card__specs{align-items:center;gap:var(--space-xs);font-size:var(--text-caption-size);color:var(--text-muted);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.designer-card__sep{opacity:.4}.designer-card__actions{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);display:flex}.designer-card__status-group{align-items:center;gap:var(--space-xs);display:flex}.designer-card__status-select{font-size:var(--text-caption-size);border:1px solid var(--border);border-radius:var(--radius-sm);background-color:var(--bg-elevated);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238888aa'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:10px;outline:none;padding:4px 24px 4px 10px;font-weight:500;transition:border-color .15s}.designer-card__status-select:hover{border-color:var(--accent)}.designer-card__status-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f133}.designer-card__status-select option{background-color:var(--bg-elevated);color:var(--text-primary);padding:6px 10px}.designer-card__upload-group{align-items:center;gap:var(--space-xs);display:flex}.designer-card__version{font-size:11px;font-family:var(--font-mono);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--accent);padding:1px 6px}.designer-card__warnings{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.designer-card__warning-badge{font-size:var(--text-caption-size);color:#f59e0b;background:#f59e0b26;border:1px solid #f59e0b4d;border-radius:999px;padding:3px 10px;font-weight:500}.designer-card__preview{gap:var(--space-sm);padding:var(--space-sm);margin-bottom:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;display:flex}.designer-card__preview-grid{gap:var(--space-xs);flex-wrap:wrap;display:flex}.designer-card__img-count{font-size:var(--text-caption-size);color:var(--text-muted);text-align:right}.designer-card__design-area{padding:var(--space-sm);margin-bottom:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none}.designer-card__design-area:focus-within{border-color:var(--accent,#3b82f6)}.designer-card__design-meta{margin-top:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.designer-card__add-img-btn{border:2px dashed var(--border);border-radius:var(--radius-sm);width:80px;height:80px;color:var(--text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;font-size:24px;transition:all .2s;display:flex}.designer-card__add-img-btn:hover{border-color:var(--accent,#3b82f6);color:var(--accent,#3b82f6);background:#3b82f60d}.designer-card__new-revision-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:3px 8px;font-size:11px;transition:all .2s}.designer-card__new-revision-btn:hover{border-color:var(--accent,#3b82f6);color:var(--accent,#3b82f6)}.designer-card__first-upload{width:100%;padding:var(--space-md);border:2px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-body-size);cursor:pointer;background:0 0;transition:all .2s}.designer-card__first-upload:hover{border-color:var(--accent,#3b82f6);color:var(--accent,#3b82f6);background:#3b82f60d}.designer-card__file-hint{color:var(--text-muted);text-align:center;margin-top:var(--space-xs);opacity:.7;font-size:10px;font-style:italic;display:block}.designer-card__preview-link{flex-shrink:0}.designer-card__preview-img{border-radius:var(--radius-sm);object-fit:contain;border:1px solid var(--border);background:var(--bg-primary);max-width:120px;max-height:80px;display:block}.designer-card__preview-file{align-items:center;gap:var(--space-xs);flex:1;min-width:0;display:flex}.designer-card__preview-icon{flex-shrink:0;font-size:1.4rem}.designer-card__preview-name{font-size:var(--text-caption-size);font-family:var(--font-mono);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.designer-card__spec-edit{gap:var(--space-sm);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.designer-card__spec-field{flex-direction:column;gap:2px;min-width:80px;display:flex}.designer-card__spec-field--wide{flex:1;min-width:160px}.designer-card__spec-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.designer-card__spec-field input{font-size:var(--text-caption-size);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);outline:none;padding:3px 6px;transition:border-color .15s}.designer-card__spec-field input:focus{border-color:var(--accent)}.designer-card__notes{border-top:1px solid var(--border);padding-top:var(--space-xs)}.designer-card__notes-toggle{width:100%;padding:var(--space-xs)0;cursor:pointer;font-size:var(--text-caption-size);color:var(--text-secondary);background:0 0;border:none;justify-content:space-between;align-items:center;font-weight:500;display:flex}.designer-card__notes-toggle:hover{color:var(--text-primary)}.designer-card__chevron{font-size:.8em;transition:transform .2s;display:inline-block}.designer-card__chevron--open{transform:rotate(90deg)}.designer-card__notes-list{margin-top:var(--space-xs);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:1px;display:flex;overflow:hidden}.designer-card__note{gap:var(--space-sm);padding:var(--space-xs)var(--space-sm);background:var(--bg-secondary);font-size:var(--text-caption-size);display:flex}.designer-card__note:nth-child(2n){background:var(--bg-primary)}.designer-card__note-floor{font-family:var(--font-mono);color:var(--accent);flex-shrink:0;min-width:32px;font-weight:600}.designer-card__note-content{flex:1;min-width:0}.designer-card__note-side{gap:var(--space-xs);display:flex}.designer-card__note-label{color:var(--text-muted);flex-shrink:0;width:16px;font-weight:600}.designer-skeleton{gap:var(--space-md);padding:var(--space-lg)0;flex-direction:column;display:flex}@media (max-width:640px){.designer-toolbar{flex-direction:column;align-items:stretch}.designer-toolbar__left{flex-direction:column}.designer-toolbar__search{min-width:100%;max-width:100%}.designer-card__header,.designer-card__actions{flex-direction:column;align-items:flex-start}.designer-card__spec-edit{flex-direction:column}.designer-card__spec-field{min-width:100%}}.planner-floor-grid{gap:var(--space-sm);flex-direction:column;display:flex}.planner-floor-card{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-subtle);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .15s,background .15s;display:flex}.planner-floor-card:hover{border-color:var(--accent);background:var(--bg-elevated)}.planner-floor-card__thumb{border-radius:var(--radius-sm);flex-shrink:0;width:60px;height:60px;overflow:hidden}.planner-floor-card__img{object-fit:cover;width:100%;height:100%}.planner-floor-card__pdf,.planner-floor-card__placeholder{background:var(--bg-elevated);width:100%;height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex}.planner-floor-card__info{flex:1;min-width:0}.planner-floor-card__name{font-weight:600;font-size:var(--text-body-size);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.planner-floor-card__meta{margin-top:4px}.designer-task-list{background:var(--bg-subtle);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;gap:2px;display:flex;overflow:hidden}.designer-task-row{padding:var(--space-sm)var(--space-md);background:var(--bg-primary);justify-content:space-between;align-items:center;transition:background .15s;display:flex}.designer-task-row:hover{background:var(--bg-elevated)}.designer-task-row--completed{opacity:.6}.designer-task-row__info{align-items:center;gap:var(--space-sm);flex:1;min-width:0;display:flex}.designer-task-row__code{font-weight:700;font-family:var(--font-mono);font-size:var(--text-body-size);color:var(--accent);white-space:nowrap}.designer-task-row__name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.designer-task-row__meta{color:var(--text-muted);font-size:var(--text-label-size);white-space:nowrap}.designer-task-row__actions{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.designer-task-row__status{font-size:var(--text-label-size);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;font-weight:600}.designer-task-row__status--pending{background:rgba(var(--warning-rgb,255,175,60),.15);color:var(--warning)}.designer-task-row__status--draft{background:rgba(var(--info-rgb,59,130,246),.15);color:var(--info)}.designer-task-row__status--done{background:rgba(var(--accent-rgb,99,102,241),.15);color:var(--accent)}.designer-task-row__status--approved{background:rgba(var(--success-rgb,34,197,94),.15);color:var(--success)}.lead-design-summary{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.lead-design-summary__item{background:var(--bg-subtle);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-label-size);align-items:center;gap:6px;padding:6px 12px;font-weight:600;display:flex}.pending-approval-list{gap:var(--space-sm);flex-direction:column;display:flex}.pending-approval-card{padding:var(--space-sm)var(--space-md);background:var(--bg-subtle);border:1px solid var(--border-color);border-left:3px solid var(--accent);border-radius:var(--radius-md);justify-content:space-between;align-items:center;display:flex}.pending-approval-card__info{align-items:center;gap:var(--space-sm);display:flex}.pending-approval-card__code{font-weight:700;font-family:var(--font-mono);color:var(--accent)}.pending-approval-card__name{color:var(--text-secondary)}@media (max-width:640px){.designer-task-row{align-items:flex-start;gap:var(--space-xs);flex-direction:column}.designer-task-row__actions{justify-content:space-between;width:100%}.designer-task-row__meta{display:none}.planner-floor-card{flex-wrap:wrap}}.role-switcher{width:100%}.role-switcher__badge{width:100%;padding:var(--space-xs)var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-label-size);cursor:pointer;background:0 0;align-items:center;gap:6px;font-weight:600;transition:background .15s,border-color .15s;display:flex}.role-switcher__badge:hover{background:var(--bg-elevated);border-color:var(--accent)}.role-switcher__arrow{opacity:.5;margin-left:auto;font-size:.6rem;transition:transform .2s}.role-switcher__menu{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);z-index:100;margin-bottom:4px;position:absolute;bottom:100%;left:0;right:0;overflow:hidden;box-shadow:0 -4px 16px #0000004d}.role-switcher__option{width:100%;color:var(--text-primary);font-size:var(--text-body-size);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;transition:background .1s;display:flex}.role-switcher__option:hover{background:var(--bg-subtle)}.role-switcher__option--active{background:rgba(var(--accent-rgb,99,102,241),.12);color:var(--accent)}.role-switcher__check{color:var(--accent);margin-left:auto;font-weight:700}.notes-page{max-width:900px;margin:0 auto;padding:2rem 1.5rem}.notes-page__header{margin-bottom:1.5rem}.notes-page__title-row{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.notes-page__title{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:700}.notes-page__create-btn{background:var(--accent);color:var(--accent-text);cursor:pointer;border:none;border-radius:8px;padding:.5rem 1.2rem;font-size:.85rem;font-weight:600;transition:background .2s}.notes-page__create-btn:hover{filter:brightness(1.1)}.notes-page__stats{gap:1rem;display:flex}.notes-page__stat{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:1;align-items:center;padding:.75rem;display:flex}.notes-page__stat-value{color:var(--text-primary);font-size:1.6rem;font-weight:700}.notes-page__stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:2px;font-size:.72rem}.notes-page__stat--open .notes-page__stat-value{color:#f59e0b}.notes-page__stat--resolved .notes-page__stat-value{color:#10b981}.notes-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.notes-form__body{background:var(--bg-primary);border:1px solid var(--border);width:100%;min-height:80px;color:var(--text-primary);resize:vertical;border-radius:8px;margin-bottom:.75rem;padding:.75rem;font-family:inherit;font-size:.9rem}.notes-form__body:focus{border-color:var(--accent);outline:none}.notes-form__attachments{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.notes-form__file-chip{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);border-radius:6px;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.78rem;display:flex}.notes-form__file-icon{font-size:.9rem}.notes-form__file-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.notes-form__file-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:.7rem}.notes-form__file-remove:hover{color:var(--danger,#ef4444)}.notes-form__add-file{border:1px dashed var(--border);color:var(--text-muted);cursor:pointer;border-radius:6px;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.78rem;transition:border-color .2s;display:flex}.notes-form__add-file:hover{border-color:var(--accent);color:var(--accent)}.notes-form__file-hint{opacity:.7;font-size:.65rem}.notes-form__options{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.notes-form__field{flex-direction:column;gap:.25rem;display:flex}.notes-form__field label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:.7rem;font-weight:600}.notes-form__field select{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-position:right .6rem center;background-repeat:no-repeat;background-size:10px 6px;min-width:120px;padding:.45rem 2rem .45rem .65rem;font-size:.82rem}.notes-form__field select:focus{border-color:var(--accent);outline:none}.notes-form__submit{background:var(--accent);color:var(--accent-text);cursor:pointer;border:none;border-radius:8px;margin-left:auto;padding:.5rem 1.5rem;font-size:.85rem;font-weight:600}.notes-form__submit:disabled{opacity:.5;cursor:not-allowed}.notes-page__filters{gap:1rem;margin-bottom:1rem;display:flex}.notes-page__filter-group{align-items:center;gap:.4rem;display:flex}.notes-page__filter-group label{color:var(--text-muted);font-size:.75rem;font-weight:600}.notes-page__filter-group select{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;padding:.35rem .6rem;font-size:.82rem}.notes-page__list{flex-direction:column;gap:.75rem;display:flex}.notes-page__loading,.notes-page__empty{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.9rem}.notes-page__empty{flex-direction:column;align-items:center;gap:.5rem;display:flex}.notes-page__empty-icon{font-size:2rem}.note-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:1rem 1.25rem;transition:border-color .2s}.note-card:hover{border-color:var(--accent)}.note-card--resolved{opacity:.65}.note-card__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;display:flex}.note-card__author{align-items:center;gap:.4rem;display:flex}.note-card__avatar{font-size:1.1rem}.note-card__name{color:var(--text-primary);font-size:.85rem;font-weight:600}.note-card__time{color:var(--text-muted);font-size:.72rem}.note-card__badges{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.note-card__role-badge{border-radius:20px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.note-card__role-badge--lead{color:#f59e0b;background:#f59e0b26}.note-card__role-badge--planner{color:#3b82f6;background:#3b82f626}.note-card__role-badge--designer{color:#a855f7;background:#a855f726}.note-card__code-badge{background:rgba(var(--accent-rgb,99,102,241),.12);color:var(--accent);border-radius:20px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.note-card__status-badge{border-radius:20px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.note-card__status-badge--done{color:#10b981;background:#10b98126}.note-card__body{color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;margin-bottom:.5rem;font-size:.88rem;line-height:1.5}.note-card__attachments{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;display:flex}.note-card__img-thumb{border:1px solid var(--border);border-radius:6px;width:80px;height:80px;display:block;overflow:hidden}.note-card__img-thumb img{object-fit:cover;width:100%;height:100%}.note-card__pdf-link{background:var(--bg-primary);border:1px solid var(--border);color:var(--accent);border-radius:6px;align-items:center;gap:.3rem;padding:.3rem .6rem;font-size:.78rem;text-decoration:none;display:inline-flex}.note-card__pdf-link:hover{border-color:var(--accent)}.note-card__actions{border-top:1px solid var(--border);align-items:center;gap:.5rem;margin-top:.5rem;padding-top:.5rem;display:flex}.note-card__action-btn{border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:6px;padding:.3rem .75rem;font-size:.78rem;transition:all .2s}.note-card__action-btn--resolve{color:#10b981;border-color:#10b981}.note-card__action-btn--resolve:hover{background:#10b9811a}.note-card__action-btn--reopen{color:#f59e0b;border-color:#f59e0b}.note-card__action-btn--reopen:hover{background:#f59e0b1a}.note-card__action-btn--delete{color:var(--danger,#ef4444);border-color:#0000;margin-left:auto}.note-card__action-btn--delete:hover{background:#ef44441a}.note-card__resolved-by{color:var(--text-muted);font-size:.72rem}.project-card__note-badge{color:#f59e0b;background:#f59e0b26;border-radius:20px;align-items:center;gap:.25rem;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}@media (max-width:640px){.notes-page{padding:1rem}.notes-page__stats{flex-direction:row;gap:.5rem}.notes-form__options{flex-direction:column;align-items:stretch}.notes-form__submit{margin-left:0}.notes-page__filters{flex-direction:column;gap:.5rem}.note-card__header{flex-direction:column}}.topbar__note-bell{width:34px;height:34px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:relative}.topbar__note-bell:hover{background:var(--bg-secondary);color:var(--text-primary)}.topbar__note-badge{text-align:center;color:#fff;background:var(--danger);pointer-events:none;border-radius:999px;min-width:16px;height:16px;padding:0 4px;font-size:.6rem;font-weight:700;line-height:16px;animation:.35s ease-out bellPulse;position:absolute;top:2px;right:1px}@keyframes bellPulse{0%{opacity:0;transform:scale(.4)}70%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.sidebar__badge{text-align:center;color:#fff;background:var(--danger);border-radius:999px;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:.65rem;font-weight:700;line-height:18px;animation:.35s ease-out bellPulse}.sign-detail__optional{color:#ffffff59;margin-left:6px;font-size:10px;font-weight:400}.sign-detail__preview-area{flex-direction:column;gap:6px;display:flex}.sign-detail__preview-thumb{object-fit:contain;background:#0003;border:1px solid #ffffff14;border-radius:6px;width:100%;max-height:140px}.sign-detail__preview-actions{gap:6px;display:flex}.sign-detail__preview-add{opacity:.6;width:100%;border-style:dashed!important}.sign-detail__preview-add:hover{opacity:1}.sign-detail__design-grid{grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:6px;margin-top:4px;display:grid}.sign-detail__design-thumb-link{border:1px solid #ffffff14;border-radius:6px;transition:border-color .2s;display:block;overflow:hidden}.sign-detail__design-thumb-link:hover{border-color:var(--accent,#3b82f6)}.sign-detail__design-thumb{aspect-ratio:1;object-fit:cover;width:100%;display:block}.sign-detail__paste-zone{outline:none}.sign-detail__paste-zone:focus-within{border-color:var(--accent,#3b82f6)}.sign-detail__paste-hint{color:#ffffff4d;text-align:center;margin-top:4px;font-size:10px;font-style:italic;display:block}.sign-detail__preview-empty{border:1px dashed #ffffff1a;border-radius:6px;flex-direction:column;align-items:center;gap:4px;padding:8px;display:flex}.edit-signcode-panel{background:var(--bg-elevated,#1a1a2e);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:0;max-height:420px;padding:12px;display:flex;overflow-y:auto}.edit-signcode-panel__header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.edit-signcode-panel__title{color:var(--text-primary);margin:0;font-size:.85rem;font-weight:700}.edit-signcode-panel__close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.9rem}.edit-signcode-panel__close:hover{color:var(--text-primary);background:#ffffff0f}.edit-signcode-panel__section{margin-bottom:10px}.edit-signcode-panel__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px;font-size:10px;font-weight:600;display:block}.edit-signcode-panel__readonly{color:var(--text-secondary);font-size:.82rem;font-weight:600;font-family:var(--font-mono,monospace);padding:4px 0}.edit-signcode-panel__color-groups{flex-wrap:wrap;gap:3px;margin-bottom:6px;display:flex}.edit-signcode-panel__group-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:2px 7px;font-size:10px;transition:all .15s}.edit-signcode-panel__group-btn:hover{border-color:var(--accent);color:var(--text-primary)}.edit-signcode-panel__group-btn--active{border-color:var(--accent);background:rgba(var(--accent-rgb,99,102,241),.12);color:var(--accent)}.edit-signcode-panel__color-grid{flex-wrap:wrap;gap:4px;display:flex}.edit-signcode-panel__color-swatch{cursor:pointer;border:2px solid #0000;border-radius:4px;width:20px;height:20px;transition:border-color .15s,transform .1s}.edit-signcode-panel__color-swatch:hover{transform:scale(1.15)}.edit-signcode-panel__color-swatch--active{box-shadow:0 0 0 1px var(--accent);border-color:#fff}.edit-signcode-panel__error{color:var(--danger,#ef4444);margin-bottom:8px;font-size:.78rem}.edit-signcode-panel__actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding-top:8px;display:flex}.edit-signcode-panel .input{padding:5px 8px;font-size:.82rem}.placed-signs-panel__edit{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;padding:0 3px;font-size:1rem;line-height:1;transition:opacity .15s,color .15s}.placed-signs-panel__item:hover .placed-signs-panel__edit{opacity:1}.placed-signs-panel__edit:hover{color:var(--accent,#3b82f6)}.do-section{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;padding:24px}.do-section--muted{background:#ffffff05;border-color:#ffffff0f}.do-section__title{color:var(--text-primary);margin:0 0 4px;font-size:1.1rem;font-weight:600}.do-section__desc{color:var(--text-secondary);margin:0 0 20px;font-size:.82rem}.do-subsection__title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin:0 0 12px;font-size:.88rem;font-weight:600}.do-card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.do-option-card{border:1.5px solid var(--border);background:var(--surface-2,#ffffff08);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.do-option-card:hover{background:#4a6fa50f;border-color:#4a6fa566}.do-option-card--active{background:#4a8be51a;border-color:#4a8be5;box-shadow:0 0 0 2px #4a8be526}.do-option-card__icon{font-size:1.6rem;line-height:1}.do-option-card__label{color:var(--text-primary);font-size:.85rem;font-weight:600}.do-option-card__desc{color:var(--text-secondary);font-size:.72rem;line-height:1.3}.do-collapse-toggle{cursor:pointer;width:100%;color:var(--text-primary);background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;font-size:1rem;font-weight:600;display:flex}.do-collapse-arrow{color:var(--text-secondary);font-size:.7rem;transition:transform .15s}.do-customize-panel{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.do-form-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.do-form-group{gap:var(--space-xs);flex-direction:column;display:flex}.do-label{font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.do-hint{font-size:var(--text-caption-size);color:var(--text-muted);margin-top:2px}.do-actions{gap:var(--space-md);display:flex}.do-floor-list{gap:var(--space-sm);flex-direction:column;display:flex}.do-floor-item{padding:var(--space-sm)var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);justify-content:space-between;align-items:center;display:flex}.do-floor-info{flex-direction:column;gap:2px;display:flex}.do-floor-name{color:var(--text-primary);font-weight:500}.do-floor-meta{font-size:var(--text-label-size);color:var(--text-secondary)}.do-save-template-row{gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.do-template-list{gap:var(--space-sm);flex-direction:column;display:flex}.do-template-item{padding:var(--space-sm)var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);justify-content:space-between;align-items:center;display:flex}.do-template-info{flex-direction:column;gap:2px;display:flex}.do-template-name{font-weight:500;font-size:var(--text-body-size);color:var(--text-primary)}.do-template-meta{font-size:var(--text-caption-size);color:var(--text-secondary);font-family:var(--font-mono)}.do-template-actions{gap:var(--space-xs);align-items:center;display:flex}.do-config-summary{gap:var(--space-md);font-size:var(--text-small-size);color:var(--text-secondary);flex-wrap:wrap;display:flex}.admin-dashboard{max-width:1200px;margin:0 auto}.admin-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.admin-title{font-size:var(--text-page-title-size);font-weight:var(--text-page-title-weight);line-height:var(--text-page-title-lh);color:var(--text-primary);align-items:center;gap:var(--space-sm);display:flex}.admin-env-badge{font-size:var(--text-caption-size);color:var(--warning);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;background:#f59e0b1f;padding:2px 8px;font-weight:500}.admin-subtitle{font-size:var(--text-body-size);color:var(--text-muted);margin-top:var(--space-xs)}.admin-kpi-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.admin-kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md)var(--space-lg);box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast)}.admin-kpi-card:hover{border-color:var(--border-subtle)}.admin-kpi-card--accent{border-left:3px solid var(--accent)}.admin-kpi-card--revenue{border-left:3px solid var(--success)}.admin-kpi-label{font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-xs)}.admin-kpi-value{font-size:var(--text-stat-size);font-weight:var(--text-stat-weight);line-height:var(--text-stat-lh);color:var(--text-primary)}.admin-section-tabs{margin-bottom:var(--space-lg);border-bottom:1px solid var(--border-subtle);-webkit-overflow-scrolling:touch;gap:2px;display:flex;overflow-x:auto}.admin-tab{padding:var(--space-sm)var(--space-md);font-size:var(--text-body-size);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-weight:500;font-family:var(--font-primary);background:0 0;border:none;border-bottom:2px solid #0000}.admin-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.admin-tab--active{color:var(--text-primary);border-bottom-color:var(--accent)}.admin-search-bar{margin-bottom:var(--space-md);position:relative}.admin-search-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;max-width:400px;padding:var(--space-xs)var(--space-md);font-family:var(--font-primary);font-size:var(--text-body-size);color:var(--text-primary);height:var(--btn-height);transition:border-color var(--transition-fast);display:block}.admin-search-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #aec3b02e}.admin-search-input::placeholder{color:var(--text-muted)}.admin-search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:14px;position:absolute;top:50%;right:calc(100% - 392px);transform:translateY(-50%)}.admin-section{animation:.2s admin-fade-in}@keyframes admin-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.admin-grid-2{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));display:grid}.admin-grid-3{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.admin-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.admin-card-title{font-size:var(--text-section-title-size);font-weight:var(--text-section-title-weight);color:var(--text-primary);margin-bottom:var(--space-md)}.admin-card-title-row{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.admin-card-title-row .admin-card-title{margin-bottom:0}.admin-bar-chart{gap:var(--space-sm);flex-direction:column;display:flex}.admin-bar-row{gap:var(--space-sm);grid-template-columns:100px 1fr 40px;align-items:center;display:grid}.admin-bar-label{font-size:var(--text-label-size);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:6px;display:flex;overflow:hidden}.admin-bar-track{background:var(--bg-elevated);border-radius:var(--radius-sm);height:20px;overflow:hidden}.admin-bar-fill{background:var(--accent);border-radius:var(--radius-sm);min-width:2px;height:100%;transition:width .4s}.admin-bar-value{font-size:var(--text-label-size);color:var(--text-primary);text-align:right;font-weight:600}.admin-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px;display:inline-block}.admin-stat-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));display:grid}.admin-stat-item{padding:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-elevated)}.admin-stat-item--highlight{background:var(--accent-subtle);border:1px solid #aec3b033}.admin-stat-label{font-size:var(--text-caption-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:4px;margin-bottom:2px;display:flex}.admin-stat-value{font-size:var(--text-section-title-size);color:var(--text-primary);font-weight:600}.admin-sparkline{height:80px;padding-top:var(--space-sm);align-items:flex-end;gap:3px;display:flex;overflow-x:auto}.admin-spark-bar-container{flex-direction:column;flex:1;align-items:center;gap:2px;min-width:24px;display:flex}.admin-spark-bar{background:var(--accent);opacity:.8;border-radius:2px 2px 0 0;width:100%;max-width:28px;min-height:2px;transition:height .3s}.admin-spark-bar-container:hover .admin-spark-bar{opacity:1}.admin-spark-label{color:var(--text-muted);white-space:nowrap;font-size:9px}.admin-table-wrapper{border-radius:var(--radius-sm);max-height:600px;overflow:auto}.admin-table{border-collapse:collapse;width:100%;font-size:var(--text-small-size)}.admin-table th{text-align:left;font-size:var(--text-caption-size);font-weight:var(--text-label-weight);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:var(--space-xs)var(--space-sm);border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:1;position:sticky;top:0}.admin-table td{padding:var(--space-xs)var(--space-sm);border-bottom:1px solid var(--border-subtle);color:var(--text-primary);vertical-align:middle;white-space:nowrap}.admin-table tr:hover td{background:var(--bg-elevated)}.admin-td-email{text-overflow:ellipsis;max-width:200px;overflow:hidden}.admin-td-mono{font-family:var(--font-mono);font-size:var(--text-caption-size);color:var(--text-secondary)}.admin-td-date{font-size:var(--text-caption-size);color:var(--text-muted);white-space:nowrap}.admin-td-message{text-overflow:ellipsis;white-space:nowrap;max-width:280px;font-size:var(--text-caption-size);color:var(--text-secondary);overflow:hidden}.admin-badge{font-size:var(--text-caption-size);color:var(--text-secondary);background:var(--bg-elevated);border-radius:var(--radius-full);text-transform:capitalize;padding:1px 8px;font-weight:500;display:inline-block}.admin-badge--event{font-family:var(--font-mono);letter-spacing:-.02em;font-size:10px}.admin-tier-badge{font-size:var(--text-caption-size);color:var(--tier-color,var(--text-secondary));background:color-mix(in srgb,var(--tier-color,var(--bg-elevated))15%,transparent);border-radius:var(--radius-full);text-transform:capitalize;padding:1px 8px;font-weight:600;display:inline-block}.admin-status-badge{font-size:var(--text-caption-size);border-radius:var(--radius-full);text-transform:capitalize;padding:1px 8px;font-weight:500;display:inline-block}.admin-status-badge--active{color:var(--success);background:var(--success-subtle)}.admin-status-badge--warning{color:var(--warning);background:#f59e0b1f}.admin-status-badge--default{color:var(--text-muted);background:var(--bg-elevated)}.admin-mini-table{flex-direction:column;gap:1px;display:flex}.admin-mini-row{padding:var(--space-xs)0;border-bottom:1px solid var(--border-subtle);font-size:var(--text-small-size);color:var(--text-secondary);justify-content:space-between;align-items:center;display:flex}.admin-mini-row:last-child{border-bottom:none}.admin-empty-text{font-size:var(--text-body-size);color:var(--text-muted);text-align:center;padding:var(--space-lg)0}@media (max-width:768px){.admin-kpi-grid{grid-template-columns:repeat(2,1fr)}.admin-grid-2,.admin-grid-3{grid-template-columns:1fr}.admin-bar-row{grid-template-columns:80px 1fr 36px}.admin-header{flex-direction:column}}.admin-period-selector{gap:var(--space-xs);margin-bottom:var(--space-lg);display:flex}.admin-period-btn{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-secondary);font-size:var(--text-small-size);cursor:pointer;font-weight:500;transition:all .15s}.admin-period-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.admin-period-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-delta{border-radius:var(--radius-sm);align-items:center;gap:4px;margin-top:4px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.admin-delta--up{color:#10b981;background:#10b9811a}.admin-delta--down{color:#ef4444;background:#ef44441a}.admin-delta--neutral{color:var(--text-tertiary);background:0 0}.admin-trend-chart{flex-direction:column;gap:6px;display:flex}.admin-trend-row{align-items:center;gap:var(--space-sm);grid-template-columns:80px 1fr 40px;display:grid}.admin-trend-label{color:var(--text-tertiary);font-size:11px;font-family:var(--font-mono,monospace);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.admin-trend-bar-track{background:var(--bg-elevated);border-radius:var(--radius-xs);height:16px;overflow:hidden}.admin-trend-bar-fill{border-radius:var(--radius-xs);min-width:2px;height:100%;transition:width .3s}.admin-trend-val{color:var(--text-primary);text-align:right;font-size:12px;font-weight:600}.admin-funnel{gap:var(--space-md);flex-direction:column;display:flex}.admin-funnel-step{flex-direction:column;gap:4px;display:flex}.admin-funnel-label{font-size:var(--text-small-size);color:var(--text-primary);justify-content:space-between;align-items:center;font-weight:500;display:flex}.admin-funnel-count{color:var(--text-tertiary);font-size:12px;font-weight:600}.admin-funnel-bar-track{background:var(--bg-elevated);border-radius:var(--radius-sm);height:24px;overflow:hidden}.admin-funnel-bar-fill{border-radius:var(--radius-sm);min-width:4px;height:100%;transition:width .4s}.admin-seo-checklist{gap:var(--space-sm);flex-direction:column;display:flex}.admin-seo-item{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-sm);background:var(--bg-elevated);border-left:3px solid var(--border-color)}.admin-seo-item--high{border-left-color:#ef4444}.admin-seo-item--medium{border-left-color:#f59e0b}.admin-seo-item--low{border-left-color:#10b981}.admin-seo-check{align-items:center;gap:var(--space-sm);font-size:var(--text-small-size);display:flex}.admin-seo-priority{font-size:14px}.admin-seo-tip{color:var(--text-tertiary);margin:4px 0 0 26px;font-size:12px;line-height:1.4}.admin-empty{color:var(--text-tertiary);font-size:var(--text-small-size);font-style:italic}.admin-status-badge--danger{color:#ef4444;background:#ef44441a}@media (max-width:768px){.admin-trend-row{grid-template-columns:60px 1fr 32px}}
