:root,[data-theme=light]{--paper: #FFFFFF;--paper-tint: #FAFAFA;--paper-deep: #F4F4F5;--surface: #FFFFFF;--surface-2: #FAFAFA;--surface-hi: #F4F4F5;--rule: #E5E6E7;--rule-soft: #EFEFF0;--ink: #0F0F10;--ink-2: #1F1F22;--muted: #62666D;--muted-2: #8A8F98;--accent: #5E6AD2;--accent-deep: #4F58B8;--accent-tint: #EEF0FB;--accent-on: #FFFFFF;--warn: #C2410C;--warn-tint: #FFEBE0;--good: #2F7E47;--good-tint: #E5F2EA;--primary: #0F0F10;--primary-on: #FFFFFF;--primary-hover: #28282D;--backdrop: rgba(15, 15, 16, .4);--shadow-color: 9, 9, 11}[data-theme=dark]{--paper: #08090A;--paper-tint: #0E0F11;--paper-deep: #131416;--surface: #0E0F11;--surface-2: #16181A;--surface-hi: #1B1D20;--rule: #1F2023;--rule-soft: #16181A;--ink: #F7F8F8;--ink-2: #E5E5E7;--muted: #8A8F98;--muted-2: #62666D;--accent: #7B82E0;--accent-deep: #9499E8;--accent-tint: #1A1C32;--accent-on: #0F0F10;--warn: #FF7A5C;--warn-tint: #2A1812;--good: #4CC38A;--good-tint: #0E251A;--primary: #FFFFFF;--primary-on: #0F0F10;--primary-hover: #E5E5E7;--backdrop: rgba(0, 0, 0, .6);--shadow-color: 0, 0, 0}:root{--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--shadow-sm: 0 1px 2px rgba(var(--shadow-color), .04);--shadow-md: 0 1px 0 rgba(var(--shadow-color), .04), 0 4px 16px rgba(var(--shadow-color), .08);--shadow-lg: 0 12px 40px rgba(var(--shadow-color), .16), 0 4px 12px rgba(var(--shadow-color), .08);--radius-sm: 4px;--radius: 6px;--radius-lg: 8px;--t-fast: .1s;--t-base: .16s;--t-slow: .24s;--ease: cubic-bezier(.2, .6, .2, 1)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}html,body{background:var(--paper);color:var(--ink);transition:background-color var(--t-base) var(--ease),color var(--t-base) var(--ease)}body{font-family:var(--font-sans);font-size:13px;line-height:1.5;font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;font-size:inherit;cursor:pointer;white-space:nowrap!important;min-width:max-content;word-break:keep-all;overflow-wrap:normal;flex-shrink:0;letter-spacing:-.005em}button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px}input,textarea{font-family:var(--font-sans);font-size:13px;color:var(--ink);background:var(--surface)}textarea{resize:vertical}code{font-family:var(--font-mono);font-size:12px}.app{position:relative;display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app__main{display:grid;grid-template-columns:minmax(440px,46%) 1fr;flex:1 1 0;min-height:0;border-top:1px solid var(--rule)}@media (max-width: 1100px){.app__main{grid-template-columns:1fr}}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px;background:var(--surface);border-bottom:1px solid var(--rule);position:relative;z-index:5;height:48px}.toolbar__brand{display:flex;align-items:center;gap:12px}.toolbar__brand:before{content:"";width:18px;height:18px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--accent-deep))}.toolbar__title{font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:-.01em;color:var(--ink);margin:0}.toolbar__subtitle{font-family:var(--font-mono);font-size:11px;letter-spacing:0;color:var(--muted-2)}.toolbar__actions{display:flex;align-items:center;gap:4px}.btn{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border:1px solid transparent;background:transparent;color:var(--ink-2);font-weight:500;font-size:12.5px;letter-spacing:-.005em;border-radius:var(--radius);transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease)}.btn:hover:not(:disabled){background:var(--surface-hi);color:var(--ink)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--bordered{border-color:var(--rule);background:var(--surface)}.btn--bordered:hover:not(:disabled){border-color:var(--muted-2);background:var(--surface)}.btn--primary{background:var(--primary);border-color:var(--primary);color:var(--primary-on);box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover);color:var(--primary-on)}.btn--accent{background:var(--accent);border-color:var(--accent);color:var(--accent-on);box-shadow:var(--shadow-sm)}.btn--accent:hover:not(:disabled){background:var(--accent-deep);border-color:var(--accent-deep)}.btn__hint{font-family:var(--font-mono);font-size:11px;letter-spacing:0;margin-left:4px;opacity:.6}.btn__icon{margin-right:2px;flex-shrink:0}.btn--cta{position:relative;font-weight:600}.btn--cta-ready{box-shadow:var(--shadow-sm),0 0 color-mix(in srgb,var(--primary) 45%,transparent);animation:cta-halo 2.6s ease-in-out infinite}@keyframes cta-halo{0%,to{box-shadow:var(--shadow-sm),0 0 color-mix(in srgb,var(--primary) 40%,transparent)}50%{box-shadow:var(--shadow-sm),0 0 0 6px color-mix(in srgb,var(--primary) 0%,transparent)}}@media (prefers-reduced-motion: reduce){.btn--cta-ready{animation:none;box-shadow:var(--shadow-sm),0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}}.previews-dropdown{position:relative;display:inline-flex}.previews-dropdown__chevron{margin-left:2px;opacity:.7}.previews-dropdown__menu{position:absolute;top:calc(100% + 4px);right:0;min-width:200px;padding:4px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow-sm);z-index:20;display:flex;flex-direction:column;gap:1px}.previews-dropdown__item{display:flex;align-items:center;height:28px;padding:0 10px;font-family:var(--font-sans);font-size:12.5px;font-weight:500;letter-spacing:-.005em;color:var(--ink-2);text-decoration:none;border-radius:var(--radius-sm, 4px);transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}.previews-dropdown__item:hover{background:var(--surface-hi);color:var(--ink)}.status{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 8px;font-family:var(--font-sans);font-size:11.5px;font-weight:500;letter-spacing:-.005em;color:var(--muted);border:1px solid var(--rule);border-radius:var(--radius);background:transparent}.status__dot{width:6px;height:6px;border-radius:50%;background:var(--muted-2)}.status--saved{color:var(--good);border-color:color-mix(in srgb,var(--good) 30%,var(--rule));background:var(--good-tint)}.status--saved .status__dot{background:var(--good)}.status--dirty{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 30%,var(--rule));background:var(--warn-tint)}.status--dirty .status__dot{background:var(--warn);animation:pulse 1.6s ease-in-out infinite}.status--working{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,var(--rule));background:var(--accent-tint)}.status--working .status__dot{background:var(--accent);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.banner{position:absolute;top:48px;left:0;right:0;z-index:4;display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--warn-tint);border-bottom:1px solid color-mix(in srgb,var(--warn) 25%,transparent);color:var(--warn);font-size:12.5px;font-weight:500;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);will-change:transform,opacity}.banner--open{animation:banner-in .28s cubic-bezier(.22,1,.36,1) both}.banner--closing{animation:banner-out .22s cubic-bezier(.4,0,1,1) both}@keyframes banner-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes banner-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}@media (prefers-reduced-motion: reduce){.banner--open,.banner--closing{animation-duration:1ms}}.banner__rule{width:2px;height:14px;background:var(--warn);border-radius:1px}.banner__count{font-family:var(--font-mono);font-size:11px;background:color-mix(in srgb,var(--warn) 18%,transparent);padding:2px 7px;border-radius:99px;color:var(--warn)}.banner__spacer{flex:1}.editor{background:var(--paper);overflow-y:auto;border-right:1px solid var(--rule);position:relative;min-height:0}.editor__inner{max-width:720px;margin:0 auto;padding:24px 24px 96px}.editor__intro{display:flex;flex-direction:column;gap:6px;padding:0 0 16px;border-bottom:1px solid var(--rule);margin-bottom:20px}.editor__intro h2{font-family:var(--font-sans);font-size:18px;font-weight:600;letter-spacing:-.02em;margin:0;color:var(--ink)}.editor__intro p{margin:0;color:var(--muted);font-size:12.5px;max-width:64ch;line-height:1.55}.group{margin-bottom:20px}.group__head{position:sticky;top:0;z-index:2;display:flex;align-items:center;gap:8px;padding:10px 8px 8px;margin:0 -8px;background:var(--paper);border-bottom:1px solid var(--rule);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--radius) var(--radius) 0 0;transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),opacity var(--t-slow) var(--ease)}.editor__inner:has(.group--open) .group--collapsed .group__head{opacity:.25}.group__head:hover{background:var(--surface-hi)}.group--open .group__head{border-bottom-color:color-mix(in srgb,var(--accent) 35%,var(--rule))}.group__chevron{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;color:var(--muted-2)}.group__chevron-svg{display:block;transition:transform var(--t-base) var(--ease)}.group--collapsed .group__chevron-svg{transform:rotate(-90deg)}.group--open .group__chevron{color:var(--accent)}.group__label{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);transition:color var(--t-fast) var(--ease)}.group--open .group__label{color:var(--accent)}.group__count{font-family:var(--font-mono);font-size:10.5px;color:var(--muted-2);letter-spacing:0;margin-left:auto}.group__body{display:grid;grid-template-rows:1fr;transition:grid-template-rows var(--t-slow) var(--ease)}.group--collapsed .group__body{grid-template-rows:0fr}.group__body-inner{min-height:0;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--rule);border-top:0;border-radius:0 0 var(--radius) var(--radius);transition:border-color var(--t-slow) var(--ease)}.group--collapsed .group__body-inner{border-color:transparent}.group__top-action{display:flex;align-items:center;justify-content:flex-start;padding:10px 12px;border-bottom:1px solid var(--rule-soft);background:var(--surface-2)}.group__action-btn{align-self:flex-start;height:34px;padding:0 14px;background:var(--surface);border-color:var(--rule);box-shadow:var(--shadow-sm);font-weight:600}.group__action-btn:hover:not(:disabled){background:var(--surface-hi);border-color:var(--muted-2)}.subgroup{background:var(--surface);border-top:1px solid var(--rule)}.subgroup:first-child{border-top:0}.subgroup__head{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--t-fast) var(--ease),opacity var(--t-slow) var(--ease)}.subgroup__head:hover{background:var(--surface-hi)}.subgroup__index{font-family:var(--font-mono);font-size:10.5px;color:var(--muted-2);letter-spacing:0;width:18px}.subgroup__label{font-family:var(--font-sans);font-size:12.5px;font-weight:500;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.005em}.subgroup__chevron{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;color:var(--muted-2)}.subgroup__chevron .group__chevron-svg{transition:transform var(--t-base) var(--ease)}.subgroup--collapsed .subgroup__chevron .group__chevron-svg{transform:rotate(-90deg)}.subgroup:not(.subgroup--collapsed) .subgroup__label,.subgroup:not(.subgroup--collapsed) .subgroup__index{color:var(--accent)}.subgroup:not(.subgroup--collapsed) .subgroup__chevron{color:var(--accent)}.group__body-inner:has(>.subgroup:not(.subgroup--collapsed))>.subgroup--collapsed>.subgroup__head,.subgroup__body-inner:has(>.subgroup:not(.subgroup--collapsed))>.subgroup--collapsed>.subgroup__head{opacity:.2}.subgroup__body{display:grid;grid-template-rows:1fr;transition:grid-template-rows var(--t-slow) var(--ease)}.subgroup--collapsed .subgroup__body{grid-template-rows:0fr}.subgroup__body-inner{min-height:0;overflow:hidden;display:flex;flex-direction:column;border-top:1px solid var(--rule-soft)}.subgroup--collapsed .subgroup__body-inner{border-top-color:transparent}.field{background:var(--surface);padding:10px 12px 12px;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--rule-soft);transition:background var(--t-fast) var(--ease)}.field:first-child{border-top:0}.field--dirty{background:color-mix(in srgb,var(--warn-tint) 60%,var(--surface))}.field__head{display:flex;align-items:center;gap:8px}.field__label{font-family:var(--font-sans);font-size:11px;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);font-weight:600}.field--dirty .field__label{color:var(--warn)}.field__kind{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:var(--muted-2);letter-spacing:0;padding:1px 6px;border-radius:var(--radius-sm);background:var(--paper-deep)}.field__input,.field__textarea{width:100%;border:1px solid var(--rule);border-radius:var(--radius);padding:7px 10px;background:var(--surface);color:var(--ink);font-size:13px;line-height:1.5;letter-spacing:-.005em;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}.field__input:focus,.field__textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.field__textarea{font-family:var(--font-sans);min-height:56px}.field__url{font-family:var(--font-mono);font-size:12px;color:var(--accent)}.preview{display:flex;flex-direction:column;background:var(--paper-deep);min-width:0;min-height:0}.preview__head{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--surface);border-bottom:1px solid var(--rule);font-family:var(--font-sans);font-size:11.5px;letter-spacing:-.005em;color:var(--muted);height:40px}.preview__head-title{display:flex;align-items:center;gap:7px;color:var(--ink);font-weight:500}.preview__head-dot{width:6px;height:6px;border-radius:50%;background:var(--good)}.preview__path{font-family:var(--font-mono);color:var(--muted-2);font-size:11px}.preview__resolution{font-family:var(--font-mono);color:var(--muted-2);font-size:11px;padding:2px 6px;border:1px solid var(--rule);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums}.preview__spacer{flex:1}.preview__refresh{background:transparent;border:1px solid var(--rule);color:var(--muted);height:24px;padding:0 8px;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:11px;letter-spacing:-.005em;font-weight:500;transition:border-color var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}.preview__refresh:hover{color:var(--ink);border-color:var(--muted-2)}.preview__stage{flex:1;min-height:0;overflow:hidden;background:var(--surface);position:relative}.preview__frame{border:0;background:var(--surface);display:block}.preview__build-log{max-height:140px;overflow-y:auto;border-top:1px solid var(--rule);padding:8px 16px;font-family:var(--font-mono);font-size:11px;color:var(--muted);background:var(--surface-2);white-space:pre-wrap;display:none}.preview__build-log--open{display:block}.preview__build-log--err{color:var(--warn)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:20;opacity:0;pointer-events:none;transition:opacity var(--t-base) var(--ease)}.drawer-overlay--open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;height:100vh;width:min(420px,100vw);background:var(--surface);border-left:1px solid var(--rule);box-shadow:var(--shadow-lg);z-index:21;transform:translate(100%);transition:transform var(--t-slow) var(--ease);display:flex;flex-direction:column}.drawer--open{transform:translate(0)}.drawer__head{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--rule);height:48px}.drawer__title{font-family:var(--font-sans);font-size:13px;font-weight:600;letter-spacing:-.01em;margin:0;color:var(--ink)}.drawer__hint{font-family:var(--font-mono);font-size:11px;letter-spacing:0;color:var(--muted-2)}.drawer__close{margin-left:auto;background:transparent;border:0;color:var(--muted-2);font-size:16px;line-height:1;padding:4px 8px;border-radius:var(--radius-sm);transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}.drawer__close:hover{color:var(--ink);background:var(--surface-hi)}.drawer__list{flex:1;overflow-y:auto;padding:4px;margin:0;list-style:none}.version{padding:10px 12px;margin-bottom:1px;border-radius:var(--radius);border:1px solid transparent;display:flex;flex-direction:column;gap:3px;transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease)}.version:hover{background:var(--surface-hi)}.version--active{background:var(--accent-tint);border-color:color-mix(in srgb,var(--accent) 30%,var(--rule))}.version__head{display:flex;align-items:center;gap:10px}.version__name{font-family:var(--font-sans);font-size:12.5px;font-weight:500;color:var(--ink);letter-spacing:-.005em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.version__name--unnamed{font-style:italic;color:var(--muted);font-weight:400}.version__stamp{font-family:var(--font-mono);font-size:11px;color:var(--muted-2);letter-spacing:0}.version__rel{font-family:var(--font-sans);font-size:11px;color:var(--muted);flex-shrink:0}.version__meta{display:flex;align-items:center;gap:5px;flex-shrink:0}.version__badge{height:18px;padding:0 6px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 38%,var(--rule));background:var(--surface);color:var(--accent);font-family:var(--font-sans);font-size:10.5px;font-weight:600;line-height:16px;letter-spacing:0;white-space:nowrap}.version__badge--dirty{border-color:color-mix(in srgb,var(--warn) 42%,var(--rule));background:color-mix(in srgb,var(--warn) 10%,var(--surface));color:var(--warn)}.version__actions{display:flex;gap:6px;margin-top:4px}.version__btn{height:24px;padding:0 10px;font-size:11.5px;font-weight:500;letter-spacing:-.005em;border:1px solid var(--rule);background:var(--surface);color:var(--ink-2);border-radius:var(--radius-sm);transition:all var(--t-fast) var(--ease)}.version__btn:hover{background:var(--accent-tint);border-color:color-mix(in srgb,var(--accent) 40%,var(--rule));color:var(--accent)}.version__btn--danger{color:var(--warn)}.version__btn--danger:hover:not(:disabled){background:color-mix(in srgb,var(--warn) 12%,transparent);border-color:color-mix(in srgb,var(--warn) 50%,var(--rule));color:var(--warn)}.version__btn:disabled{opacity:.55;cursor:not-allowed}.version__empty{padding:32px 16px;text-align:center;color:var(--muted);font-size:12.5px}.divider{width:1px;height:16px;background:var(--rule);margin:0 4px}.kbd{font-family:var(--font-mono);font-size:10.5px;background:var(--paper-deep);border:1px solid var(--rule);padding:1px 5px;border-radius:var(--radius-sm);color:var(--muted)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;height:28px;width:28px;padding:0;background:transparent;border:1px solid var(--rule);border-radius:var(--radius);color:var(--muted);cursor:pointer;transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease)}.theme-toggle:hover{background:var(--surface-hi);color:var(--ink);border-color:var(--muted-2)}.theme-toggle__icon{width:14px;height:14px;display:block}.editor::-webkit-scrollbar,.drawer__list::-webkit-scrollbar,.preview__build-log::-webkit-scrollbar{width:8px;height:8px}.editor::-webkit-scrollbar-thumb,.drawer__list::-webkit-scrollbar-thumb,.preview__build-log::-webkit-scrollbar-thumb{background:var(--rule);border-radius:4px}.editor::-webkit-scrollbar-thumb:hover,.drawer__list::-webkit-scrollbar-thumb:hover,.preview__build-log::-webkit-scrollbar-thumb:hover{background:var(--muted-2)}.editor::-webkit-scrollbar-track,.drawer__list::-webkit-scrollbar-track,.preview__build-log::-webkit-scrollbar-track{background:transparent}.btn,.modal__close,.drawer__close,.theme-toggle,.preview__refresh,.version__btn{white-space:nowrap!important;min-width:max-content;word-break:keep-all;overflow-wrap:normal;flex-shrink:0}.btn--ghost-warn{color:var(--warn);background:transparent;border-color:color-mix(in srgb,var(--warn) 22%,transparent)}.btn--ghost-warn:hover:not(:disabled){background:color-mix(in srgb,var(--warn) 12%,transparent);border-color:color-mix(in srgb,var(--warn) 38%,transparent);color:var(--warn)}.btn--ghost-warn:focus-visible{outline:2px solid color-mix(in srgb,var(--warn) 55%,transparent);outline-offset:1px}.btn--danger{background:var(--warn);border-color:var(--warn);color:#fff;box-shadow:var(--shadow-sm)}.btn--danger:hover:not(:disabled){background:color-mix(in srgb,var(--warn) 88%,#000);border-color:color-mix(in srgb,var(--warn) 88%,#000);color:#fff}.modal-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--backdrop);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;will-change:opacity}.modal-backdrop.is-open{animation:modal-backdrop-in .3s cubic-bezier(.2,.6,.2,1) forwards}.modal-backdrop.is-closing{animation:modal-backdrop-out .25s cubic-bezier(.2,.6,.2,1) forwards}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-backdrop-out{0%{opacity:1}to{opacity:0}}.modal-positioner{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:none}.modal{pointer-events:auto;width:min(440px,100%);background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;font-family:var(--font-sans);color:var(--ink);will-change:transform,opacity;transform-origin:50% 60%}.modal.is-open{animation:modal-in .3s cubic-bezier(.2,.6,.2,1) forwards}.modal.is-closing{animation:modal-out .25s cubic-bezier(.2,.6,.2,1) forwards}@keyframes modal-in{0%{opacity:0;transform:translateY(8px) scale(1)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modal-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(16px) scale(.95)}}@media (prefers-reduced-motion: reduce){.modal.is-open,.modal.is-closing,.modal-backdrop.is-open,.modal-backdrop.is-closing{animation-duration:1ms}}.modal__head{display:flex;align-items:flex-start;gap:16px;padding:20px 20px 0 24px}.modal__title{flex:1;margin:0;font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--ink);line-height:1.35}.modal__close{flex-shrink:0;background:transparent;border:0;color:var(--muted-2);width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;padding:0;margin:-4px -4px 0 0;border-radius:var(--radius-sm);transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease);cursor:pointer}.modal__close:hover{color:var(--ink);background:var(--surface-hi)}.modal__close:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.modal__body{padding:12px 24px 4px;font-size:13px;line-height:1.55;color:var(--muted);letter-spacing:-.005em}.modal__actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:20px 24px}.save-modal__body{padding:12px 24px 8px;display:flex;flex-direction:column;gap:10px}.save-modal__hint{margin:0;font-size:12.5px;line-height:1.5;color:var(--muted)}.save-modal__field-label{display:flex;align-items:center;gap:8px;font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:2px}.save-modal__required{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--warn);background:var(--warn-tint);padding:1px 6px;border-radius:var(--radius-sm)}.save-modal__input{width:100%;border:1px solid var(--rule);border-radius:var(--radius);padding:9px 12px;background:var(--surface);color:var(--ink);font-family:var(--font-sans);font-size:13px;line-height:1.4;letter-spacing:-.005em;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}.save-modal__input::placeholder{color:var(--muted-2)}.save-modal__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.save-modal__input:disabled{opacity:.6;cursor:not-allowed}.save-modal__meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:11px;color:var(--muted-2);letter-spacing:0;margin-top:2px}.save-modal__count--warn{color:var(--warn)}.hero-modal{width:min(720px,100%);max-height:min(80vh,720px);display:flex;flex-direction:column}.hero-modal__heading{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.hero-modal__warning{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--warn-tint);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);border-radius:var(--radius);color:var(--warn);animation:hero-warning-in .2s cubic-bezier(.2,.6,.2,1) both}@keyframes hero-warning-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.hero-modal__warning-badge{display:inline-flex;align-items:center;gap:5px;flex-shrink:0;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0;background:color-mix(in srgb,var(--warn) 18%,transparent);border:1px solid color-mix(in srgb,var(--warn) 38%,transparent);border-radius:var(--radius-sm);padding:2px 7px;text-transform:uppercase}.hero-modal__warning-text{font-size:12px;line-height:1.5;color:var(--warn);letter-spacing:-.005em;flex:1;min-width:0}.hero-modal__warning-text strong{font-family:var(--font-mono);font-weight:700;letter-spacing:0}.hero-modal__warning-text code{font-family:var(--font-mono);background:color-mix(in srgb,var(--warn) 14%,transparent);border:1px solid color-mix(in srgb,var(--warn) 28%,transparent);border-radius:var(--radius-sm);padding:0 5px;font-size:11px;color:var(--warn);word-break:break-word}.hero-modal__body{padding:12px 24px 4px;display:flex;flex-direction:column;gap:12px;min-height:0}.hero-modal__grid{list-style:none;margin:0;padding:4px 2px;display:grid;grid-template-columns:repeat(auto-fill,minmax(min(270px,100%),270px));justify-content:center;gap:10px;overflow-y:auto;max-height:460px}.hero-modal__grid::-webkit-scrollbar{width:8px}.hero-modal__grid::-webkit-scrollbar-thumb{background:var(--rule);border-radius:4px}.hero-modal__grid::-webkit-scrollbar-thumb:hover{background:var(--muted-2)}.hero-tile{display:flex;flex-direction:column;gap:6px;width:100%;min-width:0;padding:6px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius);text-align:left;white-space:normal!important;cursor:pointer;transition:border-color var(--t-fast) var(--ease),background var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}.hero-tile:hover:not(:disabled){border-color:var(--muted-2);background:var(--surface-hi)}.hero-tile:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero-tile:disabled{opacity:.55;cursor:not-allowed}.hero-tile--selected{border-color:var(--accent);background:var(--accent-tint);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.hero-tile--selected:hover:not(:disabled){border-color:var(--accent);background:var(--accent-tint)}.hero-tile--mismatch{border-color:color-mix(in srgb,var(--warn) 35%,var(--rule))}.hero-tile--mismatch.hero-tile--selected{border-color:var(--warn);background:var(--warn-tint);box-shadow:0 0 0 2px color-mix(in srgb,var(--warn) 35%,transparent)}.hero-tile__thumb{position:relative;display:block;width:100%;aspect-ratio:1 / 1;border-radius:var(--radius-sm);overflow:hidden;background:var(--paper-deep);border:1px solid var(--rule-soft)}.hero-tile__thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.hero-tile__badge{position:absolute;display:inline-flex;align-items:center;gap:4px;padding:2px 7px;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:0;border-radius:99px;border:1px solid transparent;pointer-events:none;white-space:nowrap;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.hero-tile__badge--current{top:6px;left:6px;background:color-mix(in srgb,var(--good) 88%,transparent);color:#fff;border-color:color-mix(in srgb,var(--good) 60%,transparent)}.hero-tile__badge--warn{top:6px;right:6px;background:color-mix(in srgb,var(--warn) 90%,transparent);color:#fff;border-color:color-mix(in srgb,var(--warn) 60%,transparent);text-transform:uppercase}.hero-tile__badge--warn svg{display:block}.hero-tile__name{font-family:var(--font-mono);font-size:11px;letter-spacing:0;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px 2px}.hero-tile--mismatch .hero-tile__name{color:var(--warn)}.hero-modal__meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--font-mono);font-size:11px;color:var(--muted-2);letter-spacing:0;border-top:1px solid var(--rule-soft);padding-top:8px}.hero-modal__selected code{color:var(--accent)}.hero-modal__empty{padding:36px 8px;text-align:center;color:var(--muted);font-size:12.5px;border:1px dashed var(--rule);border-radius:var(--radius)}.hero-modal__empty code{background:var(--paper-deep);border:1px solid var(--rule);border-radius:var(--radius-sm);padding:0 5px;font-size:11px;color:var(--ink-2)}.error-modal{width:min(480px,100%)}.error-modal__head{align-items:center}.error-modal__heading{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.error-modal__code{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0;color:var(--warn);background:var(--warn-tint);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);border-radius:var(--radius-sm);padding:2px 7px;text-transform:uppercase;flex-shrink:0}.error-modal__body{padding-bottom:8px}.error-modal__lede{margin:0 0 10px;font-size:13px;line-height:1.55;color:var(--ink-2);letter-spacing:-.005em}.error-modal__details{margin:0;font-family:var(--font-mono);font-size:11.5px;line-height:1.5;color:var(--muted);background:var(--paper-deep);border:1px solid var(--rule);border-radius:var(--radius-sm);padding:8px 10px;white-space:pre-wrap;word-break:break-word;letter-spacing:0}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--paper);padding:24px}.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius);padding:28px 28px 24px;display:flex;flex-direction:column;gap:14px;box-shadow:0 1px 2px rgba(var(--shadow-color),.04),0 8px 24px rgba(var(--shadow-color),.06)}.login-card__head{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.login-card__title{margin:0;font-family:var(--font-sans);font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.login-card__hint{margin:0;font-size:12.5px;line-height:1.5;color:var(--muted)}.login-card__input{width:100%;border:1px solid var(--rule);border-radius:var(--radius);padding:10px 12px;background:var(--surface);color:var(--ink);font-family:var(--font-sans);font-size:13px;line-height:1.4;letter-spacing:-.005em;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}.login-card__input::placeholder{color:var(--muted-2)}.login-card__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.login-card__input:disabled{opacity:.6;cursor:not-allowed}.login-card__error{font-family:var(--font-mono);font-size:11.5px;color:var(--warn);background:var(--warn-tint);padding:6px 10px;border-radius:var(--radius-sm);letter-spacing:0}.login-card__submit{margin-top:4px;white-space:nowrap!important;min-width:max-content;word-break:keep-all;overflow-wrap:normal;flex-shrink:0}.subgroup__row-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;background:var(--surface-2);border-bottom:1px solid var(--rule-soft)}.subgroup__row-btn{height:28px;padding:0 10px;font-size:12px;font-weight:500}.subgroup__row-btn--danger{color:var(--warn)}.subgroup__row-btn--danger:hover:not(:disabled){border-color:color-mix(in srgb,var(--warn) 50%,var(--rule));background:var(--warn-tint);color:var(--warn)}.subgroup__row-btn--danger:disabled{color:var(--muted-2)}.subgroup__row-btn svg{display:block}.group__footer-action{display:flex;justify-content:center;padding:12px;border-top:1px solid var(--rule-soft);background:var(--surface-2)}.group__add-btn{height:32px;padding:0 14px;font-weight:600;border-style:dashed}.group__add-btn:hover:not(:disabled){border-style:solid;border-color:var(--accent);color:var(--accent);background:var(--accent-tint)}.group__add-btn svg{display:block}.icon-modal__grid{grid-template-columns:repeat(auto-fill,minmax(min(140px,100%),160px))}.icon-tile__thumb{background:var(--paper)}.icon-tile__thumb img{object-fit:contain;padding:8px}.group__deleted-rows{border-top:1px solid var(--rule-soft);background:var(--warn-tint);padding:10px 12px 12px}.group__deleted-head{font-family:var(--font-mono);font-size:11px;letter-spacing:0;color:var(--warn);text-transform:uppercase;margin-bottom:6px}.group__deleted-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.group__deleted-item{display:flex;align-items:center;gap:10px;padding:6px 10px;background:var(--surface);border:1px solid color-mix(in srgb,var(--warn) 25%,var(--rule));border-radius:var(--radius-sm);text-decoration:line-through;text-decoration-color:color-mix(in srgb,var(--warn) 50%,transparent);color:var(--muted)}.group__deleted-label{font-family:var(--font-mono);font-size:11px;letter-spacing:0;color:var(--warn);text-decoration:none;flex-shrink:0}.group__deleted-title{flex:1;font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group__restore-btn{height:24px;padding:0 10px;font-size:11.5px;text-decoration:none;flex-shrink:0}.field--icon .field__icon-display{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:4px 0 0}.field--icon .field__icon-display code{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-2);background:var(--surface-hi);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--rule)}.field__icon-hint{font-size:11px;color:var(--muted-2)}
