*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #08080c;--bg-elevated: rgba(20, 20, 25, .88);--bg-panel: rgba(25, 25, 31, .82);--bg-panel-strong: rgba(31, 31, 39, .96);--surface-soft: rgba(236, 72, 153, .08);--surface-strong: rgba(236, 72, 153, .16);--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .16);--accent: #ec4899;--accent-hover: #f472b6;--accent-glow: rgba(236, 72, 153, .28);--text: #fafafa;--text-secondary: #d4d4d8;--text-muted: #a1a1aa;--success: #22c55e;--success-bg: rgba(34, 197, 94, .14);--error: #ef4444;--error-bg: rgba(239, 68, 68, .14);--shadow-xl: 0 28px 90px rgba(0, 0, 0, .34);--radius-lg: 24px;--radius: 16px;--radius-sm: 10px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body{min-height:100%;font-family:var(--font);background:radial-gradient(circle at top left,rgba(236,72,153,.14),transparent 28%),radial-gradient(circle at 85% 12%,rgba(244,114,182,.1),transparent 18%),linear-gradient(180deg,#121217,#08080c);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body.modal-open{overflow:hidden}a{color:var(--accent-hover);text-decoration:none}a:hover{text-decoration:underline}#app{min-height:100vh;display:flex;flex-direction:column}#app.app-drag-active:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#ec489914;border:2px dashed rgba(244,114,182,.4);box-shadow:inset 0 0 120px #ec48991f;pointer-events:none;z-index:55}.screen{min-height:100vh;display:flex;flex-direction:column}.hidden{display:none!important}.language-switcher{position:fixed;top:14px;right:16px;z-index:80;display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:999px;background:#08080ce0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.language-switcher-label{font-size:12px;color:var(--text-muted)}.language-select{background:transparent;color:var(--text);border:none;font-family:var(--font);font-size:12px;outline:none}.language-select option{background:#111114;color:var(--text)}#auth-screen{align-items:center;justify-content:center}.auth-card{text-align:center;padding:48px 40px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-xl);max-width:420px;width:100%;margin:16px}.logo{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:16px}.logo h1{font-size:28px;font-weight:700;letter-spacing:-.5px}.accent{color:var(--accent)}.tagline{color:var(--text-secondary);font-size:15px;line-height:1.5;margin-bottom:32px}.auth-footer{margin-top:32px;font-size:13px;color:var(--text-muted)}.error-text{color:var(--error);font-size:14px;margin-top:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease,color .18s ease;padding:10px 18px;line-height:1.4}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-google{width:100%;padding:12px 20px;background:#fff;color:#1f1f1f;font-size:15px;border-radius:var(--radius-sm)}.btn-google:hover:not(:disabled){background:#f5f5f5}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,#fb7185 100%);color:#fff;box-shadow:0 12px 30px #ec48992e}.btn-primary:hover:not(:disabled){box-shadow:0 16px 36px var(--accent-glow)}.btn-outline{background:#ffffff05;color:var(--text-secondary);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){border-color:var(--border-hover);color:var(--text);background:#ffffff0d}.btn-sm{padding:7px 14px;font-size:13px;background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-icon{width:34px;height:34px;padding:0;font-size:22px;background:#0000008c;color:#fff;border-radius:50%;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-icon:hover:not(:disabled){background:#000000c7}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px;border-bottom:1px solid var(--border);background:#08080cc7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);position:sticky;top:0;z-index:20}.header-left,.header-right{display:flex;align-items:center;gap:12px}.header-title{font-size:18px;font-weight:700;letter-spacing:-.3px}.credits-pill{display:inline-flex;align-items:center;justify-content:center;min-width:92px;padding:7px 12px;border-radius:999px;background:#ec48991f;border:1px solid rgba(236,72,153,.24);color:var(--accent-hover);font-size:13px;font-weight:700}.user-email{font-size:13px;color:var(--text-muted)}.app-body{flex:1;padding:32px 24px 40px}.library-shell{width:min(1180px,100%);margin:0 auto;display:flex;flex-direction:column;gap:18px}.library-toolbar{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 16px;background:#141419c7;border:1px solid var(--border);border-radius:18px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.library-toolbar-copy{min-width:0}.library-toolbar-title{font-size:18px;font-weight:700;letter-spacing:-.03em}.library-toolbar-subtitle,.modal-subtitle{color:var(--text-secondary);font-size:13px;line-height:1.5;margin-top:4px}.modal-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent-hover);margin-bottom:10px}.modal-title{font-size:clamp(28px,4vw,40px);line-height:1.05;letter-spacing:-.04em;margin-bottom:12px}.library-toolbar-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.toolbar-field{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 10px;border:1px solid var(--border);border-radius:12px;background:#ffffff08}.toolbar-label{font-size:12px;color:var(--text-muted)}.toolbar-select{min-width:92px;border:0;background:transparent;color:var(--text);font:inherit;outline:none}.toolbar-select option{background:#111114}.toolbar-layout-group{padding-right:6px}.layout-toggle-group{display:inline-flex;align-items:center;gap:4px}.layout-toggle{min-width:74px;height:30px;border:1px solid transparent;border-radius:9px;background:transparent;color:var(--text-muted);font:inherit;font-size:12px;font-weight:600;cursor:pointer}.layout-toggle.active{color:var(--text);border-color:#ec48993d;background:#ec48991f}.toolbar-create-btn{min-height:40px;padding:0 14px}.add-character-icon{font-size:20px;line-height:1}.library-panel{min-height:320px}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.library-grid-compact{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.library-card{position:relative;display:flex;flex-direction:column;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 16px 48px #0000002e;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease;cursor:pointer}.library-card:hover{border-color:#ec489947;transform:translateY(-3px);box-shadow:0 22px 60px #00000047}.library-card-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:100%;min-height:320px;padding:24px;border:1px dashed rgba(236,72,153,.24);background:linear-gradient(180deg,#ec48990a,#ffffff05);color:var(--text-secondary)}.library-card-add:hover{border-color:#ec489966;color:var(--text)}.library-card-add-icon{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:999px;border:1px solid rgba(236,72,153,.22);background:#ec489914;color:var(--accent-hover);font-size:30px;line-height:1}.library-card-add-title{font-size:15px;font-weight:700}.library-card-add-copy{font-size:13px;color:var(--text-muted);text-align:center;line-height:1.5}.library-card-image-wrap{position:relative;aspect-ratio:1 / 1;overflow:hidden;background:radial-gradient(circle at top,rgba(236,72,153,.1),transparent 48%),linear-gradient(180deg,#ffffff0d,#ffffff05)}.library-card-image-wrap:after{content:"";position:absolute;inset:auto 0 0;height:46%;background:linear-gradient(180deg,transparent,rgba(8,8,12,.16));pointer-events:none}.library-card-placeholder,.details-preview-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;text-align:center;padding:16px;background:linear-gradient(135deg,#ec48991f,#ffffff0a),repeating-conic-gradient(from 45deg,#ffffff05,#ffffff05 25%,#ffffff0a 0%,#ffffff0a 50%) 50% / 22px 22px}.library-card-image,.details-preview-image{width:100%;height:100%;object-fit:contain;padding:14px;display:none}.library-card-image-topbar{position:absolute;inset:12px 12px auto;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;z-index:1}.library-status-chip{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.library-card-image-wrap .library-status-chip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.badge-processing{background:#ec48992e;color:var(--accent-hover);border:1px solid rgba(236,72,153,.28)}.badge-queued{background:#ffffff14;color:var(--text-secondary);border:1px solid rgba(255,255,255,.14)}.badge-failed{background:var(--error-bg);color:#fca5a5;border:1px solid rgba(239,68,68,.28)}.badge-completed{background:var(--success-bg);color:#86efac;border:1px solid rgba(34,197,94,.3)}.library-card-body{display:flex;flex-direction:column;flex:1;gap:12px;padding:16px 16px 18px}.library-card-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.library-card-date,.library-card-id{font-size:12px;color:var(--text-muted)}.library-card-id{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#ffffff0d}.library-card-name{font-size:15px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-card-phase{font-size:12px;color:var(--text-secondary);line-height:1.5;min-height:36px}.library-card-progress{display:grid;gap:6px}.library-card-progress-bar{height:6px;border-radius:999px;background:#ffffff14;overflow:hidden}.library-card-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent) 0%,#fb7185 100%)}.library-card-progress-text{font-size:11px;color:var(--text-muted)}.library-card-actions{display:flex;align-items:center;gap:10px;margin-top:auto}.library-card-download,.library-card-action{flex:1}.library-card-action-secondary{flex:0 0 auto;min-width:112px}.library-card-menu{position:relative}.library-card-menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:#08080cb8;color:var(--text-secondary);font:inherit;font-size:18px;line-height:1;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:border-color .18s ease,background .18s ease,color .18s ease}.library-card-menu-toggle:hover,.library-card-menu:focus-within .library-card-menu-toggle{border-color:#ffffff3d;background:#121218e6;color:var(--text)}.library-card-menu-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:148px;padding:6px;border:1px solid var(--border);border-radius:14px;background:#121218f5;box-shadow:0 18px 40px #00000047;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .16s ease,transform .16s ease}.library-card-menu:focus-within .library-card-menu-popover{opacity:1;transform:translateY(0);pointer-events:auto}.library-card-menu-item{width:100%;border:0;border-radius:10px;background:transparent;color:var(--text-secondary);font:inherit;font-size:13px;font-weight:600;text-align:left;padding:10px 12px;cursor:pointer;transition:background .18s ease,color .18s ease}.library-card-menu-item:hover:not(:disabled){background:#ffffff0f;color:var(--text)}.library-card-menu-item-danger{color:#fca5a5}.library-card-menu-item-danger:hover:not(:disabled){background:#ef44441f;color:#fecaca}.library-card-menu-item:disabled{opacity:.6;cursor:wait}.library-loading,.library-error{text-align:center;padding:56px 18px;color:var(--text-muted)}.library-error{color:var(--error)}.library-empty{padding:72px 24px;border:1px dashed rgba(236,72,153,.22);border-radius:var(--radius-lg);text-align:center;background:#ffffff05;display:grid;gap:16px;justify-items:center}.library-empty-title{font-size:24px;font-weight:700;margin-bottom:10px}.library-empty-copy{color:var(--text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:grid;place-items:center;padding:28px}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#06060ab8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.modal-dialog{position:relative;width:min(760px,100%);max-height:min(88vh,920px);overflow:auto;background:var(--bg-panel-strong);border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow-xl)}.details-modal-dialog{width:min(900px,100%)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 0}.modal-close{width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-size:24px;cursor:pointer}.modal-close:hover{border-color:var(--border-hover);background:#ffffff14}.modal-content{padding:24px}.state{display:flex;flex-direction:column;align-items:center;gap:20px}.state-title{font-size:22px;font-weight:700;text-align:center}.state-sub{font-size:14px;color:var(--text-secondary);text-align:center;line-height:1.6}.state-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.drop-zone{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;padding:48px 24px;border:2px dashed rgba(236,72,153,.24);border-radius:var(--radius);cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .2s ease;background:linear-gradient(180deg,#ec48990f,#ffffff05)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:#ec489914;transform:translateY(-1px)}.upload-icon{color:var(--accent-hover)}.drop-text{font-size:18px;font-weight:600;color:var(--text)}.drop-sub,.drop-hint{font-size:13px;color:var(--text-muted);text-align:center}.preview-container{position:relative;width:100%;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:#ffffff05}.preview-image{display:block;width:100%;max-height:420px;object-fit:contain;background:repeating-conic-gradient(#27272a,#27272a 25%,#18181b 0%,#18181b 50%) 50% / 20px 20px}#remove-image{position:absolute;top:10px;right:10px}.preview-info{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;background:#0000006b;font-size:13px;color:var(--text-secondary)}.file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}.spinner-container{padding:8px}.spinner{width:54px;height:54px;border:3px solid rgba(255,255,255,.12);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-bar{width:100%;height:6px;background:#ffffff14;border-radius:999px;overflow:hidden}.progress-bar-inner{height:100%;width:0%;background:linear-gradient(90deg,var(--accent) 0%,#fb7185 100%);transition:width .35s ease}.success-icon{color:var(--success)}.success-icon svg{filter:drop-shadow(0 0 12px rgba(34,197,94,.32))}.error-icon{color:var(--error)}.error-icon svg{filter:drop-shadow(0 0 12px rgba(239,68,68,.32))}.details-content{min-height:260px}.details-grid{display:grid;grid-template-columns:minmax(280px,1fr) minmax(280px,360px);gap:20px;align-items:start}.details-preview-wrap{position:relative;aspect-ratio:1 / 1;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:#ffffff05}.details-panel{display:flex;flex-direction:column;gap:14px;padding:18px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffff05}.details-row{display:flex;flex-direction:column;gap:6px}.details-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.details-value{font-size:14px;color:var(--text-secondary);line-height:1.5}.details-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;word-break:break-all}.details-actions{display:flex;gap:10px;padding-top:8px}.app-footer{text-align:center;padding:16px;font-size:13px;color:var(--text-muted);border-top:1px solid var(--border);background:#08080c80}@media(max-width:900px){.library-toolbar{flex-direction:column;align-items:stretch}.library-toolbar-actions{justify-content:stretch}.toolbar-field,.toolbar-layout-group,.toolbar-create-btn{width:100%}.toolbar-create-btn{justify-content:center}.details-grid{grid-template-columns:1fr}}@media(max-width:640px){.language-switcher{top:10px;right:10px;padding:6px 8px}.language-switcher-label,.user-email{display:none}.auth-card{padding:32px 24px}.app-header{padding:12px 14px}.header-right{gap:8px}.credits-pill{min-width:0;padding:6px 10px;font-size:12px}.app-body{padding:18px 12px 24px}.library-toolbar,.modal-content,.modal-header{padding-inline:16px}.modal-title{font-size:26px}.library-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.library-card-actions{flex-direction:column}.library-card-download,.library-card-action,.library-card-action-secondary{width:100%;min-width:0}.modal{padding:12px}.modal-dialog{border-radius:22px}.drop-zone{padding:34px 18px}.state-actions,.state-actions .btn{width:100%}.preview-info{flex-direction:column}}
