.app{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);color:var(--text)}.app-header{flex-shrink:0;z-index:20;border-bottom:1px solid var(--border);background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}.header-inner{display:flex;align-items:center;gap:1rem;padding:.85rem 1.25rem}.header-copy{flex:1;min-width:0}.brand-logo-link{text-decoration:none;color:inherit;border-radius:var(--radius-sm);transition:opacity .15s}.brand-logo-link:hover{opacity:.88}.brand-tagline{margin:0;font-size:.9rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.brand-desc{margin:.15rem 0 0;font-size:.75rem;color:var(--text-muted)}.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.status-pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;padding:.3rem .65rem;border-radius:999px;border:1px solid var(--border-input)}.status-pill--ready{background:var(--brand-muted);color:var(--brand);border-color:transparent}.status-pill--busy{background:var(--bg-card);color:var(--text-muted)}.status-pill--warn{background:var(--badge-warn-bg);color:var(--badge-warn-text);border-color:transparent}.layout-hint{margin:.25rem 0 0;font-size:.68rem;line-height:1.45}.layout-hint--err{color:var(--badge-warn-text, #b45309)}.layout-hint--warn{color:var(--text-muted)}.layout-error-msg{font-size:.82rem;color:var(--badge-warn-text, #b45309)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.workflow-steps{display:flex;align-items:center;gap:.35rem;padding:0 1.25rem .65rem;font-size:.7rem;color:var(--text-faint);overflow-x:auto}.step{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}.step-num{display:inline-flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;border-radius:4px;background:var(--brand-muted);color:var(--brand);font-weight:700;font-size:.65rem}.step-arrow{color:var(--text-faint);opacity:.6}.brand-logo{display:flex;align-items:center;gap:.65rem;flex-shrink:0}.brand-mark{flex-shrink:0;filter:drop-shadow(var(--shadow-brand))}.brand-mark-bg{fill:url(#brandGrad)}[data-theme=dark] .brand-mark-bg,[data-theme=light] .brand-mark-bg{fill:var(--brand-strong)}.brand-mark-icon{fill:#fff;opacity:.95}.brand-mark-icon-dim{fill:#fff;opacity:.5}.brand-name{font-size:1.1rem;font-weight:700;letter-spacing:-.03em;line-height:1.1}.brand-name-en{font-weight:600;color:var(--brand);font-size:.95em}.theme-toggle{display:inline-flex;align-items:center;gap:.35rem;flex-shrink:0;background:var(--bg-elevated);border:1px solid var(--border-input);color:var(--text-muted);border-radius:var(--radius-sm);padding:.35rem .65rem;font-size:.75rem;font-weight:500;cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s}.theme-toggle:hover{border-color:var(--border-hover);color:var(--text)}.theme-toggle-icon{font-size:.85rem;line-height:1}@media (max-width: 640px){.theme-toggle-label{display:none}.theme-toggle{padding:.35rem .5rem}.header-actions{flex-wrap:wrap;justify-content:flex-end;gap:.35rem}}.locale-select-wrap{display:inline-flex;flex-shrink:0}.locale-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-elevated);border:1px solid var(--border-input);color:var(--text-muted);border-radius:var(--radius-sm);padding:.35rem 1.6rem .35rem .65rem;font-size:.75rem;font-weight:500;cursor:pointer;font-family:inherit;background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-position:calc(100% - 14px) calc(50% + 2px),calc(100% - 9px) calc(50% + 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;transition:border-color .15s,color .15s}.locale-select:hover{border-color:var(--border-hover);color:var(--text)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.layout{flex:1;display:grid;grid-template-columns:minmax(300px,380px) 1fr;min-height:0;overflow:hidden}.layout>.sidebar,.layout>.main-column{min-height:0;overflow:hidden}.main-column{display:flex;flex-direction:column;min-height:0}.layout.is-sidebar-collapsed{grid-template-columns:max-content 1fr}.sidebar{overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--border);padding:.75rem;background:var(--bg-subtle)}.sidebar.is-collapsed{padding:.5rem .4rem;overflow:hidden}.sidebar.is-collapsed .inputs-panel-body,.sidebar.is-collapsed .panel-heading h2,.sidebar.is-collapsed .panel-icon{display:none}.sidebar.is-collapsed .panel-heading{margin-bottom:0}.sidebar.is-collapsed .panel{padding:.5rem .35rem}.sidebar.is-collapsed .panel-toggle{margin-left:0}.panel-toggle{margin-left:auto;flex-shrink:0;padding:.2rem .45rem;font-size:.65rem;font-weight:600;font-family:inherit;color:var(--text-muted);background:transparent;border:1px solid var(--border-input);border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,border-color .15s}.panel-toggle:hover{color:var(--text);border-color:var(--border-hover)}.panel{background:var(--bg-elevated);border-radius:var(--radius);padding:1rem 1.1rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.panel-heading{display:flex;align-items:center;gap:.5rem;margin-bottom:.65rem}.panel-heading h2{margin:0;font-size:.9rem;font-weight:600;flex:1;letter-spacing:-.02em}.param-clipboard{margin:-.25rem 0 .75rem}.param-clipboard-file{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.param-clipboard-actions{display:flex;gap:.4rem;flex-wrap:wrap}.btn-compact{padding:.35rem .6rem;font-size:.72rem}.param-clipboard-hint,.param-clipboard-msg{margin:.35rem 0 0;font-size:.68rem;line-height:1.4}.param-clipboard-msg--ok{color:var(--brand)}.param-clipboard-msg--err{color:var(--badge-warn-text, #b45309)}.panel-icon{display:flex;align-items:center;justify-content:center;width:1.65rem;height:1.65rem;border-radius:var(--radius-sm);background:var(--brand-muted);color:var(--brand);font-size:.85rem;flex-shrink:0}.panel-section-label{margin:.85rem 0 .4rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.computing-badge{font-size:.65rem;font-weight:600;color:var(--brand);padding:.15rem .45rem;border-radius:999px;background:var(--brand-muted)}.computing{color:var(--brand)}.field-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.field{display:flex;flex-direction:column;gap:.25rem;font-size:.72rem}.field span{color:var(--text-muted);font-weight:500}.field input,.select-input{background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-sm);color:var(--text);padding:.4rem .55rem;font-size:.8rem;width:100%;box-sizing:border-box;font-family:inherit;transition:border-color .15s,box-shadow .15s}.field input:focus,.select-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-muted)}.field-full{grid-column:1 / -1}.bed-size-block{margin-bottom:.25rem}.bed-custom-hint{margin:.15rem 0 .35rem;font-size:.68rem;color:var(--text-faint)}.scheme-groups{display:flex;flex-direction:column;gap:.85rem;flex:1;min-height:0;overflow-y:auto;transition:opacity .15s ease}.scheme-panel .empty-state{flex:1;display:flex;flex-direction:column;justify-content:center}.scheme-groups.dimmed{opacity:.5;pointer-events:none}.scheme-group-title{margin:0 0 .4rem;font-size:.72rem;font-weight:600;color:var(--text-muted);display:flex;align-items:center;gap:.4rem;letter-spacing:.02em}.scheme-group-count{font-size:.65rem;font-weight:600;color:var(--brand);background:var(--brand-muted);padding:.1rem .4rem;border-radius:999px}.scheme-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.scheme-card{width:100%;text-align:left;background:var(--bg-card);border:1px solid var(--border-input);border-radius:var(--radius);padding:.65rem .75rem;color:inherit;cursor:pointer;font-family:inherit;overflow:visible;transition:border-color .15s,box-shadow .15s,transform .1s}.scheme-card:hover:not(:disabled){border-color:var(--brand);box-shadow:var(--shadow-sm)}.scheme-card.active{border-color:var(--brand);background:var(--bg-card-active);box-shadow:var(--shadow-brand)}.scheme-card:disabled{cursor:wait}.scheme-head{display:flex;align-items:center;gap:.5rem}.rank{font-weight:700;font-size:.7rem;color:var(--text-faint);min-width:1.5rem}.util-ring{display:flex;align-items:baseline;gap:.15rem}.util{font-weight:700;font-size:1.05rem;color:var(--brand);letter-spacing:-.03em}.util-label{font-size:.65rem;color:var(--text-faint);font-weight:500}.badge{font-size:.62rem;font-weight:600;padding:.15rem .4rem;border-radius:999px;margin-left:auto}.badge.ok{background:var(--badge-ok-bg);color:var(--badge-ok-text)}.badge.warn{background:var(--badge-warn-bg);color:var(--badge-warn-text)}.badge-tip{position:relative;cursor:help;flex-shrink:0}.badge-tip:after{content:attr(data-tip);position:absolute;right:calc(100% + 8px);top:50%;z-index:40;width:max-content;max-width:240px;padding:.5rem .65rem;font-size:.68rem;font-weight:500;line-height:1.45;text-align:left;color:var(--text);background:var(--bg-elevated);border:1px solid var(--border-input);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);pointer-events:none;opacity:0;visibility:hidden;transform:translateY(-50%) translate(6px);transition:opacity .15s,transform .15s,visibility .15s}.badge-tip:hover:after,.badge-tip:focus-visible:after{opacity:1;visibility:visible;transform:translateY(-50%) translate(0)}.scheme-meta{font-size:.72rem;color:var(--text-muted);margin-top:.35rem}.scheme-cells{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}.cell-tag{font-size:.62rem;font-weight:500;background:var(--cell-tag-bg);padding:.15rem .35rem;border-radius:4px;color:var(--text-muted)}.cell-tag--warn{background:var(--badge-warn-bg);color:var(--badge-warn-text)}.muted{color:var(--text-muted);font-size:.8rem;line-height:1.5}.empty-state{text-align:center;padding:1rem .5rem}.empty-state-icon{font-size:1.5rem;margin-bottom:.35rem;opacity:.5}.main{flex:1 1 0;display:grid;grid-template-rows:auto minmax(0,1fr);min-height:0;overflow:hidden;background:var(--bg)}.preview-chrome{grid-row:1;display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;padding:.5rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.preview-explode{display:flex;align-items:center;gap:.45rem;margin-left:auto;font-size:.72rem;color:var(--text-muted);cursor:default}.preview-explode-label{font-weight:600;color:var(--text);white-space:nowrap}.preview-explode-slider{width:6.5rem;accent-color:var(--brand);cursor:pointer}.preview-explode-value{min-width:2.25rem;font-variant-numeric:tabular-nums;text-align:right}.preview-chrome-title{display:flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:600;color:var(--text)}.preview-chrome-dot{width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 8px var(--brand)}.preview-chrome-hint{font-size:.68rem;color:var(--text-faint)}.preview-wrap{grid-row:2;min-height:0;position:relative;overflow:hidden;width:100%}.preview-wrap canvas{display:block;width:100%!important;height:100%!important;touch-action:none}.studio-export{flex:0 0 auto;display:flex;flex-direction:column}.actions-bar{flex:0 0 auto;padding:.85rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.65rem;background:var(--bg-elevated);box-shadow:0 -4px 16px #0000000f;z-index:10}.studio-tabs{display:none}.actions-bar-main{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center;justify-content:space-between}.cell-split-group{display:flex;flex-direction:column;gap:0;border-top:1px dashed var(--border-input)}.cell-color-picker{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem .65rem;padding:.55rem 0 .65rem;border-bottom:1px dashed var(--border-input)}.cell-color-label{font-size:.72rem;font-weight:600;color:var(--text);white-space:nowrap}.cell-color-swatches{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.cell-color-swatch{width:1.35rem;height:1.35rem;padding:0;border:2px solid transparent;border-radius:50%;cursor:pointer;box-shadow:inset 0 0 0 1px #0000001f;transition:transform .12s ease,border-color .12s ease}.cell-color-swatch:hover{transform:scale(1.08)}.cell-color-swatch.active{border-color:var(--brand);box-shadow:inset 0 0 0 1px #0000001f,0 0 0 2px var(--bg-elevated)}.cell-color-custom{position:relative;width:1.35rem;height:1.35rem;border-radius:50%;cursor:pointer;background:conic-gradient(#ef4444,#eab308,#22c55e,#3b82f6,#8b5cf6,#ef4444);box-shadow:inset 0 0 0 1px #0000001f}.cell-color-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;padding:0}.cell-color-custom-icon{position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:50%;background:var(--bg-elevated);pointer-events:none}.cell-color-reset{margin-left:auto}.cell-split{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .65rem;padding-top:.5rem}.cell-split-group .cell-split+.cell-split{margin-top:.35rem;padding-top:.5rem;border-top:1px dashed var(--border-input)}.split-field{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--text-muted)}.split-field input{width:4.2rem;padding:.3rem .4rem;font-size:.75rem;border:1px solid var(--border-input);border-radius:var(--radius-sm);background:var(--bg);color:inherit;font-family:inherit}.split-axis-toggle{display:inline-flex;gap:.25rem}.split-axis{padding:.3rem .5rem;font-size:.68rem;font-weight:600;font-family:inherit;border:1px solid var(--border-input);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-muted);cursor:pointer}.split-axis:hover{border-color:var(--border-hover);color:var(--text)}.split-axis.active{border-color:var(--brand);background:var(--brand-muted);color:var(--brand)}.split-preview{flex:1 1 100%;margin:0;font-size:.68rem}.split-preview--err{color:var(--badge-warn-text, #b45309)}.customized-badge{background:var(--badge-warn-bg);color:var(--badge-warn-text)}.computing-bar{justify-content:center;gap:.5rem;color:var(--text-muted);font-size:.82rem;font-weight:500}.computing-spinner{width:14px;height:14px;border:2px solid var(--border-input);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.actions-label{font-size:.72rem;font-weight:600;color:var(--text-muted);margin-right:.25rem}.cell-picker{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.cell-btn{background:var(--btn-secondary-bg);border:1px solid var(--border-input);color:var(--text);border-radius:var(--radius-sm);padding:.3rem .55rem;font-size:.72rem;font-weight:500;cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.cell-btn:hover{border-color:var(--border-hover)}.cell-btn.active{background:var(--bg-card-active);border-color:var(--brand);color:var(--brand)}.download-btns{display:flex;flex-wrap:wrap;gap:.5rem}.export-hint{margin:.5rem 0 0;font-size:.72rem;line-height:1.45;color:var(--text-muted);max-width:42rem}.btn{font-family:inherit;font-weight:600;font-size:.78rem;border-radius:var(--radius-sm);padding:.5rem 1rem;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s}.btn:active:not(:disabled){transform:scale(.98)}.btn-primary{background:var(--brand-gradient);color:#fff;border:none;box-shadow:var(--shadow-brand)}.btn-primary:hover:not(:disabled){filter:brightness(1.06)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--text);border:1px solid var(--border-input)}.btn-secondary:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.app-footer{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.35rem;padding:.55rem 1rem;font-size:.68rem;color:var(--text-faint);border-top:1px solid var(--border);background:var(--bg-subtle)}.footer-sep{opacity:.4}@media (max-width: 860px){.app-footer,.workflow-steps{display:none}.header-inner{padding:.55rem .75rem;gap:.45rem}.header-copy{display:none}.layout{display:flex;flex-direction:column;grid-template-columns:unset;grid-template-rows:unset;min-height:0;overflow:hidden}.layout.is-sidebar-collapsed{grid-template-columns:unset}.studio-tabs{display:flex;flex-shrink:0;gap:.35rem;padding:.4rem .6rem;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.studio-tab{flex:1;padding:.45rem .35rem;font-family:inherit;font-size:.72rem;font-weight:600;color:var(--text-muted);background:transparent;border:1px solid var(--border-input);border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.studio-tab.is-active{color:var(--brand);border-color:var(--brand);background:var(--brand-muted)}.layout--mobile .main-column{display:contents}.layout--mobile .studio-panel{display:none;flex:1;min-height:0;flex-direction:column;overflow:hidden}.layout--mobile .studio-panel.is-active{display:flex}.layout--mobile .sidebar{border-right:none;border-bottom:none;padding:.55rem .65rem;background:var(--bg-subtle)}.layout--mobile .sidebar.is-collapsed{padding:.55rem .65rem}.layout--mobile .sidebar.is-collapsed .inputs-panel-body,.layout--mobile .sidebar.is-collapsed .panel-heading h2,.layout--mobile .sidebar.is-collapsed .panel-icon{display:block}.layout--mobile .sidebar.is-collapsed .panel-heading{display:flex}.layout--mobile .panel-toggle{display:none}.layout--mobile .panel{padding:.7rem .8rem}.layout--mobile .inputs-panel{flex:1;min-height:0;display:flex;flex-direction:column}.layout--mobile .studio-panel--params.is-active{overflow-y:auto;-webkit-overflow-scrolling:touch}.layout--mobile .inputs-panel-body{flex:none;overflow:visible}.layout--mobile .bed-custom-hint,.layout--mobile .param-clipboard-hint{display:none}.layout--mobile .field-row{grid-template-columns:repeat(2,1fr);gap:.35rem}.layout--mobile .panel-section-label{margin:.55rem 0 .3rem}.layout--mobile .main{flex:1;min-height:0;overflow:hidden}.layout--mobile .preview-chrome-hint{display:none}.layout--mobile .preview-wrap{flex:1;min-height:0;height:auto}.layout--mobile .studio-export{flex:1;min-height:0;overflow:visible}.layout--mobile .actions-bar{flex:1;min-height:0;overflow:visible;border-top:none;box-shadow:none;padding:.55rem .65rem;gap:.5rem}.layout--mobile .actions-bar-main{flex-direction:column;align-items:stretch;gap:.55rem}.layout--mobile .cell-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem;align-items:stretch}.layout--mobile .actions-label{grid-column:1 / -1;margin:0 0 .15rem}.layout--mobile .cell-btn{width:100%;text-align:left;padding:.35rem .45rem;font-size:.68rem;line-height:1.25}.layout--mobile .download-btns,.layout--mobile .download-btns .btn{width:100%}.layout--mobile .cell-split-group{gap:.35rem}.layout--mobile .cell-split{padding-top:.35rem;gap:.35rem}.layout--mobile .cell-color-picker{padding:.4rem 0 .45rem;gap:.35rem}}.admin-shell{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:220px 1fr;background:var(--bg);color:var(--text)}.admin-sidebar{display:flex;flex-direction:column;gap:1rem;padding:1rem .85rem;border-right:1px solid var(--border);background:var(--bg-subtle)}.admin-sidebar-brand{display:flex;flex-direction:column;gap:.35rem;padding:0 .35rem}.admin-sidebar-label{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand)}.admin-nav{display:flex;flex-direction:column;gap:.25rem}.admin-nav-link{display:block;padding:.55rem .7rem;border-radius:var(--radius-sm);color:var(--text-muted);text-decoration:none;font-size:.82rem;font-weight:600}.admin-nav-link:hover,.admin-nav-link.active{background:var(--brand-muted);color:var(--brand)}.admin-sidebar-foot{margin-top:auto}.admin-main-wrap{display:flex;flex-direction:column;min-width:0}.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.25rem;border-bottom:1px solid var(--border);background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.admin-topbar-title{margin:0;font-size:1rem;font-weight:700}.admin-topbar-actions{display:flex;align-items:center;gap:.5rem}.admin-main{padding:1.25rem;overflow:auto}.admin-dashboard,.admin-users{display:grid;gap:1rem}.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.85rem}.admin-stat-card{padding:1rem 1.1rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.admin-stat-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.35rem}.admin-stat-value{font-size:1.75rem;line-height:1;letter-spacing:-.02em}.admin-panel{padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated)}.admin-panel h2{margin:0 0 .85rem;font-size:.95rem}.admin-panel-head{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.admin-panel-head h2{margin:0}.admin-table-wrap{overflow:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.8rem}.admin-table th,.admin-table td{padding:.55rem .65rem;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{color:var(--text-muted);font-weight:600;font-size:.72rem}.admin-role-badge{display:inline-flex;padding:.15rem .45rem;border-radius:999px;font-size:.68rem;font-weight:700;background:var(--btn-secondary-bg);color:var(--text-muted)}.admin-role-badge--admin{background:var(--brand-muted);color:var(--brand)}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem}.admin-muted{color:var(--text-muted);font-size:.82rem}.admin-error{margin:0 0 .75rem;color:var(--badge-warn-text);font-size:.82rem}.admin-loading{min-height:40vh;display:grid;place-items:center}.admin-loading-spinner{width:1.5rem;height:1.5rem;border-radius:50%;border:2px solid var(--border-input);border-top-color:var(--brand);animation:admin-spin .8s linear infinite}@keyframes admin-spin{to{transform:rotate(360deg)}}@media (max-width: 900px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{border-right:none;border-bottom:1px solid var(--border)}.admin-nav{flex-direction:row;flex-wrap:wrap}}.auth-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);color:var(--text)}.auth-main{flex:1;display:grid;place-items:center;padding:2rem 1.25rem 3rem}.auth-card{width:min(420px,100%);padding:1.75rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-md)}.auth-card h1{margin:0 0 .35rem;font-size:1.5rem;letter-spacing:-.02em}.auth-card-subtitle{margin:0 0 1.25rem;color:var(--text-muted);font-size:.88rem;line-height:1.5}.auth-form{display:grid;gap:.9rem}.auth-field{display:grid;gap:.35rem}.auth-field span{font-size:.78rem;font-weight:600;color:var(--text-muted)}.auth-field-label-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.auth-forgot-link{font-size:.72rem;font-weight:600;color:var(--brand);text-decoration:none}.auth-forgot-link:hover{text-decoration:underline}.auth-field input{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--bg-input);color:var(--text);padding:.55rem .7rem;font:inherit}.auth-field input:focus{outline:2px solid var(--brand-muted);border-color:var(--brand)}.auth-error{margin:0;font-size:.8rem;color:var(--badge-warn-text)}.auth-success{margin:0;font-size:.8rem;color:var(--brand)}.auth-submit{margin-top:.25rem;width:100%}.auth-switch{margin:1rem 0 0;text-align:center;font-size:.82rem;color:var(--text-muted)}.auth-switch a{color:var(--brand);font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.auth-menu{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.auth-menu--compact .auth-menu-register,.auth-menu--compact .auth-menu-logout{padding:.35rem .65rem;font-size:.72rem;white-space:nowrap}.auth-menu-link{font-size:.78rem;font-weight:600;color:var(--text-muted);text-decoration:none;white-space:nowrap;flex-shrink:0}.auth-menu-account{max-width:6rem;overflow:hidden;text-overflow:ellipsis}.auth-menu-logout{display:inline-flex;align-items:center;gap:.3rem;flex-shrink:0}.auth-menu-logout-icon{display:none;font-size:.95rem;line-height:1}.auth-menu-link:hover{color:var(--brand)}.auth-menu-user{max-width:10rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;font-weight:600;color:var(--text-muted)}.auth-menu-loading{font-size:.75rem;color:var(--text-faint)}.marketing-header-actions .auth-menu .btn,.header-actions .auth-menu .btn{text-decoration:none;display:inline-flex;align-items:center}@media (max-width: 640px){.auth-menu--compact .auth-menu-link--nav{display:none}.auth-menu--compact .auth-menu-account{max-width:4.5rem}.auth-menu--compact .auth-menu-logout-label--en{display:none}.auth-menu--compact .auth-menu-logout-icon{display:inline}.auth-menu--compact .auth-menu-logout{padding:.35rem .5rem;min-width:2.1rem;justify-content:center}}.home-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);color:var(--text)}.home-container{width:min(1120px,100% - 2.5rem);margin-inline:auto}.marketing-header{position:sticky;top:0;z-index:30;border-bottom:1px solid var(--border);background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.marketing-header-inner{display:flex;align-items:center;gap:1rem;padding:.85rem 1.25rem;max-width:1200px;margin-inline:auto}.marketing-nav{display:none;align-items:center;gap:1.25rem;flex:1;margin-left:.5rem}.marketing-nav a{font-size:.82rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .15s}.marketing-nav a:hover{color:var(--brand)}.marketing-header-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}@media (max-width: 640px){.marketing-header-inner{flex-wrap:wrap;row-gap:.45rem;padding:.55rem .75rem;gap:.5rem}.marketing-header-actions{width:100%;margin-left:0;justify-content:flex-end;flex-wrap:nowrap;gap:.35rem}}.marketing-cta{display:none;text-decoration:none;white-space:nowrap}.home-hero{position:relative;overflow:hidden;padding:3.5rem 0 2rem}.home-hero-glow{position:absolute;inset:-20% 10% auto;height:420px;background:radial-gradient(ellipse at center,rgba(20,184,166,.18) 0%,rgba(99,102,241,.08) 45%,transparent 70%);pointer-events:none}.home-hero-inner{position:relative;display:grid;gap:2rem}.home-badge{display:inline-flex;align-items:center;width:fit-content;padding:.3rem .75rem;border-radius:999px;font-size:.72rem;font-weight:600;color:var(--brand);background:var(--brand-muted);border:1px solid transparent}.home-hero-title{margin:0;font-size:clamp(2rem,5vw,3.25rem);line-height:1.1;letter-spacing:-.03em;font-weight:700;max-width:14ch}.home-hero-subtitle{margin:0;max-width:52ch;font-size:1.05rem;line-height:1.65;color:var(--text-muted)}.home-hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.home-hero-visual{display:grid;grid-template-columns:1fr 1.2fr;gap:1rem;align-items:stretch}.home-mock-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem;padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-md)}.home-mock-grid span{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-input)}.home-mock-grid span.accent{background:var(--brand-muted);border-color:#14b8a659}.home-mock-panel{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:linear-gradient(160deg,var(--bg-elevated),var(--bg-card));box-shadow:var(--shadow-md)}.home-mock-bar{height:10px;width:45%;border-radius:999px;background:var(--border-input)}.home-mock-preview{flex:1;min-height:160px;border-radius:var(--radius);background:linear-gradient(135deg,#14b8a61f,#6366f11a),var(--bg-subtle);border:1px dashed var(--border-hover)}.home-section{padding:3.5rem 0}.home-section--muted{background:var(--bg-subtle);border-block:1px solid var(--border)}.home-section-head{text-align:center;max-width:42rem;margin:0 auto 2rem}.home-section-head h2{margin:0 0 .5rem;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.02em}.home-section-head p{margin:0;color:var(--text-muted);line-height:1.6}.home-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.home-feature-card{padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.home-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:var(--radius-sm);background:var(--brand-muted);color:var(--brand);font-size:1rem;margin-bottom:.75rem}.home-feature-card h3{margin:0 0 .4rem;font-size:1rem}.home-feature-card p{margin:0;font-size:.85rem;line-height:1.55;color:var(--text-muted)}.home-steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.home-steps li{display:flex;align-items:center;gap:.85rem;padding:1rem 1.15rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);font-weight:500}.home-step-num{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;background:var(--brand-gradient);color:#fff;font-size:.78rem;font-weight:700;flex-shrink:0}.home-roadmap-grid,.home-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.home-roadmap-card,.home-price-card{position:relative;padding:1.35rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated)}.home-roadmap-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.home-roadmap-icon{font-size:1.35rem}.home-soon-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .5rem;border-radius:999px;background:var(--badge-warn-bg);color:var(--badge-warn-text)}.home-soon-badge--corner{position:absolute;top:1rem;right:1rem}.home-roadmap-card h3,.home-price-card h3{margin:0 0 .35rem;font-size:1.05rem}.home-roadmap-card p,.home-price-desc{margin:0;font-size:.85rem;line-height:1.55;color:var(--text-muted)}.home-price-card--pro{border-color:#14b8a659;box-shadow:var(--shadow-brand)}.home-price-amount{margin:.5rem 0;font-size:2rem;font-weight:700;letter-spacing:-.02em;background:var(--brand-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}.home-price-card ul{margin:1rem 0 1.25rem;padding-left:1.1rem;color:var(--text-muted);font-size:.85rem;line-height:1.7}.home-price-card .btn{width:100%;text-align:center;text-decoration:none;display:inline-block;box-sizing:border-box}.home-cta-band{padding:3rem 0 4rem}.home-cta-inner{text-align:center;padding:2.5rem 1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:linear-gradient(135deg,#14b8a614,#6366f10f),var(--bg-elevated);box-shadow:var(--shadow-md)}.home-cta-inner h2{margin:0 0 .5rem;font-size:clamp(1.35rem,3vw,1.85rem)}.home-cta-inner p{margin:0 0 1.25rem;color:var(--text-muted)}.home-cta-inner .btn{text-decoration:none}.marketing-footer{margin-top:auto;border-top:1px solid var(--border);background:var(--bg-subtle);padding:2rem 1.25rem}.marketing-footer-inner{max-width:1120px;margin-inline:auto;display:grid;gap:1.25rem}.marketing-footer-name{font-weight:700;font-size:.95rem}.marketing-footer-tagline{display:block;margin-top:.2rem;font-size:.8rem;color:var(--text-muted)}.marketing-footer-links{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem}.marketing-footer-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint)}.marketing-footer-links a{font-size:.82rem;color:var(--text-muted);text-decoration:none}.marketing-footer-links a:hover{color:var(--brand)}.marketing-footer-copy{margin:0;font-size:.75rem;color:var(--text-faint)}.home-page .btn{font-family:inherit;font-weight:600;font-size:.82rem;border-radius:var(--radius-sm);padding:.55rem 1.1rem;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s,border-color .15s,color .15s;border:none}.home-page .btn-lg{padding:.7rem 1.35rem;font-size:.9rem}.home-page .btn-primary{background:var(--brand-gradient);color:#fff;box-shadow:var(--shadow-brand)}.home-page .btn-primary:hover{filter:brightness(1.06)}.home-page .btn-secondary{background:var(--btn-secondary-bg);color:var(--text);border:1px solid var(--border-input)}.home-page .btn-secondary:hover{border-color:var(--brand);color:var(--brand)}@media (min-width: 768px){.marketing-nav{display:flex}.marketing-cta{display:inline-flex;align-items:center}.home-hero-inner{grid-template-columns:1fr 1fr;align-items:center}.home-hero-actions,.home-badge,.home-hero-title,.home-hero-subtitle{grid-column:1}.home-hero-visual{grid-column:2;grid-row:1 / span 4}}@media (max-width: 767px){.home-hero-visual{grid-template-columns:1fr}}.projects-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text)}.projects-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface)}.projects-topbar-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.projects-main{flex:1;width:min(960px,100%);margin:0 auto;padding:2rem 1.25rem 3rem}.projects-head{margin-bottom:1.5rem}.projects-head h1{margin:0 0 .35rem;font-size:1.75rem}.projects-subtitle{margin:0;color:var(--muted)}.projects-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1rem}.projects-panel h2{margin:0 0 1rem;font-size:1.1rem}.projects-panel-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1rem}.projects-panel-head h2{margin:0}.projects-create-form{display:flex;gap:.75rem;flex-wrap:wrap}.projects-input{flex:1 1 240px;min-width:0;padding:.55rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text)}.projects-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.projects-item{display:flex;align-items:center;gap:.75rem;border:1px solid var(--border);border-radius:10px;background:var(--bg)}.projects-item-link{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem;padding:.85rem 1rem;text-decoration:none;color:inherit}.projects-item-link:hover .projects-item-name{color:var(--accent)}.projects-item-name{font-weight:600}.projects-item-meta{font-size:.85rem;color:var(--muted)}.projects-delete{margin-right:.75rem}.projects-muted{color:var(--muted)}.projects-error{color:var(--danger, #c0392b);margin:0 0 1rem}.project-save-status{font-size:.85rem;color:var(--muted)}.project-save-status--saved{color:var(--success, #2ecc71)}.project-save-status--error{color:var(--danger, #c0392b)}.project-name-field{display:flex;align-items:center;gap:.5rem}.project-name-input{width:min(220px,40vw);padding:.35rem .55rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:.9rem}*{box-sizing:border-box}:root,[data-theme=dark]{--brand: #14b8a6;--brand-strong: #0d9488;--brand-muted: rgba(20, 184, 166, .15);--brand-gradient: linear-gradient(135deg, #14b8a6 0%, #6366f1 100%);--bg: #080d1a;--bg-subtle: #0c1222;--bg-elevated: #121a2e;--bg-input: #0a1020;--bg-card: #0e1528;--bg-card-active: #132238;--text: #f1f5f9;--text-muted: #8b9cb8;--text-faint: #5c6b88;--border: rgba(148, 163, 184, .12);--border-input: rgba(148, 163, 184, .22);--border-hover: rgba(148, 163, 184, .38);--accent: #2dd4bf;--accent-bg: #0d9488;--accent-hover: #0f766e;--btn-secondary-bg: #1a2438;--badge-ok-bg: rgba(34, 197, 94, .18);--badge-ok-text: #4ade80;--badge-warn-bg: rgba(245, 158, 11, .18);--badge-warn-text: #fbbf24;--cell-tag-bg: #1a2438;--preview-overlay: rgba(8, 13, 26, .72);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 8px 24px rgba(0, 0, 0, .4);--shadow-brand: 0 4px 20px rgba(20, 184, 166, .2);--radius: 10px;--radius-sm: 6px;--radius-lg: 14px;--header-bg: rgba(12, 18, 34, .85)}[data-theme=light]{--brand: #0d9488;--brand-strong: #0f766e;--brand-muted: rgba(13, 148, 136, .1);--brand-gradient: linear-gradient(135deg, #0d9488 0%, #4f46e5 100%);--bg: #eef2f7;--bg-subtle: #f8fafc;--bg-elevated: #ffffff;--bg-input: #ffffff;--bg-card: #f8fafc;--bg-card-active: #ecfdf5;--text: #0f172a;--text-muted: #64748b;--text-faint: #94a3b8;--border: rgba(15, 23, 42, .08);--border-input: #e2e8f0;--border-hover: #cbd5e1;--accent: #0d9488;--accent-bg: #0d9488;--accent-hover: #0f766e;--btn-secondary-bg: #f1f5f9;--badge-ok-bg: #dcfce7;--badge-ok-text: #15803d;--badge-warn-bg: #fef3c7;--badge-warn-text: #b45309;--cell-tag-bg: #e2e8f0;--preview-overlay: rgba(255, 255, 255, .88);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 8px 24px rgba(15, 23, 42, .08);--shadow-brand: 0 4px 20px rgba(13, 148, 136, .15);--header-bg: rgba(255, 255, 255, .9)}html,body,#root{margin:0;min-height:100%;font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text)}body.route-studio{height:100%;overflow:hidden}body.route-studio #root{height:100%}body.route-admin{overflow:auto}::selection{background:var(--brand-muted);color:var(--text)}
