.character-creator{padding:var(--space-6) 0 var(--space-7)}.character-creator__back{align-items:center;gap:var(--space-1);font-family:var(--sans);font-size:var(--fs-14);color:var(--ink-2);padding:var(--space-2) var(--space-3);transition:color var(--dur-base) var(--ease), background var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease);border:1px solid #0000;border-radius:999px;font-weight:500;text-decoration:none;display:inline-flex}.character-creator__back:hover{color:var(--accent);background:var(--bg-raised);border-color:var(--rule)}.character-creator__back:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.character-creator__header{margin:var(--space-5) 0 var(--space-6)}.character-creator__eyebrow{font-family:var(--sans);font-size:var(--fs-12);letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin:0 0 var(--space-2);font-weight:600}.character-creator__title{font-family:var(--serif);font-size:clamp(28px,4vw,44px);font-weight:500;line-height:var(--lh-tight);letter-spacing:-.015em;color:var(--ink);margin:0 0 var(--space-2)}.character-creator__title em{color:var(--accent);font-style:italic}.character-creator__sub{font-family:var(--serif);font-size:var(--fs-18);line-height:var(--lh-relaxed);color:var(--ink-2);max-width:60ch;margin:0}.character-creator__layout{gap:var(--space-7);grid-template-columns:minmax(280px,360px) 1fr;align-items:start;display:grid}@media (width<=920px){.character-creator__layout{gap:var(--space-5);grid-template-columns:1fr}}.character-preview{top:var(--space-5);background:var(--bg-raised);border:1px solid var(--rule);border-radius:var(--radius);padding:var(--space-5);gap:var(--space-4);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;position:sticky}@media (width<=920px){.character-preview{position:static}}.character-preview__stage{aspect-ratio:3/4;background:radial-gradient(circle at center, var(--accent-soft), transparent 70%), var(--bg-sunken);border-radius:var(--radius-sm);justify-content:center;align-items:flex-end;width:100%;padding-bottom:12%;display:flex;position:relative;overflow:hidden}.character-preview__stage:after{content:"";background:radial-gradient(ellipse at center, color-mix(in srgb, var(--ink) 28%, transparent) 0%, color-mix(in srgb, var(--ink) 12%, transparent) 50%, transparent 80%);filter:blur(3px);pointer-events:none;height:8px;animation:2.4s ease-in-out infinite character-shadow-pulse;position:absolute;bottom:11%;left:18%;right:18%}@keyframes character-shadow-pulse{0%,to{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(.94)}}.character-preview__sprite{width:70%;max-width:260px;height:auto;image-rendering:pixelated;filter:drop-shadow(0 4px #0000000d)}.character-preview__sprite[data-anim=walk]{animation:character-walk 1.4s var(--ease) infinite}@keyframes character-walk{0%{transform:translateY(0)rotate(-1.5deg)}25%{transform:translateY(-3px)rotate(.5deg)}50%{transform:translateY(0)rotate(1.5deg)}75%{transform:translateY(-3px)rotate(-.5deg)}to{transform:translateY(0)rotate(-1.5deg)}}@media (prefers-reduced-motion:reduce){.character-preview__stage:after{animation:none}}.character-preview__sprite[data-anim=wave]{animation:character-wave 1.4s var(--ease) infinite}@keyframes character-wave{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-2px)rotate(2deg)}}@media (prefers-reduced-motion:reduce){.character-preview__sprite,.character-preview__sprite[data-anim=wave]{animation:none;transform:none}}.character-preview__sprite-skeleton{background:linear-gradient(90deg, var(--bg-sunken), var(--bg-raised), var(--bg-sunken));border-radius:var(--radius-sm);background-size:200% 100%;justify-content:center;align-items:center;animation:1.6s linear infinite character-shimmer;display:flex;position:absolute;inset:0}@keyframes character-shimmer{0%{background-position:0 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.character-preview__sprite-skeleton{animation:none}}.character-creator[data-state=loading] .character-preview__sprite-skeleton{display:flex}.character-creator[data-state=ready] .character-preview__sprite-skeleton{display:none}.character-creator[data-state=loading] .character-preview__sprite{visibility:hidden}.character-pose-bar{justify-content:space-between;align-items:center;gap:var(--space-2);margin:var(--space-2) 0 var(--space-3);border:1px solid var(--rule,#ffffff14);background:var(--bg-sunken,#0000002e);border-radius:999px;padding:6px 8px;display:flex}.character-pose-bar[hidden]{display:none!important}.character-pose-bar:focus-visible{outline:2px solid var(--accent,#c2711f);outline-offset:2px}.character-pose-bar__directions{gap:2px;display:flex}.character-pose-bar__btn{appearance:none;width:28px;height:28px;color:var(--ink-2,#e8eaeeb3);font-family:var(--mono,"JetBrains Mono", monospace);cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;font-size:13px;line-height:1;transition:background .14s,color .14s,transform .14s;display:inline-flex}.character-pose-bar__btn:hover{color:var(--ink,#e8eaee);background:#ffffff0f}.character-pose-bar__btn[aria-pressed=true]{background:var(--accent,#c2711f);color:#1a1410;font-weight:600}.character-pose-bar__btn--animate{letter-spacing:.04em;text-transform:uppercase;width:auto;color:var(--ink-2,#e8eaeec7);padding:0 12px;font-size:11px}.character-pose-bar__btn--animate[aria-pressed=true]{color:var(--accent,#c2711f);background:#c2711f2e}.character-preview__name{gap:var(--space-1);flex-direction:column;display:flex}.character-preview__name-label{font-family:var(--sans);font-size:var(--fs-12);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);font-weight:600}.character-preview__name-input{font-family:var(--serif);font-size:var(--fs-18);border:0;border-bottom:1px solid var(--rule);padding:var(--space-2) 0;color:var(--ink);transition:border-color var(--dur-base) var(--ease);background:0 0;font-weight:500}.character-preview__name-input:focus{border-bottom-color:var(--accent);outline:0}.character-preview__name-counter{font-family:var(--sans);font-size:var(--fs-12);color:var(--ink-3);align-self:flex-end}.character-preview__actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.character-preview__action{appearance:none;cursor:pointer;font-family:var(--sans);font-size:var(--fs-14);padding:var(--space-3) var(--space-5);border:1px solid var(--rule);color:var(--ink-2);transition:background var(--dur-base) var(--ease), color var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);background:0 0;border-radius:999px;font-weight:600}.character-preview__action:hover{border-color:var(--accent);color:var(--accent)}.character-preview__action:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.character-preview__action--primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink,#fff)}.character-preview__action--primary:hover{background:color-mix(in srgb, var(--accent) 88%, black);color:var(--accent-ink,#fff)}.character-preview__action--primary[aria-busy=true]{opacity:.7;cursor:progress}.character-preview__action--primary[data-saved=true]{background:color-mix(in srgb, var(--accent) 60%, var(--success));color:#fff}@media (prefers-reduced-motion:reduce){.character-preview__action--primary[data-saved=true]{transition:none}}.character-preview__studio-cta{text-align:center;font-family:var(--sans);font-size:var(--fs-13,13px);color:var(--ink-3);transition:color var(--dur-base) var(--ease);text-decoration:none;display:block}.character-preview__studio-cta:hover{color:var(--accent)}.character-preview__studio-cta:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.character-preview__notice{font-family:var(--sans);font-size:var(--fs-13,13px);line-height:var(--lh-snug);border:1px solid var(--rule);border-radius:var(--radius-sm);padding:var(--space-3);color:var(--ink-2);display:none}.character-preview__notice[data-tone=info]{display:block}.character-preview__notice[data-tone=ok]{border-color:var(--success);color:var(--success);display:block}.character-preview__notice[data-tone=warn]{border-color:var(--warning);display:block}.character-preview__notice[data-tone=error]{border-color:var(--danger);color:var(--danger);display:block}.character-options{gap:var(--space-6);flex-direction:column;display:flex}.character-group{background:var(--bg-raised);border:1px solid var(--rule);border-radius:var(--radius);padding:var(--space-5);min-inline-size:0}.character-group__legend{font-family:var(--serif);font-size:var(--fs-22);margin:0 0 var(--space-1);color:var(--ink);float:left;border:0;width:100%;padding:0;font-weight:500}.character-group__legend+*{clear:left}.character-group__hint{font-family:var(--sans);font-size:var(--fs-14);color:var(--ink-3);margin:0 0 var(--space-4)}.character-group__row{gap:var(--space-2);flex-wrap:wrap;display:flex}.character-group--style{margin-bottom:var(--space-3)}.character-group--chibi[hidden]{display:none!important}.character-group__row--chibi{gap:var(--space-3);margin-top:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(110px,1fr));display:grid}.character-option--chibi-card{align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius);border:1px solid var(--rule);background:var(--bg);cursor:pointer;transition:border-color var(--dur-base) var(--ease), background var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease);flex-direction:column;display:flex}.character-option--chibi-card:hover{border-color:var(--accent);transform:translateY(-1px)}.character-option--chibi-card[aria-pressed=true]{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent)}.character-option__chibi-img{width:64px;height:128px;image-rendering:pixelated;image-rendering:crisp-edges;flex-shrink:0}.character-option__chibi-label{font-family:var(--sans);font-size:var(--fs-14);color:var(--ink);letter-spacing:-.005em;font-weight:600}.character-group__pack-pickers[hidden],.character-group--chibi-custom[hidden]{display:none!important}.character-group--chibi-layer{margin-top:var(--space-3)}.character-group__row--chibi-thumbs{gap:var(--space-2);margin-top:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(56px,1fr));display:grid}.character-option--chibi-thumb{border-radius:var(--radius-sm);border:1px solid var(--rule);background:var(--bg);cursor:pointer;height:88px;transition:border-color var(--dur-base) var(--ease), background var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease);justify-content:center;align-items:flex-end;padding:4px;display:flex;overflow:hidden}.character-option--chibi-thumb:hover{border-color:var(--accent);transform:translateY(-1px)}.character-option--chibi-thumb[aria-pressed=true]{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent)}.character-option--chibi-thumb .character-option__chibi-img{width:40px;height:80px;image-rendering:pixelated;image-rendering:crisp-edges}.character-option{appearance:none;cursor:pointer;background:var(--bg);border:1px solid var(--rule);color:var(--ink-2);padding:var(--space-2) var(--space-4);font-family:var(--sans);font-size:var(--fs-14);letter-spacing:-.005em;transition:background var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), color var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease);border-radius:999px;font-weight:500}.character-option:hover{border-color:var(--accent);color:var(--accent)}.character-option:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.character-option[aria-pressed=true]{background:var(--accent);border-color:var(--accent);color:var(--accent-ink,#fff);transform:translateY(-1px)}.character-swatch{appearance:none;cursor:pointer;border:2px solid var(--rule);background:var(--bg);width:32px;height:32px;transition:border-color var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur-base) var(--ease);border-radius:50%;padding:0;position:relative}.character-swatch:hover{border-color:var(--accent);transform:scale(1.06)}.character-swatch:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.character-swatch[aria-pressed=true]{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.character-swatch[aria-pressed=true]:after{content:"";mix-blend-mode:difference;border:2px solid #fff;border-radius:50%;position:absolute;inset:0}@media (width<=768px){.character-swatch{width:40px;min-width:44px;height:40px;min-height:44px}}.character-group--pack{border-color:var(--accent-soft,var(--rule))}.character-pack-row{gap:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.character-pack-row--colors{gap:var(--space-1)}.character-pack-tile{appearance:none;cursor:pointer;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3) var(--space-1) var(--space-1);border:1px solid var(--rule);background:var(--bg);color:var(--ink-2);font-family:var(--sans);font-size:var(--fs-13,13px);transition:border-color var(--dur-base) var(--ease), background var(--dur-base) var(--ease), color var(--dur-base) var(--ease);border-radius:999px;font-weight:500;display:inline-flex}.character-pack-tile:hover{border-color:var(--accent);color:var(--accent)}.character-pack-tile:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.character-pack-tile[aria-pressed=true]{background:var(--accent-soft,var(--bg-raised));border-color:var(--accent);color:var(--accent)}.character-pack-tile__thumb{width:28px;height:28px;image-rendering:pixelated;background-position:0 0;background-repeat:no-repeat;background-size:224px 224px;background-color:var(--bg-sunken);border-radius:999px;display:inline-block}.character-pack-tile__label{line-height:1}.character-pack-empty{font-family:var(--sans);font-size:var(--fs-13,13px);color:var(--ink-3)}.character-pack-color{appearance:none;cursor:pointer;min-width:38px;padding:var(--space-1) var(--space-2);border:1px solid var(--rule);background:var(--bg);color:var(--ink-2);font-family:var(--mono,var(--sans));font-size:var(--fs-12);letter-spacing:.04em;transition:border-color var(--dur-base) var(--ease), color var(--dur-base) var(--ease);border-radius:999px;font-weight:600}.character-pack-color:hover{border-color:var(--accent);color:var(--accent)}.character-pack-color:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.character-pack-color[aria-pressed=true]{background:var(--accent);border-color:var(--accent);color:var(--accent-ink,#fff)}.character-preview__sprite--canvas{image-rendering:pixelated;aspect-ratio:1;filter:drop-shadow(0 4px #0000000d);width:70%;max-width:260px;height:auto}@media (width<=920px){.character-creator__layout>.character-preview{z-index:4;border-radius:0 0 var(--radius) var(--radius);position:sticky;top:0}}@media (width<=540px){.character-creator{padding:var(--space-4) 0 var(--space-6)}.character-creator__title{font-size:clamp(22px,7vw,32px)}.character-creator__sub{font-size:var(--fs-15,15px)}.character-options,.character-swatch-row{gap:var(--space-1)}.character-creator__tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.character-creator__tabs::-webkit-scrollbar{display:none}}