@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap&subset=latin,latin-ext";:root{--bg-main: #EEF2F8;--bg-surface: #FFFFFF;--bg-panel: #FFFFFF;--bg-muted: #F5F7FB;--bg-canvas: #E4EAF3;--border: #E3E8F0;--border-strong: #C9D2E0;--text-primary: #0B2240;--text-secondary: #5A6B83;--text-muted: #8A97AC;--accent: #1E4B94;--accent-hover: #163F80;--accent-strong: #102E63;--accent-soft: rgba(30, 75, 148, .1);--accent-softer: rgba(30, 75, 148, .05);--accent-contrast: #FFFFFF;--brand-red: #E13237;--brand-red-hover: #C92128;--brand-red-soft: rgba(225, 50, 55, .1);--success: #2EA373;--warning: #F2994A;--danger: #E13237;--shadow-xs: 0 1px 2px rgba(11, 34, 64, .04);--shadow-sm: 0 2px 8px rgba(11, 34, 64, .06), 0 1px 2px rgba(11, 34, 64, .03);--shadow-md: 0 8px 20px rgba(11, 34, 64, .08), 0 2px 4px rgba(11, 34, 64, .04);--shadow-lg: 0 20px 40px rgba(11, 34, 64, .12), 0 4px 10px rgba(11, 34, 64, .06);--shadow-focus: 0 0 0 3px rgba(30, 75, 148, .18);--radius-xs: 4px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-pill: 999px;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;color-scheme:light}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{background:var(--bg-main);color:var(--text-primary);font-feature-settings:"cv11","ss01";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font:inherit;color:inherit}::selection{background:var(--accent-soft);color:var(--accent)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#c9d2e0;border:2px solid transparent;background-clip:padding-box;border-radius:999px}*::-webkit-scrollbar-thumb:hover{background:#a7b3c6;background-clip:padding-box}.editor-shell{height:100%;display:grid;grid-template-rows:auto 1fr;background:var(--bg-main);color:var(--text-primary)}.editor-shell--intro{grid-template-rows:1fr}.top-bar{background:var(--bg-surface);box-shadow:var(--shadow-sm);display:flex;align-items:stretch;padding:0 16px 0 20px;gap:12px;box-sizing:border-box;position:relative;z-index:10;min-width:0;max-width:100%}.top-bar__brand{display:flex;align-items:center;flex-shrink:0;padding:12px 4px 12px 0}.top-bar__brand-btn{display:flex;align-items:center;background:none;border:none;padding:0;cursor:pointer;border-radius:var(--radius-md);transition:opacity .15s}.top-bar__brand-btn:hover{opacity:.75}.top-bar__brand-logo{height:28px;width:auto;display:block;-webkit-user-select:none;user-select:none}.top-bar__left{display:flex;align-items:center;gap:12px;flex:1 1 auto;min-width:0;padding:12px 0}.top-bar__center{display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:12px 0}.top-bar__name{flex:1 1 auto;min-width:0;max-width:min(420px,40vw)}.top-bar__name-label{display:block;width:100%;background:transparent;border:0;color:var(--text-primary);font:inherit;font-size:15px;font-weight:700;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);transition:background .12s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.top-bar__name-label:hover:not(:disabled){background:var(--bg-muted)}.top-bar__name-label:disabled{color:var(--text-muted);cursor:default}.top-bar__name-edit{display:flex;align-items:center;gap:4px;min-width:0}.top-bar__name-input{flex:1 1 auto;min-width:0;background:var(--bg-surface);border:1px solid var(--accent);box-shadow:var(--shadow-focus);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-primary);font:inherit;font-size:14px;font-weight:600;outline:none}.top-bar__name-btn{width:32px;height:32px;flex-shrink:0;display:grid;place-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all .12s}.top-bar__name-btn--ok:hover{border-color:#1f7a4f;color:#1f7a4f;background:#1f7a4f14}.top-bar__name-btn--cancel:hover{border-color:var(--danger);color:var(--danger);background:var(--brand-red-soft)}.top-bar__actions{display:flex;gap:8px;align-items:center;flex:0 0 auto;margin-left:auto;min-width:0}.top-bar__actions--user{padding:18px 0 18px 4px}.top-bar__login{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:7px 14px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}.top-bar__login svg{color:var(--text-muted);transition:color .12s}.top-bar__login:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.top-bar__login:hover svg{color:var(--accent)}.top-bar__admin-link{display:inline-flex;align-items:center;padding:8px 14px;border-radius:var(--radius-pill);border:1.5px solid var(--border-strong);background:var(--bg-muted);color:var(--text-primary);font-size:13px;font-weight:600;text-decoration:none;box-shadow:var(--shadow-xs);transition:border-color .12s,color .12s,background .12s,box-shadow .12s}.top-bar__admin-link:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);box-shadow:var(--shadow-sm)}.top-bar__history{display:flex;gap:4px;flex-shrink:0}.top-bar__icon-btn{width:36px;height:36px;display:grid;place-items:center;background:transparent;border:1px solid transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all .12s}.top-bar__icon-btn svg{display:block}.top-bar__icon-btn:hover:not(:disabled){background:var(--accent-soft);color:var(--accent)}.top-bar__icon-btn:disabled{opacity:.35;cursor:default}.editor{position:relative;display:grid;grid-template-rows:1fr auto;min-height:0;overflow:hidden;padding:14px;gap:14px}.editor-blocking-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:35;display:flex;align-items:center;justify-content:center;background:#0b22406b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);pointer-events:all;border-radius:var(--radius-lg)}.editor-blocking-overlay__card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:28px 36px;max-width:min(360px,calc(100% - 32px));background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center}.editor-blocking-overlay__spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.editor-blocking-overlay__text{margin:0;font-size:14px;line-height:1.45;color:var(--text-secondary)}.editor-blocking-overlay__dismiss{margin-top:4px;padding:8px 18px;border:1px solid var(--border-strong);border-radius:var(--radius-pill);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s}.editor-blocking-overlay__dismiss:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.editor__intro{display:grid;grid-template-rows:1fr;overflow:hidden;padding:0}.editor:has(.editor__intro){padding:0;gap:0}.editor__layout{display:grid;grid-template-columns:240px 1fr 272px;gap:14px;min-height:0;overflow:hidden}.editor__left{display:flex;flex-direction:column;min-height:0;gap:14px;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain}.editor__left .views-panel,.editor__left .tools-panel{flex:0 0 auto}.editor__center{display:flex;flex-direction:column;min-height:0;min-width:0;background:var(--bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.editor__context-bar{background:var(--bg-muted);border-bottom:1px solid var(--border);padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:12px}.editor__context-text{flex:1;min-width:0;line-height:1.35}.editor__render-model-toggle{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.editor__render-model-toggle input{cursor:pointer;margin:0}.editor__context-preview-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border:none;border-radius:var(--radius-sm);background:linear-gradient(180deg,#4a7fc4,#3568a8);color:#fff;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-sm),0 1px #ffffff1f inset;transition:background .15s,transform .12s,box-shadow .15s}.editor__context-preview-btn:hover:not(:disabled){background:linear-gradient(180deg,#5a8fd4,#4578b8);box-shadow:var(--shadow-md),0 1px #ffffff26 inset;transform:translateY(-1px)}.editor__context-preview-btn:active:not(:disabled){transform:translateY(0)}.editor__context-preview-btn:disabled{opacity:.5;cursor:default;box-shadow:none;transform:none}.editor__context-preview-btn-icon{flex-shrink:0;opacity:.95}.intro{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg-surface);position:relative;overflow-y:auto}.intro--drag{outline:3px solid var(--accent);outline-offset:-3px;background:var(--accent-softer)}.intro__nav{position:sticky;top:0;z-index:10;display:flex;align-items:stretch;gap:12px;padding:0 16px 0 20px;height:auto;min-width:0;max-width:100%;background:var(--bg-surface);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.intro__nav-brand{display:flex;align-items:center;flex-shrink:0;padding:12px 4px 12px 0;-webkit-user-select:none;user-select:none}.intro__nav-logo{height:28px;width:auto;display:block;-webkit-user-select:none;user-select:none}.intro__nav-left{display:flex;align-items:center;gap:12px;flex:1 1 auto;min-width:0;padding:12px 0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.intro__nav-left::-webkit-scrollbar{display:none}.intro__nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:12px 0}.intro__login-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:7px 16px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s}.intro__login-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.intro__hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:60px 24px 72px}.intro__hero-logo{height:104px;width:auto;max-width:min(520px,85vw);display:block;-webkit-user-select:none;user-select:none}.intro__headline{margin:0;font-size:clamp(19px,2.5vw,26px);font-weight:700;letter-spacing:-.02em;color:var(--text-primary);text-align:center;line-height:1.05}.intro__sub{margin:0;font-size:16px;color:var(--text-secondary);line-height:1.6;text-align:center;max-width:440px}.intro__drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;max-width:460px;min-height:180px;border:1.5px dashed var(--border-strong);border-radius:var(--radius-xl);padding:32px 24px;cursor:pointer;transition:all .15s;background:var(--bg-muted)}.intro__drop:hover,.intro--drag .intro__drop{border-color:var(--accent);background:var(--accent-softer)}.intro__drop--loading{pointer-events:none;opacity:.75}.intro__drop-icon{color:var(--accent);opacity:.7}.intro__drop-primary{font-size:16px;font-weight:600;color:var(--text-primary)}.intro__drop-sub{font-size:13px;color:var(--text-muted)}.intro__spinner{display:block;width:32px;height:32px;border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:intro-spin .7s linear infinite}@keyframes intro-spin{to{transform:rotate(360deg)}}.intro__error{margin:0;font-size:13.5px;color:var(--danger);background:var(--brand-red-soft);padding:10px 16px;border-radius:var(--radius-md);max-width:460px;text-align:center}.intro__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.intro__action-btn{display:inline-flex;align-items:center;gap:8px;background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text-secondary);padding:10px 20px;border-radius:var(--radius-pill);font-size:13.5px;font-weight:600;cursor:pointer;transition:all .12s}.intro__action-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.intro__action-btn:disabled{opacity:.45;cursor:default}.projects-menu{position:relative;flex-shrink:0}.projects-menu__trigger{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:7px 14px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}.projects-menu__trigger:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.projects-menu__trigger:disabled{opacity:.6;cursor:wait}.projects-menu__chev{opacity:.7}.projects-menu__panel{position:absolute;top:calc(100% + 8px);left:0;z-index:40;width:min(320px,80vw);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:8px}.projects-menu__action{width:100%;display:flex;align-items:center;gap:10px;text-align:left;background:transparent;border:0;border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:background .12s}.projects-menu__action:hover:not(:disabled){background:var(--bg-muted)}.projects-menu__action:disabled{opacity:.45;cursor:default}.projects-menu__section-label{padding:8px 12px 4px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.projects-menu__divider{height:1px;background:var(--border);margin:6px 4px}.projects-menu__empty{margin:0;padding:8px 12px;font-size:12px;color:var(--text-secondary)}.projects-menu__list{list-style:none;margin:0;padding:0 4px;max-height:220px;overflow:auto;display:flex;flex-direction:column;gap:2px}.projects-menu__item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;background:transparent;border:0;border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;transition:background .12s}.projects-menu__item:hover:not(:disabled){background:var(--bg-muted)}.projects-menu__item--active{background:var(--accent-softer)}.projects-menu__item-name{font-size:13px;font-weight:600;color:var(--text-primary)}.projects-menu__item-date{font-size:11px;color:var(--text-muted);flex-shrink:0}.top-bar__projects-menu{flex-shrink:0}.top-bar__viz-btn{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:7px 14px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}.top-bar__viz-btn svg{display:block;flex-shrink:0}.top-bar__viz-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.top-bar__viz-btn:disabled{opacity:.55;cursor:default}.top-bar__viz-count{min-width:18px;padding:1px 6px;border-radius:var(--radius-pill);background:var(--accent-soft);color:var(--accent);font-size:10px;font-weight:700;font-variant-numeric:tabular-nums;text-align:center}.top-bar__viz-btn:disabled .top-bar__viz-count{background:var(--bg-muted);color:var(--text-muted)}.my-projects-menu{position:relative}.my-projects-menu__trigger{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:7px 14px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}.my-projects-menu__trigger:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.my-projects-menu__trigger:disabled{opacity:.6;cursor:wait}.my-projects-menu__panel{position:absolute;top:calc(100% + 8px);right:0;z-index:30;width:min(320px,80vw);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:8px}.my-projects-menu__empty{margin:0;padding:10px 12px;font-size:13px;color:var(--text-secondary)}.my-projects-menu__list{list-style:none;margin:0;padding:0;max-height:280px;overflow:auto;display:flex;flex-direction:column;gap:4px}.my-projects-menu__item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;background:transparent;border:0;border-radius:var(--radius-sm);padding:9px 10px;cursor:pointer;transition:background .12s}.my-projects-menu__item:hover:not(:disabled){background:var(--bg-muted)}.my-projects-menu__item--active{background:var(--accent-softer)}.my-projects-menu__item-name{font-size:13px;font-weight:600;color:var(--text-primary)}.my-projects-menu__item-date{font-size:11px;color:var(--text-muted);flex-shrink:0}.intro__my-projects .my-projects-menu__trigger{font-size:12px;padding:7px 14px}.top-bar__cloud{font-size:11px;font-weight:600;padding:6px 10px;border-radius:var(--radius-pill);white-space:nowrap}.top-bar__cloud--saving{color:var(--text-secondary);background:var(--bg-muted)}.top-bar__cloud--saved{color:#1f7a4f;background:#1f7a4f1a}.top-bar__cloud--error{color:#b42318;background:#b4231814}.intro__cloud{width:min(720px,100%);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:16px 18px;margin-top:4px}.intro__cloud-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.intro__cloud-title{margin:0;font-size:14px;font-weight:700}.intro__cloud-hint{margin:4px 0 0;font-size:12px;color:var(--text-muted)}.intro__cloud-loading,.intro__cloud-empty{margin:0;font-size:13px;color:var(--text-secondary)}.intro__cloud-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;max-height:320px;overflow:auto}.intro__cloud-card{width:100%;display:flex;flex-direction:column;align-items:stretch;text-align:left;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;overflow:hidden;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .12s}.intro__cloud-card:hover:not(:disabled){border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.intro__cloud-card:disabled{opacity:.6;cursor:wait}.intro__cloud-thumb{position:relative;aspect-ratio:4 / 3;background:var(--bg-canvas);overflow:hidden}.intro__cloud-thumb img{width:100%;height:100%;object-fit:cover;display:block}.intro__cloud-thumb-empty{width:100%;height:100%;display:grid;place-items:center;color:var(--text-muted)}.intro__cloud-views-badge{position:absolute;right:6px;bottom:6px;font-size:10px;font-weight:700;color:#fff;background:#0b2240b8;padding:2px 7px;border-radius:var(--radius-pill)}.intro__cloud-item-name{display:block;font-size:13px;font-weight:600;color:var(--text-primary);padding:8px 10px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.intro__cloud-item-date{display:block;font-size:11px;color:var(--text-muted);padding:2px 10px 10px}.intro__samples{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:460px}.intro__samples-label{font-size:12px;font-weight:500;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.intro__sample-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.intro__sample-chip{background:var(--bg-muted);border:1px solid var(--border);color:var(--text-secondary);padding:7px 16px;border-radius:var(--radius-pill);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s}.intro__sample-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.intro__sample-chip:disabled{opacity:.45;cursor:default}.intro-screen{display:none}.intro-screen__title{margin:0;font-size:30px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.intro-screen__subtitle{margin:0;color:var(--text-secondary);font-size:15px;line-height:1.5}.intro-screen__url-row{display:flex;gap:10px;align-items:stretch}.intro-screen__url-row input{flex:1}.intro-screen__samples{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.step-screen__input{padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--bg-surface);color:var(--text-primary);font-size:14px;outline:none;transition:all .12s}.step-screen__input::placeholder{color:var(--text-muted)}.step-screen__input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus)}.step-screen__btn{background:var(--accent);color:#fff;border:0;border-radius:var(--radius-md);padding:12px 22px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;text-align:center;transition:background .12s,transform .12s,box-shadow .12s;box-shadow:var(--shadow-xs)}.step-screen__btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-sm)}.step-screen__btn:active:not(:disabled){transform:translateY(1px)}.step-screen__btn:disabled{opacity:.45;cursor:default}.step-screen__btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-pill);padding:8px 18px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s}.step-screen__btn-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.step-screen__error{color:var(--danger);margin:0;font-size:14px;padding:10px 14px;background:var(--brand-red-soft);border-radius:var(--radius-sm)}.drop-zone{width:100%;min-height:220px;border:2px dashed var(--border-strong);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-secondary);background:var(--bg-muted);transition:all .16s;padding:24px}.drop-zone.is-over{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.drop-zone__primary{font-size:16px;color:var(--text-primary);font-weight:500}.drop-zone__or{font-size:13px;color:var(--text-muted)}.drop-zone__label{cursor:pointer}.views-panel,.tools-panel,.surfaces-panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;min-height:0}.views-panel__header{display:flex;align-items:center;gap:8px;padding:14px 16px 10px}.views-panel__header h3{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);flex:1;font-weight:600}.views-panel__add{width:28px;height:28px;border-radius:8px;border:0;background:var(--accent);color:#fff;font-size:18px;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-xs);transition:all .12s}.views-panel__add:hover{background:var(--accent-hover);box-shadow:var(--shadow-sm)}.views-panel__list{padding:4px 10px 10px;display:flex;flex-direction:column;gap:4px}.views-panel__empty{text-align:center;color:var(--text-muted);font-size:12px;padding:24px 12px;margin:0}.view-item{display:grid;grid-template-columns:56px 1fr auto;gap:10px;align-items:center;padding:8px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;position:relative;transition:background .12s,border-color .12s}.view-item:hover{background:var(--bg-muted)}.view-item.is-active{border-color:var(--accent);background:var(--accent-soft)}.view-item__thumb{width:56px;height:44px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-muted);display:grid;place-items:center;box-shadow:var(--shadow-xs)}.view-item__thumb img{width:100%;height:100%;object-fit:cover}.view-item__body{min-width:0;overflow:hidden}.view-item__name{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view-item__meta{font-size:11px;color:var(--text-muted);margin-top:2px}.view-item__del{background:none;border:0;color:var(--text-muted);cursor:pointer;padding:4px;line-height:0;border-radius:6px;transition:all .12s}.view-item__del:hover{color:var(--danger);background:var(--brand-red-soft)}.view-item__del svg{display:block}.canvas-stage{position:relative;flex:1;overflow:hidden;min-height:0;background:linear-gradient(180deg,#eef3fa,#dfe6f1)}.canvas-stage__bitmap{position:absolute;top:0;left:0;image-rendering:auto;-webkit-user-select:none;user-select:none;pointer-events:none;box-shadow:var(--shadow-md)}.canvas-stage__soften-overlay{position:absolute;top:0;left:0;pointer-events:none;-webkit-user-select:none;user-select:none}.canvas-stage__svg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:auto}.canvas-stage__svg polygon,.canvas-stage__svg path{fill:#1e4b9424;stroke:var(--accent);stroke-width:2;pointer-events:none}.canvas-stage__svg polygon.surface-outer{fill:none}.canvas-stage__svg path.surface-fill{stroke:none}.canvas-stage__svg polygon.surface-outer.is-inactive,.canvas-stage__svg path.surface-fill.is-inactive{stroke:#1e4b948c;fill:#1e4b940f}.canvas-stage__svg polygon.surface-outer.is-active{stroke:var(--accent);stroke-width:2.5;filter:drop-shadow(0 0 6px rgba(30,75,148,.35))}.canvas-stage__svg path.surface-fill.is-active{fill:#1e4b942e;stroke:none}.canvas-stage__svg polygon.surface-outer.is-hole-cutting{fill:none;fill-opacity:0;stroke:var(--accent);stroke-width:2.5}.canvas-stage__svg polygon.surface-outer.is-draft{stroke:var(--accent);stroke-dasharray:4 3}.canvas-stage__svg polyline{fill:none;stroke:var(--accent);stroke-width:2;pointer-events:none}.canvas-stage__svg polygon.is-hole,.canvas-stage__svg polyline.is-hole{fill:none;fill-opacity:0;stroke:var(--brand-red);stroke-dasharray:6 5}.canvas-stage__svg circle.canvas-stage__spray-dab{fill:#50c8782e;stroke:#50c8788c;stroke-width:1;pointer-events:none}.canvas-stage__svg circle.canvas-stage__spray-cursor{fill:#00eb5824;stroke:#00d24bc7;stroke-width:1.5;stroke-dasharray:4 3;pointer-events:none}.canvas-stage__svg circle.canvas-stage__spray-cursor--eraser{fill:#e132371a;stroke:#c8282deb;stroke-dasharray:5 4}.canvas-stage__draw-cursor{pointer-events:none}.canvas-stage__draw-cursor__ring{fill:none;stroke:#ffffffe6;stroke-width:1.5;filter:drop-shadow(0 0 1.5px rgba(0,0,0,.65))}.canvas-stage__draw-cursor__cross{stroke:#ffffffe6;stroke-width:1.5;filter:drop-shadow(0 0 1.5px rgba(0,0,0,.65))}.canvas-stage__next-edge{stroke:var(--accent);stroke-width:2;stroke-dasharray:8 6;opacity:.9;pointer-events:none}.canvas-stage__next-edge--to-first{opacity:.6}.canvas-stage__next-edge.is-hole-preview{stroke:var(--brand-red)}.canvas-stage__svg circle{fill:#fff;stroke:var(--accent);stroke-width:2;cursor:grab;filter:drop-shadow(0 1px 2px rgba(11,34,64,.25))}.canvas-stage__svg circle.is-inactive{fill:#fff;stroke:#1e4b94b3}.canvas-stage__svg circle.is-hole-point{fill:#fff;stroke:var(--brand-red)}.canvas-stage__svg circle.is-insert-point{fill:var(--success);stroke:#fff;stroke-width:1.5;pointer-events:none}.canvas-stage__svg circle.is-deletable{cursor:no-drop}.canvas-stage__svg circle.is-deletable:hover{fill:var(--danger);stroke:var(--danger)}.canvas-stage__lasso-trail{fill:#f2994a24;stroke:var(--warning);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}.canvas-stage__lasso-close{stroke:var(--warning);stroke-width:1.5;stroke-dasharray:5 4;opacity:.7;pointer-events:none}.canvas-stage__lasso-anchor{fill:var(--warning);stroke:#fff;stroke-width:1.5;pointer-events:none}.canvas-stage__lasso-trail.is-subtract{fill:#e1323724;stroke:var(--danger)}.canvas-stage__lasso-close.is-subtract{stroke:var(--danger)}.canvas-stage__lasso-anchor.is-subtract{fill:var(--danger)}.canvas-stage__insert-edge{stroke:var(--success);stroke-width:3;stroke-dasharray:6 4;pointer-events:none}.canvas-stage__finish-btn{cursor:pointer}.canvas-stage__finish-btn rect{fill:var(--success);stroke:#fff;stroke-width:1.5}.canvas-stage__finish-btn text{fill:#fff;font-size:12px;font-weight:800;pointer-events:none}.canvas-stage__finish-btn.is-hole-confirm rect{fill:var(--brand-red)}.canvas-stage__svg circle:active{cursor:grabbing}.canvas-stage__badge{position:absolute;top:16px;left:50%;transform:translate(-50%);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);padding:8px 16px;border-radius:var(--radius-pill);font-size:12px;font-weight:500;box-shadow:var(--shadow-sm)}.canvas-stage__badge--error{border-color:var(--danger);color:var(--danger);background:var(--brand-red-soft)}.canvas-stage__badge--hint{border-color:var(--accent);color:var(--accent);background:#1e4b9414}.canvas-stage__hud{position:absolute;bottom:14px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:4px;height:40px;box-sizing:border-box;background:var(--bg-surface);border:1px solid var(--border);padding:0 10px;border-radius:var(--radius-pill);font-size:12px;color:var(--text-secondary);pointer-events:auto;box-shadow:var(--shadow-sm)}.canvas-stage__hud-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:0;color:var(--text-secondary);cursor:pointer;min-width:32px;height:32px;padding:0 6px;border-radius:6px;font-size:16px;line-height:1;transition:all .12s}.canvas-stage__hud-btn--icon{padding:0;min-width:32px}.canvas-stage__hud-confirm{color:var(--accent);font-weight:700;font-size:18px;border:1px solid var(--accent);background:var(--accent-soft)}.canvas-stage__hud-btn:hover{color:var(--accent);background:var(--accent-soft)}.canvas-stage__hud-btn.canvas-stage__hud-confirm:hover{color:#fff;background:var(--accent)}.canvas-stage__hud-zoom{min-width:42px;text-align:center;color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.canvas-stage__hud-hint{margin-left:8px;color:var(--text-muted);border-left:1px solid var(--border);padding-left:10px}.surfaces-panel--empty{padding:24px;color:var(--text-muted);text-align:center;font-size:13px}.surfaces-panel__tabs{display:flex;gap:0;padding:10px 10px 0;border-bottom:1px solid var(--border);flex-shrink:0}.surfaces-panel__tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;background:transparent;color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:10px 8px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,background .12s,border-color .12s}.surfaces-panel__tab:hover{color:var(--text-primary);background:var(--bg-muted)}.surfaces-panel__tab--active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-softer)}.surfaces-panel__count{font-size:10px;font-weight:700;color:var(--accent);background:var(--accent-soft);padding:2px 7px;border-radius:var(--radius-pill);text-transform:none;letter-spacing:0}.surfaces-panel__tab-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.surfaces-panel__tab-panel--combinations{overflow-y:auto;padding:0 10px 12px}.surfaces-panel__list-filter{display:flex;gap:4px;padding:8px 10px 6px;border-bottom:1px solid var(--border)}.surfaces-panel__list-filter-btn{flex:1;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.surfaces-panel__list-filter-btn:hover{background:var(--bg-muted);color:var(--text)}.surfaces-panel__list-filter-btn.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}.surfaces-panel__list-filter-btn.is-active--vyrezy{border-color:var(--brand-red);background:var(--brand-red-soft);color:var(--brand-red)}.surfaces-panel__list-filter-btn.is-active--vyrezy .surfaces-panel__count{background:#e1323729;color:var(--brand-red)}.surfaces-panel__list-filter-btn .surfaces-panel__count{margin-left:6px}.global-hole-points--detail{padding:0;gap:4px}.surfaces-panel__list{max-height:38%;overflow-y:auto;padding:0 10px 8px;display:flex;flex-direction:column;gap:4px}.surfaces-panel__empty{text-align:center;color:var(--text-muted);font-size:12px;padding:18px;margin:0;line-height:1.4}.surface-item{display:grid;grid-template-columns:auto 18px 1fr auto auto;gap:8px;align-items:center;padding:8px 10px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;font-size:13px;transition:background .12s,border-color .12s}.surface-item--hole{grid-template-columns:auto 1fr auto auto}.surface-item:hover{background:var(--bg-muted)}.surface-item.is-active{border-color:var(--accent);background:var(--accent-soft)}.surface-item__vis{background:none;border:0;color:var(--text-muted);cursor:pointer;padding:4px;line-height:0;border-radius:6px;transition:all .12s}.surface-item__vis:hover{color:var(--accent);background:var(--accent-soft)}.surface-item__vis svg{display:block}.surface-item__swatch--empty,.color-current__chip--empty{background:var(--bg-muted, #eef2f6);box-shadow:inset 0 0 0 1px #0b22401f;background-image:repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(11,34,64,.06) 4px,rgba(11,34,64,.06) 8px)}.surface-item__swatch{width:18px;height:18px;border-radius:6px;border:1px solid rgba(11,34,64,.12);box-shadow:inset 0 0 0 1px #fff6}.surface-item__name{flex:1;min-width:0;background:transparent;border:0;color:var(--text-primary);font:inherit;font-size:13px;font-weight:500;outline:none;padding:2px 4px;border-radius:4px}.surface-item__name:focus{background:var(--bg-surface);box-shadow:inset 0 0 0 1px var(--accent)}.surface-item__name--label{cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.surface-item__idx{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}.surface-item__del{background:none;border:0;color:var(--text-muted);line-height:0;cursor:pointer;padding:4px;border-radius:6px;transition:all .12s}.surface-item__del:hover{color:var(--danger);background:var(--brand-red-soft)}.surface-item__del svg{display:block}.global-hole-points{width:100%;padding:4px 8px 6px 32px;display:flex;flex-direction:column;gap:2px}.global-hole-point-row{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:11px;color:var(--text-secondary);padding:2px 4px;border-radius:4px}.global-hole-point-row:hover{background:var(--bg-muted)}.global-hole-point-label{flex:1;min-width:0}.global-hole-point-del{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:11px;padding:2px 4px;border-radius:3px;line-height:1}.global-hole-point-del:hover{color:var(--danger);background:var(--brand-red-soft)}.surfaces-panel__detail{flex:1;overflow-y:auto;border-top:1px solid var(--border);padding:14px 16px;display:flex;flex-direction:column;gap:14px;background:var(--bg-muted)}.surfaces-panel__detail-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.surfaces-panel__detail-meta{margin:-6px 0 0;font-size:12px;color:var(--text-muted)}.surface-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}.surface-action{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-surface);border:1px dashed var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-size:12.5px;font-weight:600;cursor:pointer;text-align:left;transition:all .12s}.surface-action svg{flex-shrink:0}.surface-action__label{flex:1}.surface-action__count{min-width:22px;padding:2px 8px;border-radius:var(--radius-pill);background:#e1323729;color:var(--brand-red);font-size:11px;font-weight:700;text-align:center;font-variant-numeric:tabular-nums}.surface-action--hole:hover{border-style:solid;border-color:var(--brand-red);color:var(--brand-red);background:var(--brand-red-soft)}.surface-action--hole.is-active{border-style:solid;border-color:var(--brand-red);background:var(--brand-red);color:#fff;box-shadow:0 0 0 4px #e132372e}.surface-action--hole.is-active .surface-action__count{background:#ffffff40;color:#fff}.surface-action--remove-hole:hover{border-style:solid;border-color:var(--brand-red);color:var(--brand-red);background:var(--brand-red-soft)}.surface-action--remove-hole.is-active{border-style:solid;border-color:var(--brand-red);background:var(--brand-red);color:#fff;box-shadow:0 0 0 4px #e132372e}.canvas-stage__svg polygon.is-hole.is-hole-removable{fill:#e132371f;pointer-events:auto;cursor:pointer}.canvas-stage__svg polygon.is-global-hole{stroke:var(--brand-red);stroke-width:1.5;stroke-dasharray:6 5;fill:none;pointer-events:none}.canvas-stage__svg polygon.is-global-hole.is-global-hole--selected{stroke-width:2.5;stroke-dasharray:none;filter:drop-shadow(0 0 4px rgba(225,50,55,.45))}.canvas-stage__svg polygon.is-global-hole.is-global-hole--hidden-selected{stroke-dasharray:6 5;opacity:.85}.canvas-stage__svg polygon.is-global-hole.is-global-hole--hidden{stroke:#e1323759;stroke-dasharray:3 5;fill:none}.canvas-stage__svg polygon.is-global-hole.is-global-hole--removable{fill:#e132371f;pointer-events:auto;cursor:pointer}.surface-action--delete:hover{border-style:solid;border-color:var(--warning);color:var(--warning);background:#f2994a1a}.surface-action--delete.is-active{border-style:solid;border-color:var(--warning);background:var(--warning);color:#fff;box-shadow:0 0 0 4px #f2994a38}.surface-action__link{align-self:flex-start;background:none;border:0;color:var(--text-muted);font-size:11px;font-weight:500;cursor:pointer;padding:2px 0;margin:-4px 0 0}.surface-action__link:hover{color:var(--danger);text-decoration:underline}.tools-panel__help-note{padding-top:4px;color:var(--text-secondary);font-style:italic}.surface-slider{display:flex;flex-direction:column;gap:4px}.surface-slider label{display:flex;justify-content:space-between;font-size:12px;font-weight:500;color:var(--text-secondary)}.surface-slider label span:last-child{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.surface-slider input{width:100%;accent-color:var(--accent)}.surface-field{display:flex;flex-direction:column;gap:6px;padding-top:8px;border-top:1px dashed var(--border)}.surface-field label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.surface-field__select{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:8px 10px;font-size:13px;cursor:pointer}.surface-field__select:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus)}.surface-field__hint{margin:2px 0 0;font-size:11px;color:var(--text-muted);line-height:1.4}.color-palette{display:flex;flex-direction:column;gap:10px;padding:10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.color-current{display:grid;grid-template-columns:40px 1fr;gap:10px;align-items:center;padding:8px 10px;background:linear-gradient(135deg,var(--bg-muted) 0%,#ECF1F8 100%);border:1px solid var(--border);border-radius:var(--radius-md)}.color-current__chip{width:40px;height:40px;border-radius:8px;box-shadow:inset 0 0 0 1px #0b22402e,var(--shadow-sm)}.color-current__meta{display:flex;flex-direction:column;gap:2px;min-width:0}.color-current__code{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:10px;font-weight:700;letter-spacing:.05em;color:var(--accent);text-transform:uppercase}.color-current__name{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.25;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.color-current--empty{background:var(--bg-muted, #eef2f6)}.color-current__name--empty{font-weight:600;color:var(--text-secondary)}.color-catalog-picker{display:flex;flex-direction:column;gap:14px}.color-palette__line{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:600;color:var(--text-secondary)}.color-palette__line-heading{display:block}.line-dropdown{position:relative;width:100%}.line-dropdown__trigger{display:flex;align-items:center;gap:8px;width:100%;min-height:40px;padding:6px 10px 6px 12px;font-size:12px;font-weight:600;color:var(--text-primary);background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:border-color .12s}.line-dropdown__trigger:hover{border-color:var(--text-muted)}.line-dropdown__trigger-label{min-width:0;flex:0 1 42%}.line-dropdown__trigger-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;font-size:12px}.line-dropdown__strip{display:flex;flex:1 1 auto;min-width:72px;max-width:48%;height:20px;border-radius:5px;overflow:hidden;gap:1px;background:var(--border);box-shadow:inset 0 0 0 1px #0b22401f}.line-dropdown__strip--trigger{max-width:none;flex:1 1 0}.line-dropdown__chip{flex:1 1 0;min-width:0;height:100%;box-shadow:inset 0 0 0 .5px #0000001f}.line-dropdown__chev{flex:0 0 auto;color:var(--text-muted);display:grid;place-items:center;opacity:.9}.line-dropdown__menu{position:absolute;z-index:30;left:0;right:0;top:calc(100% + 4px);max-height:min(55vh,360px);overflow-y:auto;padding:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.line-dropdown__option{display:flex;flex-direction:column;align-items:stretch;gap:6px;width:100%;padding:8px 10px;margin:0;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font:inherit;text-align:left;cursor:pointer;transition:background .1s}.line-dropdown__option:hover{background:var(--bg-muted)}.line-dropdown__option.is-active{background:color-mix(in srgb,var(--accent) 10%,var(--bg-muted));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent)}.line-dropdown__option-text{display:block;width:100%}.line-dropdown__option-name{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.line-dropdown__option .line-dropdown__strip{max-width:none;width:100%;flex:none}.color-palette__swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.color-palette__swatches--small{grid-template-columns:repeat(10,1fr);gap:4px}.swatch{width:100%;aspect-ratio:1;border-radius:10px;border:0;cursor:pointer;padding:0;display:grid;place-items:center;color:#fff;box-shadow:inset 0 0 0 1px #0b224029,var(--shadow-xs);transition:transform .12s,box-shadow .12s}.swatch:hover{transform:translateY(-1px) scale(1.06);box-shadow:inset 0 0 0 1px #0b22403d,var(--shadow-sm)}.swatch.is-active{transform:scale(1.04);box-shadow:inset 0 0 0 2px #fff,0 0 0 2px var(--accent),var(--shadow-sm)}.swatch.is-in-draft:not(.is-active){box-shadow:inset 0 0 0 2px #fff,0 0 0 2px #2563eb8c,var(--shadow-xs)}.swatch:disabled{opacity:.45;cursor:not-allowed;transform:none}.swatch svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}.swatch--small{border-radius:6px;box-shadow:inset 0 0 0 1px #0b22401f}.swatch--small.is-active{box-shadow:inset 0 0 0 2px #fff,0 0 0 2px var(--accent)}.color-palette__history-label{font-size:10px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;margin-bottom:6px;font-weight:700}.color-combos{display:flex;flex-direction:column;gap:12px;padding:12px 0 4px;border-top:1px solid var(--border);margin-top:8px}.color-combos--tab{border-top:0;margin-top:0;padding-top:12px}.color-combos__title{margin:0;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary)}.color-combos__saved{display:flex;flex-direction:column;gap:8px}.color-combos__empty{margin:0;padding:14px 12px;font-size:11.5px;color:var(--text-muted);line-height:1.5;text-align:center;background:var(--bg-muted);border:1px dashed var(--border);border-radius:var(--radius-md)}.color-combos__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.combo-card{display:grid;grid-template-columns:1fr auto;gap:8px;padding:8px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .12s,box-shadow .12s}.combo-card--expanded{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft, rgba(37, 99, 235, .18))}.combo-card__head{display:flex;align-items:center;gap:8px;min-width:0;padding:0;border:0;background:transparent;cursor:pointer;text-align:left}.combo-card__strip{display:flex;gap:2px;height:26px;width:64px;flex-shrink:0;border-radius:6px;overflow:hidden;box-shadow:inset 0 0 0 1px #0b22401f}.combo-card__name{flex:1;min-width:0;font-size:12.5px;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combo-card__chev{display:flex;color:var(--text-muted);transition:transform .16s}.combo-card--expanded .combo-card__chev{transform:rotate(180deg)}.combo-card__apply{align-self:center;padding:8px 16px;font-size:12px;font-weight:700;border:0;border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:opacity .12s,transform .12s}.combo-card__apply:hover:not(:disabled){transform:translateY(-1px)}.combo-card__apply:disabled{opacity:.4;cursor:not-allowed}.combo-card__detail{grid-column:1 / -1;display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px solid var(--border)}.combo-card__detail-label{margin:0;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.combo-card__detail .combo-builder__slots,.combo-card__detail .combo-builder__hint{margin-bottom:8px}.combo-card__detail-hint{margin:0;font-size:11px;color:var(--text-muted);line-height:1.4}.combo-map{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.combo-map__item{display:flex;flex-direction:column}.combo-map__item--active .combo-map__chev{transform:rotate(180deg)}.combo-map__row{display:flex;align-items:center;gap:6px;font-size:11.5px}.combo-map__row--pickable{width:100%;padding:6px 8px;margin:0;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;cursor:pointer;text-align:left;transition:background .15s ease,border-color .15s ease}.combo-map__row--pickable:hover{background:var(--bg-surface);border-color:var(--border)}.combo-map__row--pickable.combo-map__row--active{background:var(--bg-surface);border-color:var(--accent, #2563eb)}.combo-map__chev{flex-shrink:0;color:var(--text-muted);transition:transform .24s cubic-bezier(.4,0,.2,1)}.combo-map__expand{display:grid;grid-template-rows:0fr;transition:grid-template-rows .24s cubic-bezier(.4,0,.2,1)}.combo-map__item--active .combo-map__expand{grid-template-rows:1fr}.combo-map__expand-inner{overflow:hidden;min-height:0}.combo-map__expand-content{padding:0 4px;opacity:0;transform:translateY(-4px);transition:opacity .2s ease,transform .24s cubic-bezier(.4,0,.2,1),padding .24s cubic-bezier(.4,0,.2,1)}.combo-map__item--active .combo-map__expand-content{padding:6px 4px 8px;opacity:1;transform:translateY(0)}.combo-map__surface{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.combo-map__arrow{color:var(--text-muted);flex-shrink:0}.combo-map__swatch{width:18px;height:18px;flex-shrink:0;border-radius:4px;box-shadow:inset 0 0 0 1px #0b22402e}.combo-map__hex{flex-shrink:0;font-size:10px;font-weight:600;color:var(--text-secondary);min-width:64px;text-align:right}.combo-map__label{flex:1;min-width:0;font-size:12px;font-weight:600;color:var(--text-secondary);line-height:1.35}.combo-card__order-note{margin:0;font-size:10px;line-height:1.4;color:var(--text-muted);font-style:italic}.combo-card__apply-all{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;font-size:11.5px;font-weight:700;border:1px solid var(--accent);border-radius:var(--radius-md);background:var(--accent-soft, rgba(37, 99, 235, .1));color:var(--accent);cursor:pointer;transition:background .12s}.combo-card__apply-all:hover{background:var(--accent);color:#fff}.combo-card__delete{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;padding:5px 8px;font-size:11px;font-weight:600;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer;transition:color .12s,background .12s}.combo-card__delete:hover{color:#c0392b;background:#c0392b14}.color-combos__create{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.color-combos__name{width:100%;padding:8px 10px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary)}.color-combos__name:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #2563eb26}.color-combos__save{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;font-size:12px;font-weight:700;border:none;border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:opacity .12s,transform .12s}.color-combos__save:hover:not(:disabled){transform:translateY(-1px)}.color-combos__save:disabled{opacity:.4;cursor:not-allowed}.color-combos__save-preview{display:flex;gap:2px;height:14px;width:56px;border-radius:4px;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff59}.color-combos__custom-toggle{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 12px;font-size:12px;font-weight:600;border:1px dashed var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:border-color .12s,color .12s}.color-combos__custom-toggle:hover{border-color:var(--accent);color:var(--accent)}.combo-builder{display:flex;flex-direction:column;gap:10px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-panel)}.combo-builder__head{display:flex;align-items:center;justify-content:space-between}.combo-builder__title{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary)}.combo-builder__count{font-size:11px;font-weight:700;color:var(--text-muted)}.combo-builder__slots{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.combo-builder__slot-wrap{position:relative}.combo-builder__slot{aspect-ratio:1;width:100%;border-radius:8px;display:grid;place-items:center;font-size:11px;font-weight:700}.combo-builder__slot--empty{border:1px dashed var(--border);background:var(--bg-muted);color:var(--text-muted)}.combo-builder__slot--filled{border:0;cursor:pointer;color:#fff;box-shadow:inset 0 0 0 1px #0b224033;transition:transform .12s,box-shadow .12s}.combo-builder__slot--filled:hover{transform:scale(1.04)}.combo-builder__slot--active{box-shadow:inset 0 0 0 1px #0b224033,0 0 0 2px var(--accent)}.combo-builder__slot-remove{position:absolute;top:-5px;right:-5px;width:16px;height:16px;padding:0;border:0;border-radius:999px;background:#0b2240d1;color:#fff;font-size:12px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s,background .12s}.combo-builder__slot-wrap:hover .combo-builder__slot-remove,.combo-builder__slot--active+.combo-builder__slot-remove{opacity:1}.combo-builder__slot-remove:hover{background:var(--brand-red, #c92128)}.combo-builder__hint{margin:0;font-size:10.5px;line-height:1.4;color:var(--text-muted)}.combo-builder__actions{display:flex;gap:8px}.combo-builder__actions .color-combos__save{flex:1}.combo-builder__cancel{padding:10px 14px;font-size:12px;font-weight:600;border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer}.combo-builder__cancel:hover{border-color:var(--text-muted)}.color-combo__chip{flex:1;min-width:0}.project-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg)}.project-actions__btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:10px 6px;background:var(--bg-muted);border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:11.5px;font-weight:600;line-height:1.15;text-align:center;cursor:pointer;transition:all .12s}.project-actions__btn svg{flex-shrink:0;width:17px;height:17px;opacity:.9}.project-actions__btn:hover:not(:disabled){background:var(--accent-soft);color:var(--accent)}.project-actions__btn:disabled{opacity:.45;cursor:default}.toolbar{position:relative;background:#000;color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:14px;padding:11px 18px;min-height:67px;overflow:hidden}.toolbar:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-red) 0%,var(--brand-red) 32%,rgba(255,255,255,.1) 32%,rgba(255,255,255,.1) 34%,var(--accent) 34%,#3E78D1 100%)}.toolbar__group{display:flex;align-items:center;gap:10px}.toolbar__logo{height:40px;width:auto;display:block;object-fit:contain}.toolbar__group--flex{flex:1}.toolbar__group--cta{gap:12px}.toolbar__toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:#ffffffeb;padding:6px 11px;border-radius:var(--radius-pill);background:#ffffff1a;border:1px solid rgba(255,255,255,.14);cursor:pointer;transition:background .12s}.toolbar__toggle:hover{background:#ffffff24}.toolbar__toggle input{accent-color:#fff}.toolbar__status{font-size:12px;font-weight:600;color:#fff;background:#ffffff24;padding:5px 10px;border-radius:var(--radius-pill)}.toolbar__cta{display:inline-grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:8px 14px 8px 11px;border:0;border-radius:var(--radius-md);cursor:pointer;text-align:left;font:inherit;color:#fff;min-height:45px;transition:transform .12s,box-shadow .12s,background .12s;box-shadow:var(--shadow-sm)}.toolbar__cta:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.toolbar__cta:active:not(:disabled){transform:translateY(0)}.toolbar__cta:disabled{opacity:.45;cursor:default;box-shadow:none}.toolbar__cta-icon{width:32px;height:32px;display:grid;place-items:center;background:#ffffff24;border-radius:var(--radius-sm);flex-shrink:0}.toolbar__cta-body{display:flex;flex-direction:column;gap:2px;line-height:1.1}.toolbar__cta-title{font-size:14px;font-weight:700;letter-spacing:-.01em}.toolbar__cta-hint{font-size:11.5px;font-weight:500;color:#ffffffc7}.toolbar__cta--preview{background:linear-gradient(180deg,#4a7fc4,#3568a8)}.toolbar__cta--preview:hover:not(:disabled){background:linear-gradient(180deg,#5a8fd4,#4578b8)}.toolbar__cta--hq{background:linear-gradient(180deg,#2e63b6,#1e4b94)}.toolbar__cta--hq:hover:not(:disabled){background:linear-gradient(180deg,#3875c8,#245cae)}.toolbar__cta--final{background:linear-gradient(180deg,#eb4b50,#c92128);box-shadow:var(--shadow-sm),0 0 #e1323700}.toolbar__cta--final:hover:not(:disabled){background:linear-gradient(180deg,#f15a60,#d62328);box-shadow:var(--shadow-md),0 0 0 4px #e1323738}.toolbar__cta--final:not(:disabled) .toolbar__cta-icon{background:#ffffff38}.tool-btn{background:var(--bg-surface);border:1px solid transparent;color:var(--text-secondary);padding:8px 14px;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:all .12s}.tool-btn svg{flex-shrink:0}.tool-btn kbd{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:10px;font-weight:600;padding:2px 6px;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);background:var(--bg-muted);line-height:1}.tool-btn:hover:not(:disabled){background:var(--accent-softer);color:var(--accent)}.tool-btn.is-active{background:var(--accent-soft);color:var(--accent)}.tool-btn:disabled{opacity:.4;cursor:default}.tool-btn--primary{background:var(--accent);color:#fff;font-weight:600;box-shadow:var(--shadow-xs)}.tool-btn--primary:hover:not(:disabled){background:var(--accent-hover);color:#fff;box-shadow:var(--shadow-sm)}.tool-btn--accent{background:var(--brand-red);color:#fff;font-weight:600;border:0;box-shadow:var(--shadow-xs)}.tool-btn--accent:hover:not(:disabled){background:var(--brand-red-hover);color:#fff;box-shadow:var(--shadow-sm)}.tool-btn--accent:disabled{opacity:.5}.tool-btn--secondary{border-color:var(--border-strong);color:var(--text-secondary)}.tool-btn--secondary:hover:not(:disabled){border-color:var(--accent);background:var(--accent-softer);color:var(--accent)}.tool-btn--promote{background:linear-gradient(135deg,#2e8b57,#1a6b40);color:#fff;font-weight:600;border-color:transparent;box-shadow:0 2px 8px #2e8b5759}.tool-btn--promote:hover:not(:disabled){background:linear-gradient(135deg,#38a868,#22804e);box-shadow:0 2px 12px #2e8b5780}.knob{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--text-secondary)}.knob input{accent-color:var(--accent);width:100px}.knob__value{min-width:24px;text-align:right;color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.render-dialog{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:40;padding:24px}.render-dialog__card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(740px,100%);max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.render-dialog__header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.render-dialog__header h3{margin:0;flex:1;font-size:17px;font-weight:700;letter-spacing:-.01em}.render-dialog__close{background:transparent;border:0;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;padding:4px 10px;border-radius:6px;transition:all .12s}.render-dialog__close:hover{background:var(--bg-muted);color:var(--text-primary)}.render-dialog__body{flex:1;overflow:auto;min-height:260px;display:flex;align-items:center;justify-content:center;padding:28px;background:var(--bg-muted)}.render-dialog__progress{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;color:var(--text-secondary);font-size:14px}.render-dialog__spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.render-dialog__provider{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.render-dialog__result img{max-width:100%;max-height:60vh;border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.render-dialog__error{color:var(--danger);text-align:center;font-size:14px}.render-dialog__error pre{background:var(--bg-surface);border:1px solid var(--border);padding:12px;border-radius:var(--radius-sm);font-size:11px;text-align:left;max-width:520px;overflow-x:auto;color:var(--text-secondary)}.render-dialog__footer{display:flex;gap:12px;align-items:center;padding:14px 20px;border-top:1px solid var(--border);background:var(--bg-surface)}.render-dialog__chip{display:flex;align-items:center;gap:8px;flex:1;font-size:12px;color:var(--text-secondary)}.render-dialog__chip-swatch{width:16px;height:16px;border-radius:5px;border:1px solid rgba(11,34,64,.12);flex-shrink:0}.render-dialog__chip-label{font-size:12px;color:var(--text-primary);font-weight:500}.viz-dialog{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b224080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:40;padding:20px}.viz-dialog__card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(980px,100%);max-height:92vh;display:flex;flex-direction:column;overflow:hidden}.viz-dialog__header{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.viz-dialog__header-icon{color:var(--accent);display:flex;align-items:center;flex-shrink:0}.viz-dialog__header h3{margin:0;flex:1;font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary)}.viz-dialog__close{background:transparent;border:0;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;padding:4px 10px;border-radius:6px;transition:all .12s;flex-shrink:0}.viz-dialog__close:hover{background:var(--bg-muted);color:var(--text-primary)}.viz-dialog__body{flex:1;overflow:hidden;display:flex;min-height:0}.viz-dialog__image-area{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:24px;background:#111820;min-width:0}.viz-dialog__image-area img{max-width:100%;max-height:65vh;border-radius:var(--radius-md);box-shadow:0 8px 40px #00000080;display:block}.viz-dialog__legend{width:280px;flex-shrink:0;border-left:1px solid var(--border);overflow-y:auto;background:var(--bg-surface);display:flex;flex-direction:column}.viz-dialog__legend-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:16px 18px 10px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-surface);z-index:1}.viz-color-list{list-style:none;margin:0;padding:8px 0;display:flex;flex-direction:column;gap:2px}.viz-color-item{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-radius:8px;transition:background .1s}.viz-color-item:hover{background:var(--bg-muted)}.viz-color-item__swatch{width:34px;height:34px;border-radius:8px;border:1px solid rgba(0,0,0,.1);flex-shrink:0;margin-top:1px;box-shadow:0 1px 3px #0000001f}.viz-color-item__info{display:flex;flex-direction:column;gap:2px;min-width:0}.viz-color-item__name{font-size:15px;font-weight:600;line-height:1.35;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viz-color-item__shade{font-size:13px;line-height:1.4;color:var(--text-secondary);white-space:normal;overflow:hidden;text-overflow:ellipsis}.viz-color-item__hex{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:10px;color:var(--text-muted);background:var(--bg-muted);padding:1px 6px;border-radius:4px;align-self:flex-start;letter-spacing:.03em}.viz-dialog__footer{display:flex;gap:10px;align-items:center;padding:14px 20px;border-top:1px solid var(--border);background:var(--bg-surface);flex-wrap:wrap}.viz-dialog__btn-download{text-decoration:none}.zoomable-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;max-width:100%;max-height:100%;overflow:hidden;border-radius:var(--radius-lg)}.zoomable-wrap img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;transform-origin:center center}.zoomable-reset{position:absolute;bottom:10px;right:10px;z-index:5;width:32px;height:32px;border-radius:var(--radius-pill);border:1px solid rgba(255,255,255,.22);background:#0c121abf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}.zoomable-reset:hover{background:#1e2837f2}.viz-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:flex;align-items:center;justify-content:center;outline:none}.viz-lightbox__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#06090eeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.viz-lightbox__img-wrap{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;padding:48px 64px 80px;box-sizing:border-box;pointer-events:none}.viz-lightbox__img-wrap>.zoomable-wrap{pointer-events:all;max-width:100%;max-height:100%;flex-shrink:1}.viz-lightbox__img-inner{position:relative;display:inline-flex;align-items:center;justify-content:center;max-width:100%;max-height:100%;border-radius:var(--radius-lg);overflow:hidden}.viz-lightbox__img-inner .viz-lightbox__img{border-radius:0;box-shadow:none}.viz-lightbox__img-inner .zoomable-wrap{max-width:100%;max-height:100%}.viz-lightbox__img-label{position:absolute;top:12px;z-index:9010;padding:5px 12px;border-radius:var(--radius-pill);background:#0c121aa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.viz-lightbox__img-label--left{left:50%;transform:translate(-50%)}.viz-lightbox__img-label--right{right:12px;font-weight:400}.viz-lightbox__img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:var(--radius-lg);box-shadow:0 24px 80px #000000b3;display:block;-webkit-user-select:none;user-select:none}.viz-lightbox__close{position:fixed;top:16px;right:16px;z-index:9010;width:42px;height:42px;border-radius:var(--radius-pill);border:1px solid rgba(255,255,255,.22);background:#0c121acc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s}.viz-lightbox__close:hover{background:#1e2837f2;border-color:#ffffff73}.viz-lightbox .viz-page__gallery-counter{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:9010}.viz-lightbox .viz-page__gallery-nav{position:fixed;top:50%;z-index:9010}.viz-lightbox .viz-page__gallery-nav--prev{left:16px}.viz-lightbox .viz-page__gallery-nav--next{right:16px}.viz-lightbox__filmstrip{position:fixed!important;bottom:18px;z-index:9010}.viz-page__gallery-slide-track--clickable{cursor:zoom-in}.viz-page__gallery-zoom-hint{position:absolute;bottom:14px;left:14px;z-index:3;width:34px;height:34px;border-radius:var(--radius-pill);background:#0c121aa6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.14);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s;pointer-events:none}.viz-page__gallery-slide-track--clickable:hover .viz-page__gallery-zoom-hint{opacity:1}.viz-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-main);color:var(--text-primary);overflow:hidden}.viz-page__topbar{flex-shrink:0}.viz-page__topbar-sep{width:1px;height:24px;background:var(--border);flex-shrink:0}.viz-page__topbar-info{display:flex;flex-direction:column;gap:1px;justify-content:center}.viz-page__topbar-badge{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.viz-page__topbar-project{font-size:15px;font-weight:500;color:var(--text-secondary);max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viz-page__topbar-spacer{flex:1}.viz-page__topbar-actions{display:flex;align-items:center;gap:8px;padding:8px 0;flex-shrink:0}.viz-page__topbar-actions a{text-decoration:none}.viz-page__main,.viz-page__body{flex:1;display:flex;overflow:hidden;min-height:0}.viz-page__sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-panel);border-right:1px solid var(--border);overflow:hidden;min-height:0}.viz-page__sidebar-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:12px 14px 8px;flex-shrink:0}.viz-page__sidebar-projects{flex:1;overflow-y:auto;min-height:0}.viz-page__sidebar-project{padding:0 8px 8px}.viz-page__sidebar-project.is-current .viz-page__sidebar-project-head{color:var(--accent)}.viz-page__sidebar-project-box{margin-top:4px;padding:8px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-surface);box-shadow:var(--shadow-xs)}.viz-page__sidebar-project-head{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:transparent;cursor:pointer;text-align:left;color:var(--text-primary);font-size:13px;font-weight:600;transition:background .12s}.viz-page__sidebar-project-head:hover{background:var(--bg-muted)}.viz-page__sidebar-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .15s ease}.viz-page__sidebar-chevron.is-open{transform:rotate(180deg)}.viz-page__sidebar-project-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viz-page__sidebar-project-count{flex-shrink:0;font-size:11px;font-weight:700;color:var(--text-muted);background:var(--bg-muted);border-radius:var(--radius-pill);padding:2px 8px;line-height:1.4}.viz-page__sidebar-hero{display:block;width:100%;padding:0;border:2px solid transparent;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:#111;aspect-ratio:16 / 10;transition:border-color .12s,box-shadow .12s}.viz-page__sidebar-hero img{width:100%;height:100%;object-fit:cover;display:block}.viz-page__sidebar-hero:hover{border-color:var(--border-strong)}.viz-page__sidebar-hero.is-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.viz-page__sidebar-thumb-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.viz-page__sidebar-mini{width:40px;height:40px;padding:0;border:2px solid transparent;border-radius:4px;overflow:hidden;cursor:pointer;background:#111;flex-shrink:0;transition:border-color .12s,transform .12s}.viz-page__sidebar-mini img{width:100%;height:100%;object-fit:cover;display:block}.viz-page__sidebar-mini:hover{border-color:var(--border-strong);transform:scale(1.04)}.viz-page__sidebar-mini.is-active{border-color:var(--accent)}.viz-page__sidebar-project-hint{margin:6px 0 0;font-size:11px;color:var(--text-muted);text-align:center}.viz-page__loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--text-secondary);background:#0e1620}.viz-page__loading p{margin:0;font-size:18px;font-weight:500;color:#fff}.viz-page__loading-hint{font-size:14px!important;color:#ffffff73!important;font-weight:400!important}.viz-page__spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:viz-spin .9s linear infinite}@keyframes viz-spin{to{transform:rotate(360deg)}}.viz-page__gallery{flex:1;min-width:0;min-height:0;display:flex;background:#0e1620;padding:10px}.viz-page__gallery-stage{flex:1;min-width:0;min-height:0;width:100%;position:relative}.viz-page__gallery-frame{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.viz-page__gallery-preload{position:absolute;width:0;height:0;overflow:hidden;opacity:0;pointer-events:none}.viz-page__gallery-slide-track{position:relative;width:100%;height:100%;overflow:hidden}.viz-page__gallery-slide-track .viz-page__image{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;will-change:transform}.viz-page__gallery-layer--active{z-index:2;transform:translate(0)}.viz-page__gallery-layer--idle,.viz-page__gallery-layer--hidden{visibility:hidden;z-index:0;transform:translate(0)}.viz-page__image{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;display:block;border-radius:var(--radius-lg)}@keyframes viz-gallery-exit-next{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes viz-gallery-enter-next{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes viz-gallery-exit-prev{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes viz-gallery-enter-prev{0%{transform:translate(-100%)}to{transform:translate(0)}}.viz-page__image--slide-out-next{z-index:1;animation:viz-gallery-exit-next .42s cubic-bezier(.32,.72,0,1) forwards}.viz-page__image--slide-in-next{z-index:2;animation:viz-gallery-enter-next .42s cubic-bezier(.32,.72,0,1) forwards}.viz-page__image--slide-out-prev{z-index:1;animation:viz-gallery-exit-prev .42s cubic-bezier(.32,.72,0,1) forwards}.viz-page__image--slide-in-prev{z-index:2;animation:viz-gallery-enter-prev .42s cubic-bezier(.32,.72,0,1) forwards}.viz-page__gallery-nav{position:absolute;top:50%;z-index:4;width:48px;height:48px;border-radius:var(--radius-pill);border:1px solid rgba(255,255,255,.22);background:#0c121ab8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00000059;transform:translateY(-50%);transition:background .12s,border-color .12s,opacity .12s,transform .12s;outline:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.viz-page__gallery-nav:focus,.viz-page__gallery-nav:focus-visible,.viz-page__gallery-nav:active:not(:disabled){outline:none;box-shadow:0 4px 20px #00000059}.viz-page__gallery-nav--prev{left:16px}.viz-page__gallery-nav--next{right:16px}.viz-page__gallery-nav:hover:not(:disabled){background:#141c26e0;border-color:#fff6;transform:translateY(-50%) scale(1.05)}.viz-page__gallery-nav:disabled{opacity:.2;cursor:not-allowed}.viz-page__gallery-counter{position:absolute;top:52px;right:14px;z-index:3;padding:4px 10px;border-radius:var(--radius-pill);background:#0c121aa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);color:#ffffffbf;font-size:11px;font-weight:500;pointer-events:none}.viz-page__gallery-viz-label{position:absolute;top:14px;right:14px;z-index:3;padding:5px 12px;border-radius:var(--radius-pill);background:#0c121ab8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.viz-page__viz-number-label{font-size:18px;font-weight:700;color:var(--text-primary);padding:16px 16px 4px;line-height:1.2}.viz-page__gallery-filmstrip{position:absolute;bottom:18px;left:50%;z-index:5;transform:translate(-50%);display:flex;gap:10px;padding:12px 14px;max-width:min(92%,720px);overflow-x:auto;border-radius:var(--radius-xl);background:#0c121ad1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);box-shadow:0 10px 40px #00000073;scrollbar-width:thin}.viz-page__gallery-thumb{flex-shrink:0;width:104px;height:70px;padding:0;border:2px solid transparent;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:#111;opacity:.8;transition:border-color .12s,opacity .12s,transform .12s,box-shadow .12s}.viz-page__gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.viz-page__gallery-thumb:hover{opacity:1;transform:translateY(-2px)}.viz-page__gallery-thumb.is-active{opacity:1;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 4px 12px #00000059}.viz-page__detail,.viz-page__legend{width:280px;flex-shrink:0;border-left:1px solid var(--border);background:var(--bg-panel);display:flex;flex-direction:column;overflow:hidden}.viz-page__card{flex-shrink:0;margin:12px 12px 0;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-surface);overflow:hidden}.viz-page__card-header{padding:12px 14px 4px}.viz-page__card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.viz-page__card-actions{display:flex;gap:8px;padding:8px 12px 12px}.viz-page__delete-btn{flex-shrink:0;margin:12px 12px 0;width:calc(100% - 24px);justify-content:center}.viz-page__delete-btn:hover{color:var(--danger);border-color:var(--danger);background:var(--brand-red-soft)}.viz-page__card-btn{flex:1;min-width:0;justify-content:center;text-decoration:none}.viz-page__legend-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:14px 16px 10px;border-bottom:1px solid var(--border);background:var(--bg-panel);flex-shrink:0}.viz-page__detail .viz-color-list,.viz-page__legend .viz-color-list{flex:1;overflow-y:auto;padding:8px 0}.viz-page--empty{align-items:center;justify-content:center}.viz-page__not-found{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;color:var(--text-secondary);max-width:360px;padding:40px;margin:auto}.viz-page__not-found svg{color:var(--text-muted);opacity:.5}.viz-page__not-found h2{margin:0;font-size:22px;font-weight:700;color:var(--text-primary)}.viz-page__not-found p{margin:0;font-size:16px;line-height:1.5}.viz-page .tool-btn,.viz-dialog .tool-btn{font-size:15px;padding:10px 16px}.viz-page .top-bar__viz-btn{font-size:13px;padding:8px 16px}@media (max-width: 600px){.viz-page{height:100dvh}.viz-page__topbar-sep,.viz-page__topbar-info .viz-page__topbar-project{display:none}.viz-page__topbar-badge{font-size:11px}.viz-page__body{flex-direction:column}.viz-page__sidebar{display:none}.viz-page__gallery{flex:1;min-height:0;padding:6px}.viz-page__detail,.viz-page__legend{width:100%;flex-shrink:0;flex-direction:row;overflow-x:auto;overflow-y:hidden;max-height:110px;border-left:none;border-top:1px solid var(--border);gap:0}.viz-page__card{flex-shrink:0;margin:8px 0 8px 8px;min-width:160px}.viz-page__delete-btn{margin:8px 0 8px 8px;width:auto;flex-shrink:0}.viz-page__legend-title{writing-mode:vertical-rl;padding:12px 8px;border-bottom:none;border-right:1px solid var(--border);font-size:10px;flex-shrink:0}.viz-page__detail .viz-color-list,.viz-page__legend .viz-color-list{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:8px;gap:6px;flex:1}.viz-color-item{flex-direction:column;align-items:center;gap:4px;min-width:52px;padding:6px 4px}.viz-color-item__info{align-items:center;text-align:center}.viz-color-item__name{font-size:10px;white-space:nowrap}.viz-color-item__shade{font-size:9px}.viz-page__gallery-filmstrip{bottom:10px;padding:8px 10px;gap:7px}.viz-page__gallery-thumb{width:72px;height:48px}.viz-page__gallery-nav{width:38px;height:38px}.viz-page__gallery-nav--prev{left:8px}.viz-page__gallery-nav--next{right:8px}}@media (max-height: 500px) and (orientation: landscape){.viz-page{height:100dvh}.viz-page__topbar-sep,.viz-page__topbar-project,.viz-page__sidebar{display:none}.viz-page__body{flex-direction:row}.viz-page__gallery{flex:1;min-height:0;padding:4px}.viz-page__detail,.viz-page__legend{width:200px;overflow-y:auto;overflow-x:hidden}.viz-page__card{margin:8px 8px 0}.viz-page__card-header{padding:8px 10px 4px}.viz-page__card-actions{padding:6px 8px 8px;gap:6px}.viz-page .tool-btn{font-size:13px;padding:8px 10px}.viz-page__gallery-filmstrip{bottom:8px;padding:8px 10px;gap:6px}.viz-page__gallery-thumb{width:80px;height:52px}.viz-page__gallery-nav{width:36px;height:36px}.viz-page__gallery-nav--prev{left:8px}.viz-page__gallery-nav--next{right:8px}}.viz-popup-blocked{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:12px 16px;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary);z-index:50;white-space:nowrap}.tools-panel{flex:0 0 auto;padding:14px;gap:10px}.tools-panel__header h3{margin:0 0 4px;padding:0;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.tools-panel__list{display:flex;flex-direction:column;gap:4px}.tools-panel__item{display:flex;flex-direction:column}.tools-panel__expand{display:grid;grid-template-rows:0fr;transition:grid-template-rows .24s cubic-bezier(.4,0,.2,1)}.tools-panel__item.is-active .tools-panel__expand{grid-template-rows:1fr}.tools-panel__expand-inner{overflow:hidden;min-height:0}.tools-panel__expand-content{padding:0 2px;opacity:0;transform:translateY(-4px);transition:opacity .2s ease,transform .24s cubic-bezier(.4,0,.2,1),padding .24s cubic-bezier(.4,0,.2,1)}.tools-panel__item.is-active .tools-panel__expand-content{padding:2px 2px 6px;opacity:1;transform:translateY(0)}.tools-panel__expand-hint{margin:0;padding:8px 10px;font-size:11px;line-height:1.45;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}@media (prefers-reduced-motion: reduce){.tools-panel__expand,.tools-panel__expand-content{transition:none}.tools-panel__item.is-active .tools-panel__expand{grid-template-rows:1fr}.tools-panel__expand-content{opacity:1;transform:none}.tools-panel__item.is-active .tools-panel__expand-content{padding:2px 2px 6px}}.tools-panel__btn{display:grid;grid-template-columns:20px 1fr auto;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-muted);border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:500;text-align:left;cursor:pointer;transition:all .12s}.tools-panel__btn:hover{background:var(--accent-softer);color:var(--accent)}.tools-panel__btn.is-active{background:var(--accent);color:#fff;box-shadow:var(--shadow-xs)}.tools-panel__btn.is-active kbd{background:#fff3;color:#ffffffe6;border-color:#ffffff40}.tools-panel__icon{font-size:14px;line-height:0;text-align:center;display:grid;place-items:center}.tools-panel__icon svg{display:block}.tools-panel__label{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.tools-panel__btn kbd{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:10px;font-weight:600;padding:2px 5px;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);background:var(--bg-surface)}.tools-panel__ai{margin-top:2px;display:flex;flex-direction:column;gap:6px}.tools-panel__ai-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:0;border-radius:var(--radius-md);cursor:pointer;text-align:left;font:inherit;color:#fff;background:linear-gradient(180deg,#2e8b57,#1e6b40);box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s,background .12s,opacity .12s}.tools-panel__ai-btn:hover:not(:disabled){background:linear-gradient(180deg,#38a868,#247a4c);box-shadow:var(--shadow-md),0 0 0 3px #2e8b572e;transform:translateY(-1px)}.tools-panel__ai-btn:active:not(:disabled){transform:translateY(0)}.tools-panel__ai-btn:disabled{opacity:.5;cursor:default;box-shadow:none}.tools-panel__ai-btn--detect{background:linear-gradient(180deg,#2563eb,#1d4ed8)}.tools-panel__ai-btn--detect:hover:not(:disabled){background:linear-gradient(180deg,#3b82f6,#2563eb);box-shadow:var(--shadow-md),0 0 0 3px #2563eb33}.tools-panel__ai-icon{flex:0 0 auto;display:grid;place-items:center;width:32px;height:32px;background:#fff3;border-radius:var(--radius-sm)}.tools-panel__ai-text{display:flex;min-width:0;flex:1 1 auto;flex-direction:column;gap:1px;line-height:1.2}.tools-panel__ai-title{font-size:13px;font-weight:700;letter-spacing:-.01em}.tools-panel__ai-hint{font-size:11px;font-weight:500;color:#ffffffd1}.tools-panel__knobs{display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.tools-panel__field{display:flex;flex-direction:column;gap:6px}.tools-panel__field-label{font-size:12px;font-weight:500;color:var(--text-secondary)}.tools-panel__seg{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:3px;background:var(--bg-muted);border-radius:var(--radius-md)}.tools-panel__seg--triple{grid-template-columns:repeat(3,1fr)}.tools-panel__seg-btn{padding:6px 8px;border:0;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--text-secondary);font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.tools-panel__seg-btn:hover{color:var(--accent);background:var(--accent-softer)}.tools-panel__seg-btn.is-active{background:var(--accent);color:#fff;box-shadow:var(--shadow-xs)}.tools-panel__clear-btn{margin-top:2px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-muted);color:var(--text-secondary);font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.tools-panel__clear-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.tools-panel__clear-btn:disabled{opacity:.45;cursor:not-allowed}.tools-panel__knob{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--text-secondary)}.tools-panel__knob input[type=range]{accent-color:var(--accent);width:100%}.tools-panel__knob-value{min-width:22px;text-align:right;color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.tools-panel__toggle{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--text-secondary)}.tools-panel__toggle input{accent-color:var(--accent)}.tools-panel__help{display:flex;flex-direction:column;gap:4px;font-size:10.5px;color:var(--text-muted);line-height:1.45;padding:10px 10px 0;border-top:1px dashed var(--border)}.tools-panel__help strong{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.finish-picker{display:flex;flex-direction:column;gap:10px;padding-top:12px;border-top:1px dashed var(--border)}.finish-picker__header{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.finish-picker__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.finish-tile{display:flex;flex-direction:column;gap:8px;padding:8px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all .12s}.finish-tile:hover{border-color:var(--accent);background:var(--accent-softer);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.finish-tile.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--text-primary);box-shadow:0 0 0 1px var(--accent),var(--shadow-sm)}.finish-tile__canvas{width:100%;height:64px;border-radius:var(--radius-sm);display:block;box-shadow:inset 0 0 0 1px #0b22401f;object-fit:cover}.finish-tile__meta{display:flex;flex-direction:column;gap:3px;min-width:0}.finish-tile__name{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.2}.finish-tile__desc{font-size:10.5px;color:var(--text-muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.finish-picker__hint{margin:0;font-size:11px;color:var(--text-muted);line-height:1.45}.renov-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.renov-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:0}.renov-header{display:flex;align-items:flex-start;gap:12px;padding:20px 20px 0}.renov-header__icon{font-size:28px;line-height:1;flex-shrink:0;margin-top:2px}.renov-header__title{margin:0 0 4px;font-size:17px;font-weight:700;color:var(--text-primary);line-height:1.2}.renov-header__sub{margin:0;font-size:12px;color:var(--text-secondary);line-height:1.4}.renov-close{margin-left:auto;flex-shrink:0;background:transparent;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px 6px;border-radius:6px;line-height:1;transition:color .15s,background .15s}.renov-close:hover{color:var(--text-primary);background:var(--bg-muted)}.renov-section{padding:16px 20px 0}.renov-section:last-of-type{padding-bottom:0}.renov-section__title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.renov-section__title{margin:0 0 10px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.renov-section__title-row .renov-section__title{margin-bottom:0}.renov-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-muted)}.renov-checkbox-row{display:flex;align-items:flex-start;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;color:var(--text-primary);line-height:1.4}.renov-checkbox-row input[type=checkbox]{margin-top:2px;flex-shrink:0;cursor:pointer}.renov-checkbox-hint{font-weight:400;color:var(--text-secondary)}.renov-select-all{background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:11px;cursor:pointer;padding:3px 8px;transition:color .15s,border-color .15s,background .15s}.renov-select-all:hover{color:var(--text-primary);border-color:var(--accent);background:var(--accent-softer)}.renov-chips{display:flex;flex-wrap:wrap;gap:8px}.renov-chip{display:flex;align-items:center;gap:6px;padding:7px 13px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg-muted);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;line-height:1}.renov-chip:hover{border-color:var(--accent);color:var(--text-primary);background:var(--accent-softer)}.renov-chip--active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.renov-chip--active:hover{border-color:var(--accent-hover);background:var(--accent-soft);color:var(--accent-hover)}.renov-chip__emoji{font-size:15px;line-height:1}.renov-chip__hint{display:block;font-size:10px;font-weight:400;opacity:.75;margin-top:2px;line-height:1.2}.renov-chip--style{flex-direction:column;align-items:flex-start;padding:8px 13px;border-radius:10px;gap:0}.renov-chip--style.renov-chip--active .renov-chip__hint{opacity:.9}.renov-textarea{width:100%;box-sizing:border-box;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;line-height:1.5;padding:10px 12px;resize:vertical;font-family:inherit;transition:border-color .15s;outline:none}.renov-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.renov-textarea::placeholder{color:var(--text-muted)}.renov-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;margin-top:4px;border-top:1px solid var(--border)}.renov-btn{padding:10px 20px;border-radius:var(--radius-pill);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .15s ease;line-height:1}.renov-btn--cancel{background:var(--bg-muted);color:var(--text-secondary);border:1px solid var(--border)}.renov-btn--cancel:hover{background:var(--accent-softer);color:var(--text-primary);border-color:var(--accent)}.renov-btn--start{background:var(--accent);color:var(--accent-contrast);box-shadow:0 2px 8px #1e4b9440}.renov-btn--start:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #1e4b9459;transform:translateY(-1px)}.renov-btn--start:disabled{opacity:.5;cursor:not-allowed}.detect-surfaces-dialog{max-width:560px}.detect-surfaces-dialog__text{margin:0;font-size:14px;line-height:1.5;color:var(--text-secondary)}.detect-surfaces-dialog__footer{justify-content:stretch}.detect-surfaces-dialog__actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;align-items:center;width:100%}.detect-surfaces-dialog__actions .renov-btn{flex:0 1 auto;white-space:nowrap}.detect-surfaces-dialog__btn-keep{background:var(--bg-muted);color:var(--text-primary);border:1px solid var(--border)}.detect-surfaces-dialog__btn-keep:hover{background:var(--accent-softer);color:var(--accent);border-color:var(--accent)}.renov-color-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md)}.renov-color-row__label{font-size:12px;color:var(--text-secondary);font-weight:500}.renov-color-row__swatch{width:24px;height:24px;border-radius:6px;border:1px solid var(--border);box-shadow:inset 0 0 0 1px #0000000f;flex-shrink:0}.renov-color-row__code{font-size:12px;color:var(--text-primary);font-family:JetBrains Mono,ui-monospace,monospace;margin-left:auto}.renov-no-surfaces{margin:0;font-size:12px;color:var(--text-muted);background:var(--bg-muted);border:1px dashed var(--border);border-radius:var(--radius-md);padding:10px 14px;line-height:1.5}.auth-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px}.auth-dialog__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.auth-dialog__card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(420px,100%);overflow:hidden}.auth-dialog__header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.auth-dialog__header h3{margin:0;flex:1;font-size:17px;font-weight:700}.auth-dialog__close{background:transparent;border:0;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;padding:4px 10px;border-radius:6px}.auth-dialog__close:hover{background:var(--bg-muted);color:var(--text-primary)}.auth-dialog__tabs{display:flex;gap:4px;padding:12px 16px 0}.auth-dialog__tab{flex:1;border:0;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;padding:10px 12px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:pointer;border-bottom:2px solid transparent}.auth-dialog__tab--active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-softer)}.auth-dialog__form{display:flex;flex-direction:column;gap:14px;padding:20px}.auth-dialog__field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary)}.auth-dialog__field input{font:inherit;font-weight:500;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary)}.auth-dialog__field input:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus)}.auth-dialog__error{margin:0;font-size:13px;color:var(--danger, #c0392b);background:#c0392b14;border-radius:var(--radius-sm);padding:8px 12px}.auth-dialog__notice{margin:0;font-size:12px;line-height:1.45;color:var(--text-secondary);background:var(--bg-muted);border-radius:var(--radius-sm);padding:10px 12px}.auth-dialog__submit{margin-top:4px;padding:11px 16px;border:0;border-radius:var(--radius-pill);background:var(--accent);color:#fff;font-size:14px;font-weight:700;cursor:pointer}.auth-dialog__submit:disabled{opacity:.6;cursor:wait}.auth-dialog__hint{margin:0;padding:0 20px 20px;font-size:13px;color:var(--text-secondary);text-align:center}.auth-dialog__link{background:none;border:0;padding:0;color:var(--accent);font:inherit;font-weight:600;cursor:pointer;text-decoration:underline}.auth-user{display:flex;align-items:center;gap:10px}.auth-user__label{font-size:12px;font-weight:600;color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-bar__actions--user .auth-user__label{display:block}.intro__quote-btn,.quote-request-btn{display:inline-flex;align-items:center;gap:6px;border:0;border-radius:var(--radius-pill);background:var(--accent);color:#fff;font-size:12px;font-weight:700;padding:7px 12px;cursor:pointer;transition:filter .12s,transform .12s;white-space:nowrap;flex-shrink:0}.toolbar__share-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid rgba(255,255,255,.35);border-radius:var(--radius-md);background:#ffffff1a;color:#fff;font-size:13px;font-weight:700;padding:8px 16px;min-height:45px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .12s,transform .12s,box-shadow .12s}.toolbar__share-btn:hover{background:#ffffff2e;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.toolbar__quote-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;border-radius:var(--radius-md);background:linear-gradient(180deg,#eb4b50,#c92128);color:#fff;font-size:13px;font-weight:700;padding:8px 16px;min-height:45px;cursor:pointer;white-space:nowrap;flex-shrink:0;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s,filter .12s}.toolbar__quote-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:linear-gradient(180deg,#f15a60,#d62328)}.toolbar__quote-btn:active{transform:translateY(0)}.quote-request-btn__short{display:none}.intro__quote-btn{font-size:13px}@media (max-width: 1180px){.quote-request-btn__full{display:none}.quote-request-btn__short{display:inline}}.intro__quote-btn:hover,.quote-request-btn:hover{filter:brightness(1.06)}.quote-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));box-sizing:border-box}.quote-dialog__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.quote-dialog__card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(440px,100%);max-height:min(90vh,100%);overflow:auto}.quote-dialog__header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.quote-dialog__header h3{margin:0;flex:1;font-size:17px;font-weight:700}.quote-dialog__close{background:transparent;border:0;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;padding:4px 10px;border-radius:6px}.quote-dialog__body,.quote-dialog__form{padding:20px;display:flex;flex-direction:column;gap:14px}.quote-dialog__intro{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.5}.quote-dialog__field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary)}.quote-dialog__field input,.quote-dialog__field textarea{font:inherit;font-weight:500;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary)}.quote-dialog__field input:focus,.quote-dialog__field textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus)}.quote-dialog__optional{font-weight:400;color:var(--text-muted)}.quote-dialog__error{margin:0;font-size:13px;color:#b42318;background:#b4231814;border-radius:var(--radius-sm);padding:8px 12px}.quote-dialog__success{margin:0;font-size:14px;color:var(--text-primary);line-height:1.5}.quote-dialog__submit{margin-top:4px;padding:11px 16px;border:0;border-radius:var(--radius-pill);background:var(--accent);color:#fff;font-size:14px;font-weight:700;cursor:pointer}.quote-dialog__submit:disabled{opacity:.6;cursor:wait}.my-projects-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.my-projects-dialog__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.my-projects-dialog__card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(920px,100%);max-height:min(85vh,720px);display:flex;flex-direction:column;overflow:hidden}.my-projects-dialog__header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.my-projects-dialog__header h3{margin:0;flex:1;font-size:17px;font-weight:700}.my-projects-dialog__close{width:32px;height:32px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer}.my-projects-dialog__close:hover{background:var(--bg-muted);color:var(--text-primary)}.my-projects-dialog__body{padding:18px 20px 22px;overflow-y:auto;min-height:0}.my-projects-dialog__status{margin:0;padding:24px 8px;text-align:center;color:var(--text-secondary);font-size:14px}.my-projects-dialog__status--error{color:var(--danger)}.my-projects-dialog__grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.my-projects-dialog__card-btn{width:100%;display:flex;flex-direction:column;align-items:stretch;text-align:left;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-panel);padding:0;cursor:pointer;overflow:hidden;transition:border-color .12s,box-shadow .12s,transform .12s}.my-projects-dialog__card-btn:hover:not(:disabled){border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.my-projects-dialog__card-btn--active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft)}.my-projects-dialog__card-btn:disabled{opacity:.6;cursor:wait}.my-projects-dialog__thumb{position:relative;aspect-ratio:4 / 3;background:var(--bg-muted);overflow:hidden}.my-projects-dialog__thumb img{width:100%;height:100%;object-fit:cover;display:block}.my-projects-dialog__thumb-empty{width:100%;height:100%;display:grid;place-items:center;color:var(--text-muted)}.my-projects-dialog__views-badge{position:absolute;right:8px;bottom:8px;font-size:10px;font-weight:700;color:#fff;background:#0b2240b8;padding:3px 8px;border-radius:var(--radius-pill)}.my-projects-dialog__meta{padding:10px 12px 12px;display:flex;flex-direction:column;gap:4px;min-width:0}.my-projects-dialog__name{font-size:13px;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.my-projects-dialog__date{font-size:11px;color:var(--text-muted)}.my-projects-dialog__item{position:relative}.my-projects-dialog__delete{position:absolute;top:8px;right:8px;z-index:2;width:28px;height:28px;border:0;border-radius:var(--radius-sm);background:#0b2240b8;color:#fff;font-size:18px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s,background .12s}.my-projects-dialog__item:hover .my-projects-dialog__delete,.my-projects-dialog__delete:focus-visible{opacity:1}.my-projects-dialog__delete:hover:not(:disabled){background:var(--danger)}.my-projects-dialog__delete:disabled{opacity:.5;cursor:wait}.share-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.share-dialog__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.share-dialog__card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(520px,100%)}.share-dialog__header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.share-dialog__header h3{margin:0;flex:1;font-size:17px;font-weight:700}.share-dialog__close{width:32px;height:32px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:22px;cursor:pointer}.share-dialog__close:hover{background:var(--bg-muted)}.share-dialog__body{padding:20px;display:flex;flex-direction:column;gap:14px}.share-dialog__intro{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5}.share-dialog__status{margin:0;font-size:13px;color:var(--text-secondary)}.share-dialog__error{margin:0;font-size:13px;color:var(--danger)}.share-dialog__link-row{display:flex;gap:8px}.share-dialog__input{flex:1;min-width:0;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;color:var(--text-primary);background:var(--bg-muted)}.share-dialog__copy{flex-shrink:0;border:0;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:700;padding:10px 16px;cursor:pointer}.share-dialog__copy:hover{background:var(--accent-hover)}.share-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-main);overflow:hidden}.share-page__header{display:flex;align-items:center;gap:16px;padding:16px 24px;background:var(--bg-surface);box-shadow:var(--shadow-sm);flex-shrink:0}.share-page__logo{height:28px;width:auto}.share-page__label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.share-page__title{margin:2px 0 0;font-size:18px;font-weight:700}.share-page__main{flex:1;min-height:0;display:flex;flex-direction:column;align-items:stretch;padding:16px 20px;gap:16px}.share-page__status{margin:0;color:var(--text-secondary);font-size:14px;text-align:center}.share-page__status--error{color:var(--danger)}.share-page__body{display:flex;gap:20px;align-items:flex-start;flex:1;min-height:0;width:100%;max-width:1400px;margin:0 auto}.share-page__canvas-col{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;gap:12px;align-self:stretch}.share-gallery{position:relative;width:100%;flex:1;min-height:0;border-radius:var(--radius-lg);overflow:hidden;background:#0e1620}.share-gallery__img-wrap{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.share-gallery__img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;display:none}.share-gallery__img.is-active{display:block}.share-gallery__viz-label{position:absolute;top:14px;left:14px;z-index:3;padding:7px 16px;border-radius:var(--radius-pill);background:#0c121ab8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:15px;font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none}.share-page__gallery{width:100%;height:min(72vh,840px);border-radius:var(--radius-lg);overflow:hidden;background:#0e1620;display:flex;flex-direction:column}.share-page__viz-frame{width:100%;height:min(72vh,840px);border-radius:var(--radius-lg);overflow:hidden;background:#0e1620;display:flex;align-items:center;justify-content:center}.share-page__viz-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}.share-page__views{display:flex;gap:8px;flex-wrap:wrap}.share-page__view-tab{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg-surface);color:var(--text-secondary);font-size:12px;font-weight:600;padding:7px 14px;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.share-page__view-tab:hover{border-color:var(--accent);color:var(--accent)}.share-page__view-tab--active{border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.share-page__legend{width:260px;flex-shrink:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow-y:auto;align-self:flex-start;max-height:100%}.share-page__viz-number{font-size:18px;font-weight:700;color:var(--text-primary);padding:16px 16px 8px;line-height:1.2;margin-bottom:4px}.share-page__legend-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:14px 16px 10px;border-bottom:1px solid var(--border)}.share-page__color-list{list-style:none;margin:0;padding:6px 0}.share-page__color-item{display:flex;align-items:center;gap:10px;padding:8px 14px}.share-page__color-item:hover{background:var(--bg-muted)}.share-page__color-swatch{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1);flex-shrink:0}.share-page__color-info{display:flex;flex-direction:column;gap:2px;min-width:0}.share-page__color-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-page__color-shade{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 720px){.share-page__body{flex-direction:column}.share-page__legend{width:100%}}.share-preview{width:100%;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:12px;display:flex;justify-content:center}.share-preview__canvas,.share-preview__render{display:block;max-width:100%;height:auto;border-radius:var(--radius-sm)}.admin-page{min-height:100vh;background:var(--bg-app);color:var(--text-primary);padding:0 0 48px}.admin-page__nav{display:flex;align-items:center;padding:0 clamp(16px,4vw,40px);min-height:52px;background:var(--bg-surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:10}.admin-page__nav-logo{height:28px;width:auto;display:block;-webkit-user-select:none;user-select:none}.admin-page__body{padding:24px clamp(16px,4vw,40px) 0}.admin-page--loading{display:grid;place-items:center;min-height:calc(100vh - 52px)}.admin-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.admin-page__header-actions{display:flex;gap:10px;align-items:center;flex-shrink:0}.admin-page__header h1{margin:8px 0 4px;font-size:clamp(22px,3vw,28px)}.admin-page__subtitle{margin:0;color:var(--text-secondary);font-size:14px}.admin-page__back{display:inline-flex;align-items:center;padding:7px 14px;border-radius:var(--radius-pill);border:1.5px solid var(--border-strong);background:var(--bg-muted);color:var(--accent);font-size:13px;font-weight:600;text-decoration:none;box-shadow:var(--shadow-xs);transition:border-color .12s,background .12s,color .12s,box-shadow .12s}.admin-page__back:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong);text-decoration:none;box-shadow:var(--shadow-sm)}.admin-page__primary{border:0;border-radius:var(--radius-pill);background:var(--accent);color:var(--accent-contrast);font-size:14px;font-weight:700;padding:10px 20px;cursor:pointer;text-decoration:none;box-shadow:var(--shadow-sm);transition:background .12s,box-shadow .12s,transform 80ms}.admin-page__primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-md)}.admin-page__primary:active:not(:disabled){transform:translateY(1px)}.admin-page__primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-page__primary:disabled{opacity:.55;cursor:default}.admin-page__secondary{border:1.5px solid var(--border-strong);border-radius:var(--radius-pill);background:var(--bg-muted);color:var(--text-primary);font-size:14px;font-weight:600;padding:9px 20px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;box-shadow:var(--shadow-xs);transition:border-color .12s,background .12s,color .12s,box-shadow .12s}.admin-page__secondary:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);box-shadow:var(--shadow-sm)}.admin-stats-summary{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.admin-stat-card{flex:1;min-width:140px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:20px 24px;display:flex;flex-direction:column;gap:4px}.admin-stat-card__value{font-size:32px;font-weight:800;color:var(--accent);line-height:1}.admin-stat-card__label{font-size:12px;color:var(--text-muted);font-weight:500}.admin-stat-card__meta{font-size:11px;color:var(--text-secondary);margin-top:2px}.admin-stats-summary--overview,.admin-stats-summary--clients{padding:20px 24px 0}.admin-overview__charts{display:flex;flex-direction:column;gap:28px;padding:8px 24px 24px}.admin-chart-panel{background:var(--bg-elevated, var(--bg-surface));border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px 20px}.admin-chart-panel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}.admin-chart-panel__title{margin:0;font-size:15px;font-weight:700;color:var(--text-primary)}.admin-chart-legend{display:flex;gap:14px;flex-wrap:wrap}.admin-chart-legend__item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.admin-chart-legend__swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}.admin-chart-legend__swatch--guest{background:#94a3b8}.admin-chart-legend__swatch--registered{background:var(--accent)}.admin-compare-bars{display:flex;flex-direction:column;gap:12px}.admin-compare-bar{display:grid;grid-template-columns:minmax(140px,180px) 1fr 40px;gap:12px;align-items:center}.admin-compare-bar__label{font-size:13px;color:var(--text-secondary);font-weight:500}.admin-compare-bar__track{display:flex;height:28px;border-radius:6px;overflow:hidden;background:var(--bg-muted, rgba(0, 0, 0, .04));border:1px solid var(--border)}.admin-compare-bar__segment{display:flex;align-items:center;justify-content:center;min-width:0;font-size:11px;font-weight:700;color:#fff;transition:width .2s ease}.admin-compare-bar__segment--guest{background:#94a3b8}.admin-compare-bar__segment--registered{background:var(--accent)}.admin-compare-bar__total{text-align:right;font-size:14px;font-weight:700;color:var(--text-primary)}.admin-trend-chart__grid{display:flex;align-items:flex-end;gap:3px;height:160px;padding:0 2px}.admin-trend-chart__col{flex:1;min-width:0;height:100%;display:flex;align-items:flex-end}.admin-trend-chart__stack{width:100%;display:flex;flex-direction:column-reverse;border-radius:3px 3px 0 0;overflow:hidden;min-height:0}.admin-trend-chart__segment--guest{background:#94a3b8;min-height:2px}.admin-trend-chart__segment--registered{background:var(--accent);min-height:2px}.admin-trend-chart__axis{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--text-muted)}.admin-section-divider{padding:20px 24px 0;border-top:1px solid var(--border);margin-top:8px}.admin-section-divider__title{margin:0 0 4px;font-size:16px;font-weight:700}.admin-section-divider__subtitle{margin:0 0 16px;font-size:13px;color:var(--text-secondary)}@media (max-width: 640px){.admin-compare-bar{grid-template-columns:1fr;gap:6px}.admin-compare-bar__total{text-align:left;font-size:12px;color:var(--text-secondary)}}.admin-page__nav-links{display:flex;gap:12px;margin-bottom:4px}.admin-page__content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:8px 0 4px}.admin-page__card{max-width:420px;margin:10vh auto 0;padding:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl)}.admin-page__status{margin:0;padding:24px;text-align:center;color:var(--text-secondary)}.admin-page__status--error{color:var(--danger)}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th,.admin-table td{padding:12px 18px;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:700}.admin-table__empty{text-align:center;color:var(--text-secondary);padding:32px 18px!important}.admin-table__row--inactive{opacity:.65}.admin-table__actions{text-align:right;white-space:nowrap}.admin-table__link{border:1.5px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-muted);color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;padding:6px 14px;box-shadow:var(--shadow-xs);transition:border-color .12s,background .12s,color .12s,box-shadow .12s}.admin-table__link:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong);box-shadow:var(--shadow-sm)}.admin-table__link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--radius-pill);background:#c0392b1f;color:var(--danger)}.admin-badge--ok{background:#2e7d321f;color:#2e7d32}.admin-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px}.admin-dialog__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#0b224073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.admin-dialog__card{position:relative;width:min(440px,100%);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:22px 24px 24px}.admin-dialog__card h2{margin:0 0 8px;font-size:18px}.admin-dialog__email{margin:0 0 16px;font-size:13px;color:var(--text-muted)}.admin-dialog__form{display:flex;flex-direction:column;gap:12px}.admin-dialog__field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-secondary)}.admin-dialog__field input{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-panel);color:var(--text-primary);font-size:14px}.admin-dialog__checkbox{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.admin-dialog__error{margin:0;font-size:13px;color:var(--danger)}.admin-dialog__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.admin-dialog__primary,.admin-dialog__secondary{border-radius:var(--radius-pill);font-size:14px;font-weight:600;padding:10px 18px;cursor:pointer;transition:background .12s,border-color .12s,color .12s,box-shadow .12s}.admin-dialog__primary{border:0;background:var(--accent);color:var(--accent-contrast);box-shadow:var(--shadow-sm)}.admin-dialog__primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-md)}.admin-dialog__primary:disabled{opacity:.55;cursor:default}.admin-dialog__primary:focus-visible,.admin-dialog__secondary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-dialog__secondary{border:1.5px solid var(--border-strong);background:var(--bg-muted);color:var(--text-primary);box-shadow:var(--shadow-xs)}.admin-dialog__secondary:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);box-shadow:var(--shadow-sm)}.admin-dialog__readonly{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;color:var(--text-secondary);background:var(--bg-muted)}.admin-dialog__field--readonly{margin-bottom:4px}.admin-dialog__confirm-delete p{margin:0 0 16px;font-size:14px;color:var(--text-secondary);line-height:1.5}.admin-dialog__actions--split{justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.admin-dialog__actions-right{display:flex;gap:10px;flex-wrap:wrap}.admin-dialog__danger{border:1.5px solid var(--danger);background:var(--danger);color:#fff;font-weight:600;padding:9px 16px;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-xs);transition:background .12s,border-color .12s,box-shadow .12s}.admin-dialog__danger:hover:not(:disabled){filter:brightness(1.05);box-shadow:var(--shadow-sm)}.admin-dialog__danger:disabled{opacity:.6;cursor:not-allowed}.admin-dialog__danger--ghost{background:transparent;color:var(--danger);border-color:color-mix(in srgb,var(--danger) 55%,var(--border))}.admin-dialog__danger--ghost:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 10%,transparent);filter:none}
