@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.start{inset-inline-start:var(--spacing)}.contents{display:contents}.hidden{display:none}.inline{display:inline}.h-full{height:100%}.min-h-full{min-height:100%}.rounded{border-radius:.25rem}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}:root{--bg:#faf6f1;--bg-elevated:#fff;--bg-sunken:#f3ede5;--text-1:#1a1614;--text-2:#6b5d55;--text-3:#a89990;--accent:#e85d3a;--accent-hover:#d14e2d;--accent-soft:#fff0eb;--accent-glow:#e85d3a2e;--sage:#4a7c5c;--sage-soft:#edf5f0;--border:#e8e0d8;--border-strong:#d5cbc2;--shadow-sm:0 1px 3px #1a16140d;--shadow-md:0 4px 16px #1a161414;--shadow-lg:0 12px 32px #1a16141f;--shadow-accent:0 4px 20px #e85d3a40;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--header-h:56px;--bottomnav-h:68px;--sidebar-w:220px;--font-display-fallback:"Hiragino Sans", "Yu Gothic", sans-serif;--font-body-fallback:"Hiragino Sans", "Yu Gothic", sans-serif;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0}html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}body{color:var(--text-1);font-family:var(--font-body), var(--font-body-fallback);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.6;overflow-x:clip}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}img{max-width:100%;display:block}.app-shell{flex-direction:column;width:100%;min-height:100dvh;display:flex;overflow-x:clip}.app-header{z-index:40;height:var(--header-h);-webkit-backdrop-filter:blur(20px)saturate(1.4);backdrop-filter:blur(20px)saturate(1.4);border-bottom:1px solid var(--border);background:#faf6f1e0;justify-content:space-between;align-items:center;gap:12px;padding:0 16px;display:flex;position:sticky;top:0}.app-logo{font-family:var(--font-display), var(--font-display-fallback);letter-spacing:-.01em;color:var(--text-1);white-space:nowrap;flex-shrink:0;font-size:1.25rem;font-weight:700}.app-logo span{color:var(--accent)}.app-header-right{align-items:center;gap:8px;min-width:0;margin-left:auto;display:flex}.app-user{align-items:center;gap:8px;min-width:0;display:flex}.app-user-badge{border-radius:var(--radius-full);background:var(--accent-soft);min-width:0;max-width:96px;color:var(--accent);text-overflow:ellipsis;white-space:nowrap;align-items:center;padding:7px 10px;font-size:12px;font-weight:700;line-height:1;display:inline-flex;overflow:hidden}.app-user-copy{flex-direction:column;align-items:flex-end;min-width:0;display:none}.app-user-copy strong{text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:12px;line-height:1.2;overflow:hidden}.app-user-copy span{text-overflow:ellipsis;white-space:nowrap;max-width:180px;color:var(--text-3);font-size:11px;line-height:1.2;overflow:hidden}.app-user .btn{flex-shrink:0}.desktop-nav{gap:4px;display:none}.desktop-nav-link{border-radius:var(--radius-full);color:var(--text-2);transition:all .2s var(--ease-out);align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;display:flex}.desktop-nav-link:hover{background:var(--bg-sunken);color:var(--text-1)}.desktop-nav-link.is-active{background:var(--accent-soft);color:var(--accent)}.desktop-nav-link svg{flex-shrink:0;width:18px;height:18px}.app-main{padding:16px 16px calc(var(--bottomnav-h) + 16px);flex:1;width:100%;min-width:0;max-width:960px;margin:0 auto;overflow-x:clip}.bottom-nav{z-index:40;height:var(--bottomnav-h);padding-bottom:env(safe-area-inset-bottom,0);-webkit-backdrop-filter:blur(20px)saturate(1.4);backdrop-filter:blur(20px)saturate(1.4);border-top:1px solid var(--border);background:#ffffffeb;grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch;display:grid;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{cursor:pointer;width:100%;min-width:0;color:var(--text-3);transition:color .2s var(--ease-out);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:6px 0;text-decoration:none;display:flex}.bottom-nav-item svg{width:22px;height:22px;transition:transform .2s var(--ease-spring);flex-shrink:0}.bottom-nav-item span{letter-spacing:.02em;font-size:10px;font-weight:600}.bottom-nav-item.is-active{color:var(--accent)}.bottom-nav-item.is-active svg{transform:scale(1.1)}.bottom-nav-item:active svg{transform:scale(.9)}.heading-xl{font-family:var(--font-display), var(--font-display-fallback);letter-spacing:-.02em;color:var(--text-1);font-size:28px;font-weight:700;line-height:1.15}.heading-lg{font-family:var(--font-display), var(--font-display-fallback);letter-spacing:-.01em;color:var(--text-1);font-size:22px;font-weight:600;line-height:1.2}.heading-md{font-family:var(--font-display), var(--font-display-fallback);color:var(--text-1);font-size:17px;font-weight:600;line-height:1.3}.heading-sm{font-family:var(--font-display), var(--font-display-fallback);color:var(--text-1);font-size:14px;font-weight:600;line-height:1.4}.text-secondary{color:var(--text-2)}.text-tertiary{color:var(--text-3)}.text-sm{font-size:13px}.text-xs{letter-spacing:.02em;font-size:11px}.page-content{min-width:0;animation:pageIn .4s var(--ease-out);flex-direction:column;gap:20px;display:flex}.page-title-block{flex-direction:column;gap:6px;padding:8px 0;display:flex}.page-title-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.page-subtitle{color:var(--text-2);font-size:14px;line-height:1.5}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-body{flex-direction:column;gap:12px;padding:16px;display:flex}.card-padded{padding:16px}.card-section{flex-direction:column;gap:10px;display:flex}.card-divider{background:var(--border);height:1px;margin:4px -16px}.surface-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:20px}.surface-copy{color:var(--text-2);font-size:14px}.sign-in-card{flex-direction:column;gap:14px;max-width:560px;display:flex}.sign-in-actions{flex-wrap:wrap;gap:10px;display:flex}.btn{border-radius:var(--radius-full);min-height:44px;font-family:var(--font-display), var(--font-display-fallback);cursor:pointer;transition:all .2s var(--ease-out);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-sunken);color:var(--text-1);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{color:#b42318;background:#fff1f1;border:1px solid #f3c7c7}.btn-danger:hover{background:#fde2e2}.btn-ghost{color:var(--text-2);background:0 0}.btn-ghost:hover{background:var(--bg-sunken);color:var(--text-1)}.btn-sm{min-height:36px;padding:6px 14px;font-size:13px}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-icon{border-radius:var(--radius-full);background:var(--bg-sunken);border:1px solid var(--border);cursor:pointer;min-width:40px;min-height:40px;transition:all .2s var(--ease-out);justify-content:center;align-items:center;padding:8px;display:inline-flex}.btn-icon:hover{background:var(--border)}.btn-icon svg{width:18px;height:18px}.btn-icon-sm{border-radius:10px;min-width:28px;min-height:28px;padding:4px}.btn-icon-sm svg{width:14px;height:14px}.btn-icon-danger{color:#b42318;background:#fff1f1;border-color:#f3c7c7}.btn-icon-danger:hover{background:#fde2e2}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.builder-route-switch{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.chip{border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);max-width:100%;color:var(--text-2);transition:all .18s var(--ease-out);justify-content:center;align-items:center;padding:6px 12px;font-size:13px;font-weight:500;display:inline-flex}.chip-selectable{cursor:pointer;-webkit-user-select:none;user-select:none}.chip-selectable:hover{border-color:var(--border-strong);background:var(--bg-sunken)}.chip-selectable:active{transform:scale(.95)}.chip-selected{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.chip-selected:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.chip-soft{background:var(--accent-soft);color:var(--accent);border-color:#0000;font-size:12px}.chip-sage{background:var(--sage-soft);color:var(--sage);border-color:#0000;font-size:12px}.chip-row{flex-wrap:wrap;gap:6px;min-width:0;display:flex}.form-stack{flex-direction:column;gap:20px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--text-1);font-size:13px;font-weight:600}.field-label-row{align-items:center;gap:6px;display:flex}.info-tooltip{z-index:1;align-items:center;display:inline-flex;position:relative}.info-tooltip-trigger{width:18px;height:18px;color:var(--text-3);cursor:help;transition:color .16s var(--ease-out), background-color .16s var(--ease-out);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;display:inline-flex}.info-tooltip-trigger:hover,.info-tooltip-trigger:focus-visible{color:var(--accent);background:var(--accent-soft);outline:none}.info-tooltip-trigger svg{width:18px;height:18px}.info-tooltip-popup{z-index:20;border:1px solid var(--border-strong);border-radius:var(--radius-md);width:min(260px,100vw - 48px);box-shadow:var(--shadow-lg);color:var(--text-2);opacity:0;pointer-events:none;transition:opacity .16s var(--ease-out), transform .16s var(--ease-out);background:#fffffffa;padding:10px 12px;font-size:12px;line-height:1.55;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%,6px)}.info-tooltip-popup:after{content:"";border-right:1px solid var(--border-strong);border-bottom:1px solid var(--border-strong);background:#fffffffa;width:10px;height:10px;position:absolute;top:100%;left:50%;transform:translate(-50%)rotate(45deg)}.info-tooltip:hover .info-tooltip-popup,.info-tooltip:focus-within .info-tooltip-popup{opacity:1;z-index:30;transform:translate(-50%)}.field-hint,.form-helper{color:var(--text-3);font-size:12px}.input,.select,.textarea{border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-elevated);width:100%;transition:all .2s var(--ease-out);outline:none;padding:11px 14px;font-size:15px}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.textarea{resize:vertical;min-height:100px}.input-compact,.select-compact,.textarea-compact{padding:8px 12px;font-size:14px}.textarea-compact{min-height:64px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23a89990' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-row{grid-template-columns:1fr 1fr;gap:12px;min-width:0;display:grid}.field-row{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.composite-character-stack{flex-direction:column;gap:8px;display:flex}.composite-character-row{align-items:center;gap:10px;min-width:0;display:flex}.composite-character-field{flex:1}.composite-character-action{margin-top:22px}.field-checkbox{color:var(--text-2);align-items:center;gap:8px;margin-top:14px;font-size:13px;display:inline-flex}.field-checkbox input{width:16px;height:16px;accent-color:var(--accent)}@media (max-width:640px){.info-tooltip-popup{left:0;transform:translateY(6px)}.info-tooltip-popup:after{left:16px;transform:rotate(45deg)}.info-tooltip:hover .info-tooltip-popup,.info-tooltip:focus-within .info-tooltip-popup{transform:translateY(0)}.form-row{grid-template-columns:1fr}.field-row,.composite-character-row,.side-panel-head,.btn-row{flex-wrap:wrap}.composite-character-action{margin-top:0}.ref-grid,.ref-grid-large{grid-template-columns:1fr}}.form-section-title{font-family:var(--font-display);color:var(--text-1);border-bottom:1px solid var(--border);padding-bottom:4px;font-size:15px;font-weight:600}.builder-section{flex-direction:column;gap:16px;display:flex}.builder-section-head{flex-direction:column;gap:6px;display:flex}.builder-subgrid{grid-template-columns:1fr;gap:16px;display:grid}.custom-field-box{border-radius:var(--radius-md);background:var(--bg-sunken);border:1px solid var(--border);flex-direction:column;gap:8px;padding:12px;display:flex}.custom-field-box-compact{gap:6px;padding:10px}.custom-field-inline{grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;display:grid}.custom-field-inline .input{border:none;border-bottom:1px solid var(--border);box-shadow:none;background:0 0;border-radius:0;padding:4px 0}.custom-field-inline .input:focus{border-color:var(--accent);box-shadow:none}.custom-field-icon{width:18px;height:18px;color:var(--text-3)}.custom-field-icon svg{width:100%;height:100%}.overview-stack{flex-direction:column;gap:18px;display:flex}.selector-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.selector-group{flex-direction:column;gap:8px;display:flex}.selector-group-card{gap:10px}.selector-group-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.selector-group-label{color:var(--text-2);font-size:13px;font-weight:600}.selector-group-subtitle{color:var(--text-3);margin-top:3px;font-size:12px}.option-grid{flex-wrap:wrap;gap:6px;display:flex}.option-grid-compact{gap:5px}.option-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.option-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);text-align:left;cursor:pointer;transition:all .18s var(--ease-out);flex-direction:column;gap:10px;padding:10px;display:flex}.option-card-compact{border-radius:var(--radius-md);padding:8px}.option-card:hover{border-color:var(--border-strong);background:linear-gradient(180deg, #fffdfa 0%, var(--bg-elevated) 100%);box-shadow:var(--shadow-sm)}.option-card.is-selected{border-color:var(--accent);background:linear-gradient(#fff7f2 0%,#fff1ea 100%);box-shadow:0 8px 20px #e85d3a1f}.option-card-body{flex-direction:column;gap:6px;display:flex}.option-card-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.option-card-title{color:var(--text-1);font-size:13px;font-weight:700}.option-card-badge{border-radius:var(--radius-full);color:var(--accent);letter-spacing:.04em;background:#ffffffb3;justify-content:center;align-items:center;padding:4px 8px;font-size:10px;font-weight:700;display:inline-flex}.option-card-description{color:var(--text-2);font-size:12px;line-height:1.45}.chip-compact{padding:4px 9px;font-size:11px}.color-swatch-row{flex-wrap:wrap;gap:6px;display:flex}.color-swatch{border:1px solid #1a16141f;border-radius:999px;width:18px;height:18px;box-shadow:inset 0 0 0 1px #ffffff59}.color-picker-panel{gap:12px}.builder-slider-stack{gap:8px}.detail-toggle{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:10px 12px;display:flex}.detail-toggle-text{font-size:13px;font-weight:600}.detail-toggle-icon{color:var(--accent);font-size:16px;line-height:1}.detail-panel{flex-direction:column;gap:16px;display:flex}.slider-range-labels{color:var(--text-3);justify-content:space-between;font-size:11px;display:flex}.floating-submit-spacer{height:92px}.floating-submit-bar{left:50%;bottom:calc(var(--bottomnav-h) + 12px);z-index:35;pointer-events:none;width:min(100vw - 24px,960px);position:fixed;transform:translate(-50%)}.floating-submit-inner{border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(20px)saturate(1.2);backdrop-filter:blur(20px)saturate(1.2);pointer-events:auto;background:#ffffffeb;align-items:center;gap:8px;padding:10px;display:flex}.floating-submit-inner .btn-block{flex:1}.color-picker-grid{grid-template-columns:1fr;gap:10px;display:grid}.color-picker-card{flex-direction:column;gap:8px;display:flex}.color-input-row{align-items:center;gap:8px;display:flex}.color-input{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:12px;width:44px;min-width:44px;height:44px;padding:0}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:none;border-radius:10px}.character-grid{grid-template-columns:1fr;gap:16px;display:grid}.character-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);transition:all .25s var(--ease-out);overflow:hidden}.character-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.zoomable-image-trigger{cursor:zoom-in;background:0 0;border:0;width:100%;height:100%;padding:0;display:block}.character-card-images{background:var(--border);grid-template-columns:1fr;gap:2px;display:grid}.character-card-img{aspect-ratio:4/5;background:var(--bg-sunken);cursor:zoom-in;overflow:hidden}.character-card-img:first-child{aspect-ratio:16/9;background:linear-gradient(#ffffff73,#ffffff1f),linear-gradient(160deg,#d8cfc6 0%,#f1ebe4 100%)}.character-card-img img{object-fit:cover;width:100%;height:100%;transition:transform .3s var(--ease-out)}.character-card-img:first-child img{object-fit:contain}.character-card-img:hover img{transform:scale(1.04)}.character-card-info{flex-direction:column;gap:10px;padding:14px 16px;display:flex}.character-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.character-card-edit-fields{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.character-card-header-main{flex:1;min-width:0}.character-card-header-side{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.character-card-toolbar{align-items:center;gap:4px;display:flex}.character-card-name{font-family:var(--font-display);font-size:18px;font-weight:600}.character-card-tagline{color:var(--text-2);margin-top:2px;font-size:13px}.character-card-badge{border-radius:var(--radius-full);background:var(--sage-soft);color:var(--sage);flex-shrink:0;padding:3px 8px;font-size:10px;font-weight:600}.character-card-specs{border-radius:var(--radius-md);background:var(--bg-sunken);gap:16px;padding:10px 12px;display:flex}.character-card-spec{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.character-card-spec dt{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.character-card-spec dd{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.character-card-actions{gap:8px;display:flex}.character-card-actions .btn{flex:1}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;display:flex}.empty-state-icon{border-radius:var(--radius-full);background:var(--accent-soft);width:64px;height:64px;color:var(--accent);justify-content:center;align-items:center;display:flex}.empty-state-icon svg{width:28px;height:28px}.empty-state-title{font-family:var(--font-display);font-size:18px;font-weight:600}.empty-state-text{color:var(--text-2);max-width:280px;font-size:14px}.stats-row{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.stat-item{border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border);flex-direction:column;align-items:center;gap:2px;padding:12px 8px;display:flex}.stat-value{font-family:var(--font-display);color:var(--text-1);font-size:22px;font-weight:700}.stat-label{color:var(--text-3);font-size:11px;font-weight:500}.quick-actions{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;display:grid}.quick-action{border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .2s var(--ease-out);align-items:center;gap:10px;padding:14px;text-decoration:none;display:flex}.quick-action:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.quick-action:active{transform:scale(.98)}.quick-action-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.quick-action-icon svg{width:20px;height:20px}.quick-action-icon-coral{background:var(--accent-soft);color:var(--accent)}.quick-action-icon-sage{background:var(--sage-soft);color:var(--sage)}.quick-action-icon-sky{color:#2e6f8f;background:#ecf6fb}.quick-action-text{flex-direction:column;gap:1px;min-width:0;display:flex}.quick-action-label{font-family:var(--font-display);color:var(--text-1);font-size:14px;font-weight:600}.quick-action-desc{color:var(--text-3);font-size:11px}.two-col{flex-direction:column;gap:20px;display:flex}.studio-layout{flex-direction:column;gap:20px;min-width:0;display:flex}.studio-layout>:first-child{z-index:2;position:relative}.studio-layout>:first-child.card{overflow:visible}.studio-layout>:last-child{z-index:1;position:relative}.mode-toggle{border-radius:var(--radius-full);background:var(--bg-sunken);border:1px solid var(--border);padding:3px;display:flex}.mode-toggle-btn{border-radius:var(--radius-full);color:var(--text-2);cursor:pointer;transition:all .2s var(--ease-out);background:0 0;border:none;flex:1;padding:8px 14px;font-size:13px;font-weight:600}.mode-toggle-btn.is-active{background:var(--bg-elevated);color:var(--text-1);box-shadow:var(--shadow-sm)}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s var(--ease-out);color:var(--text-3);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:24px;display:flex}.upload-zone:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.upload-zone svg{width:32px;height:32px}.upload-zone input[type=file]{display:none}.reference-upload-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;display:grid}.reference-upload-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);flex-direction:column;gap:8px;padding:10px;display:flex}.reference-upload-preview{aspect-ratio:4/5;border-radius:var(--radius-md);background:var(--bg-sunken);position:relative;overflow:hidden}.reference-upload-preview img{object-fit:cover;width:100%;height:100%}.reference-upload-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.reference-upload-name{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.backdrop-preview{border-radius:var(--radius-lg);border:1px solid var(--border);position:relative;overflow:hidden}.backdrop-preview img{display:block}.backdrop-preview-stage{aspect-ratio:16/9;background:radial-gradient(circle at 0 0,#e85d3a33,#0000 36%),radial-gradient(circle at 100% 100%,#4a7c5c2e,#0000 32%),linear-gradient(160deg,#f4ede6 0%,#e8ddd2 48%,#f5efe8 100%);width:min(100%,520px);margin-inline:auto;padding:18px;box-shadow:inset 0 1px #ffffffa6,0 14px 32px #1a161414}.backdrop-preview-stage:after{content:"";border-radius:calc(var(--radius-lg) - 4px);pointer-events:none;border:1px solid #ffffff6b;position:absolute;inset:12px}.backdrop-preview-frame{z-index:1;border-radius:calc(var(--radius-lg) - 4px);background:linear-gradient(#ffffff80,#ffffff2e),linear-gradient(160deg,#d5cbc2 0%,#ede4da 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.backdrop-preview-stage img{z-index:1;object-fit:contain;filter:drop-shadow(0 16px 24px #1a16142e);width:100%;max-width:100%;height:100%;max-height:100%;position:relative}.backdrop-preview-stage.is-portrait .backdrop-preview-frame{background:linear-gradient(90deg,#221d1bd9 0%,#3e353180 15%,#eee6de0f 34% 66%,#3b52437a 85%,#202d25d1 100%),linear-gradient(160deg,#302824 0%,#5c5049 48%,#2a2320 100%)}.backdrop-preview-stage.is-portrait .backdrop-preview-frame:before{content:"";filter:blur(26px);opacity:.72;pointer-events:none;background:linear-gradient(90deg,#e85d3a85 0%,#e85d3a00 28%,#4a7c5c00 72%,#4a7c5c85 100%);position:absolute;inset:-8%}.backdrop-preview-stage.is-standard .backdrop-preview-frame{background:linear-gradient(#ffffff6b,#ffffff24),linear-gradient(160deg,#d6ccc4 0%,#efe7df 100%)}.progress-overlay{z-index:50;padding:max(20px, env(safe-area-inset-top,0px) + 20px) 16px max(20px, env(safe-area-inset-bottom,0px) + 20px);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);animation:fadeIn .3s var(--ease-out);overscroll-behavior:contain;background:#faf6f1f5;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow-y:auto}.progress-panel{text-align:center;background:linear-gradient(#fffffffa,#f8f3eefa),radial-gradient(circle at top,#e85d3a1f,#0000 55%);border:1px solid #d5cbc2e6;border-radius:28px;flex-direction:column;align-items:center;gap:18px;width:min(100%,420px);padding:22px 18px 18px;display:flex;box-shadow:0 18px 48px #1a16141f}.progress-panel-header{flex-direction:column;align-items:center;gap:6px;display:flex}.progress-panel-caption{color:var(--text-3);font-size:12px}.progress-spinner{background:conic-gradient(var(--accent) 0deg, var(--accent-soft) 60deg, var(--accent) 360deg);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;animation:1.2s linear infinite spin;display:flex}.progress-spinner-inner{background:var(--bg);border-radius:50%;width:44px;height:44px}.progress-title{font-family:var(--font-display);color:var(--text-1);font-size:22px;font-weight:700}.progress-text{color:var(--text-2);max-width:28ch;font-size:14px}.progress-meta{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.progress-step-list{gap:8px;width:100%;display:grid}.progress-step{border:1px solid var(--border);text-align:left;background:#ffffffa8;border-radius:14px;align-items:center;gap:10px;padding:10px 12px;display:flex}.progress-step-index{border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:inline-flex}.progress-step-label{font-size:13px;font-weight:600}.progress-step-done{color:var(--sage);background:#edf5f0f2;border-color:#4a7c5c38}.progress-step-done .progress-step-index{background:var(--sage);color:#fff}.progress-step-current{color:var(--accent);background:#fff0ebfa;border-color:#e85d3a47;box-shadow:0 10px 22px #e85d3a1f}.progress-step-current .progress-step-index{background:var(--accent);color:#fff}.progress-step-pending{color:var(--text-3)}.progress-step-pending .progress-step-index{background:var(--bg-sunken);color:var(--text-2)}.progress-action{justify-content:center;width:100%}.progress-footnote{color:var(--text-3);font-size:12px}@media (max-width:767px){.progress-overlay{background:linear-gradient(#faf6f1fa,#f5eee7fa),radial-gradient(circle at top,#e85d3a1a,#0000 42%);justify-content:stretch;align-items:stretch;padding:0}.progress-panel{width:100%;min-height:100dvh;padding:max(24px, env(safe-area-inset-top,0px) + 24px) 20px max(24px, env(safe-area-inset-bottom,0px) + 24px);box-shadow:none;background:0 0;border:none;border-radius:0;justify-content:center;gap:14px}.progress-panel-caption{display:none}.progress-spinner{width:48px;height:48px}.progress-spinner-inner{width:38px;height:38px}.progress-title{font-size:20px}.progress-text{max-width:24ch;font-size:13px}.progress-step-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;max-width:336px}.progress-step:last-child:nth-child(odd){grid-column:1/-1}.progress-step{border-radius:12px;gap:8px;min-height:40px;padding:8px 10px}.progress-step-index{width:20px;height:20px;font-size:11px}.progress-step-label{font-size:12px;line-height:1.25}.progress-meta{gap:6px;max-width:336px}.progress-meta .chip{padding:5px 10px;font-size:11px}.progress-action{max-width:336px}.progress-footnote{font-size:11px}}@media (max-width:767px) and (max-height:740px){.progress-panel{padding:max(16px, env(safe-area-inset-top,0px) + 16px) 16px max(16px, env(safe-area-inset-bottom,0px) + 16px);gap:10px}.progress-title{font-size:18px}.progress-text{max-width:22ch;font-size:12px}.progress-spinner{width:42px;height:42px}.progress-spinner-inner{width:32px;height:32px}.progress-step{min-height:34px;padding:6px 8px}.progress-step-label{font-size:11px}}.status-badge{border-radius:var(--radius-full);align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.status-badge-pending{background:var(--accent-soft);color:var(--accent)}.status-badge-success{background:var(--sage-soft);color:var(--sage)}.status-badge-error{color:#b91c1c;background:#fef2f2}.prompt-box{border-radius:var(--radius-md);color:#e8ddd4;background:#1a1614;padding:12px 14px;font-size:12px;line-height:1.6}.prompt-box-subtle{color:var(--text-1);border:1px solid var(--border);background:#f3ede5}.prompt-box code{white-space:pre-wrap;word-break:break-all;font-family:SF Mono,Menlo,monospace}.album-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.album-series-list{flex-direction:column;gap:18px;display:flex}.album-series{flex-direction:column;gap:12px;display:flex}.series-header{z-index:5;justify-content:space-between;align-items:center;gap:12px;display:flex;position:relative}.series-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.series-header-delete{z-index:6;position:relative}.album-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .25s var(--ease-out);position:relative;overflow:hidden}.album-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.album-card-link{display:block}.album-card-toolbar{z-index:3;position:absolute;top:10px;right:10px}.album-card-delete-trigger{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);background:#fffffff0}.album-card-delete-trigger:hover{background:#fff}.album-card-menu{z-index:20;border-radius:var(--radius-md);border:1px solid var(--border);width:min(220px,100vw - 48px);box-shadow:var(--shadow-lg);background:#fffffffa;flex-direction:column;gap:10px;padding:12px;display:flex;position:absolute;top:calc(100% + 8px);right:0}.album-card-menu-header{width:min(240px,100vw - 48px)}.album-card-menu-title{font-family:var(--font-display);font-size:13px;font-weight:600;line-height:1.3}.album-card-menu-text{color:var(--text-2);font-size:12px;line-height:1.5}.album-card-menu-list,.album-card-menu-actions{flex-direction:column;gap:8px;display:flex}.album-card-menu-option,.album-card-menu-confirm{border:1px solid var(--border);background:var(--bg-elevated);text-align:left;cursor:pointer;min-height:34px;transition:all .18s var(--ease-out);border-radius:10px;padding:8px 10px;font-size:12px;font-weight:600}.album-card-menu-option:hover,.album-card-menu-confirm:hover{border-color:var(--border-strong);transform:translateY(-1px)}.album-card-menu-option-danger,.album-card-menu-confirm{color:#b42318;background:#fff5f5;border-color:#f3c7c7}.album-card-menu-option-danger:hover,.album-card-menu-confirm:hover{background:#ffeaea;border-color:#e79d9d}.album-card-menu-option:disabled,.album-card-menu-confirm:disabled{opacity:.6;cursor:not-allowed;transform:none}.album-card-image{aspect-ratio:4/5;background:var(--bg-sunken);overflow:hidden}.album-card-image img{object-fit:cover;width:100%;height:100%}.album-card-info{flex-direction:column;gap:6px;padding:10px 12px;display:flex}.album-card-title{font-family:var(--font-display);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;line-height:1.3;overflow:hidden}.album-card-meta{justify-content:space-between;align-items:center;display:flex}.fav-btn{border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-2);cursor:pointer;transition:all .18s var(--ease-out);align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.fav-btn:hover{border-color:var(--accent);color:var(--accent)}.fav-btn.is-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.filter-bar{border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;display:flex}.filter-stack{flex-direction:column;gap:10px;display:flex}.filter-chip-row{flex-wrap:wrap;gap:6px;display:flex}.filter-bar select{appearance:none;background:0 0;border:none;outline:none;flex:1;font-size:14px;font-weight:500}.filter-bar-count{color:var(--text-3);white-space:nowrap;font-size:13px;font-weight:500}.result-image{border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-lg);overflow:hidden}.result-image img{width:100%;height:auto}.result-meta{flex-direction:column;gap:8px;display:flex}.result-meta-row{justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;display:flex}.result-meta-row+.result-meta-row{border-top:1px solid var(--border)}.result-meta-label{color:var(--text-2)}.result-meta-value{color:var(--text-1);font-weight:600}.suggestion-card{border-radius:var(--radius-md);background:var(--bg-sunken);border:1px solid var(--border);padding:12px 14px}.suggestion-card h4{font-family:var(--font-display), var(--font-display-fallback);margin-bottom:4px;font-size:14px;font-weight:600}.suggestion-card p{color:var(--text-2);font-size:13px}.side-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:16px;min-width:0;max-width:100%;padding:16px;display:flex}.side-panel-head{justify-content:space-between;align-items:flex-start;gap:12px;min-width:0;display:flex}.ref-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;min-width:0;display:grid}.ref-grid-large{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.ref-card{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-sunken);min-width:0;overflow:hidden}.ref-card img{object-fit:contain;width:100%;height:auto}.ref-card-label{color:var(--text-2);text-align:center;padding:6px 10px;font-size:12px;font-weight:500}.modal-overlay{z-index:60;padding:max(12px, env(safe-area-inset-top,0px) + 12px) 12px max(12px, env(safe-area-inset-bottom,0px) + 12px);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .2s var(--ease-out);background:#0c0a09d6;grid-template-rows:auto 1fr;gap:12px;display:grid;position:fixed;inset:0}.lightbox-chrome{animation:sheetUp .26s var(--ease-out);justify-content:space-between;align-items:center;gap:12px;display:flex}.lightbox-meta{min-width:0}.modal-title{font-family:var(--font-display), var(--font-display-fallback);color:#fffffff5;text-shadow:0 1px 2px #00000047;font-size:14px;font-weight:600}.lightbox-close{color:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff24;border:1px solid #ffffff2e;flex-shrink:0}.lightbox-close:hover{background:#ffffff38}.modal-body{min-height:0}.modal-body-full{animation:sheetUp .3s var(--ease-out);justify-content:center;align-items:center;display:flex}.lightbox-image{border-radius:var(--radius-lg);width:auto;max-width:100%;height:auto;max-height:calc(100dvh - 104px);box-shadow:0 18px 60px #0000006b}.error-text{color:#b91c1c;border-radius:var(--radius-sm);background:#fef2f2;padding:8px 12px;font-size:13px}.meta-row{color:var(--text-2);justify-content:space-between;align-items:center;gap:16px;padding:6px 0;font-size:14px;display:flex}.meta-row strong{color:var(--text-1);text-align:right}.meta-row-top{align-items:flex-start}.meta-row-value-wrap{white-space:pre-wrap;word-break:break-word;max-width:min(62%,420px)}.meta-list{flex-direction:column;display:flex}.slider-stack{flex-direction:column;gap:6px;display:flex}.slider-stack input[type=range]{width:100%;accent-color:var(--accent)}.result-empty-state{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--bg-elevated);min-height:320px}.completion-layout{flex-direction:column;gap:20px;display:flex}.completion-preview{overflow:hidden}.completion-preview-inner{padding:12px}.completion-preview-inner img{width:100%;height:auto}.registered-reference-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.registered-reference-card{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-sunken);overflow:hidden}.registered-reference-media{background:linear-gradient(#ffffff61,#ffffff24),linear-gradient(160deg,#d8cfc6 0%,#f1ebe4 100%);height:280px}.registered-reference-media .zoomable-image-trigger{height:100%}.registered-reference-media img{object-fit:contain;width:100%;height:100%}.completion-actions{flex-direction:column;gap:10px;display:flex}.stack-xs{flex-direction:column;gap:6px;display:flex}.stack-sm{flex-direction:column;gap:10px;display:flex}.stack-md{flex-direction:column;gap:16px;display:flex}.stack-lg{flex-direction:column;gap:24px;display:flex}.builder-side-column{min-width:0}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes sheetUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes staggerIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (min-width:640px){.album-grid{grid-template-columns:repeat(3,1fr)}.character-grid{grid-template-columns:repeat(2,1fr)}.builder-subgrid{grid-template-columns:.9fr 1.1fr}.color-picker-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.stats-row{grid-template-columns:repeat(4,1fr)}}@media (min-width:768px){.app-header{padding:0 20px}.app-main{padding:24px;padding-bottom:calc(var(--bottomnav-h) + 24px);max-width:1080px}.two-col{flex-direction:row;gap:24px}.two-col>:first-child{flex:1.2;min-width:0}.two-col>:last-child{flex:.8;min-width:0}.builder-side-column{top:calc(var(--header-h) + 24px);max-height:calc(100dvh - var(--header-h) - 48px);align-self:flex-start;padding-bottom:8px;position:sticky;overflow-y:auto}.studio-layout{flex-direction:row;gap:24px}.studio-layout>:first-child{flex:1.1;min-width:0}.studio-layout>:last-child{flex:.9;min-width:0}.modal-overlay{padding:max(20px, env(safe-area-inset-top,0px) + 20px) 24px max(20px, env(safe-area-inset-bottom,0px) + 20px);gap:18px}.progress-overlay{padding:max(24px, env(safe-area-inset-top,0px) + 24px) 24px max(24px, env(safe-area-inset-bottom,0px) + 24px)}.progress-panel{padding:28px 24px 22px}.selector-grid{grid-template-columns:repeat(3,1fr)}.option-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.page-content{gap:24px}.completion-layout{flex-direction:row;align-items:flex-start;gap:24px}.completion-layout>:first-child{flex:1.2;min-width:0}.completion-layout>:last-child{flex:.8;min-width:0}}@media (min-width:1024px){.app-header{padding:0 24px}.app-main{padding-bottom:48px}.bottom-nav{display:none}.desktop-nav{display:flex}.app-user-badge{display:none}.app-user-copy{display:flex}.character-grid{grid-template-columns:repeat(2,1fr)}}
