*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--lw-bg: #08080f;--lw-surface: #111119;--lw-surface-2: #191922;--lw-surface-3: #1e1e2a;--lw-overlay: rgba(8, 8, 15, .85);--lw-border: #252535;--lw-border-2: #2e2e42;--lw-text: #e8e0d0;--lw-text-muted: #9090a8;--lw-text-dim: #5a5a72;--lw-gold: #c9a84c;--lw-gold-dim: #6b5a28;--lw-gold-glow: rgba(201, 168, 76, .15);--lw-purple: #7c3aed;--lw-purple-light: #a78bfa;--lw-success: #22c55e;--lw-success-bg: #052e16;--lw-success-border: #166534;--lw-warning: #f59e0b;--lw-warning-bg: #1c1200;--lw-danger: #ef4444;--lw-danger-bg: #450a0a;--lw-danger-border: #7f1d1d;--lw-info: #3b82f6;--lw-info-bg: #0c1a3d;--lw-status-lobby: #3b82f6;--lw-status-active: #22c55e;--lw-status-paused: #f59e0b;--lw-status-ended: #6b7280;--lw-tier-trial: #3b2f00;--lw-tier-starter: #1e3a5f;--lw-tier-pro: #1e3a2a;--lw-tier-enterprise: #3b1f5e;--lw-font-sans: system-ui, -apple-system, "Segoe UI", sans-serif;--lw-font-serif: "Georgia", "Times New Roman", serif;--lw-font-mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;--lw-space-1: 4px;--lw-space-2: 8px;--lw-space-3: 12px;--lw-space-4: 16px;--lw-space-5: 20px;--lw-space-6: 24px;--lw-space-8: 32px;--lw-radius-sm: 4px;--lw-radius: 6px;--lw-radius-lg: 10px;--lw-radius-xl: 14px;--lw-radius-full: 9999px;--lw-shadow-sm: 0 1px 3px rgba(0,0,0,.4);--lw-shadow: 0 4px 16px rgba(0,0,0,.5);--lw-shadow-lg: 0 8px 32px rgba(0,0,0,.6);--lw-shadow-gold: 0 0 20px rgba(201,168,76,.12);--lw-transition: .15s ease;--lw-transition-slow: .3s ease}html,body{font-family:var(--lw-font-sans)}.lw-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--lw-space-2);border:none;border-radius:var(--lw-radius);font-family:var(--lw-font-sans);font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap;transition:opacity var(--lw-transition),background var(--lw-transition),box-shadow var(--lw-transition),color var(--lw-transition);outline:none;position:relative;-webkit-user-select:none;user-select:none}.lw-btn:focus-visible{outline:2px solid var(--lw-gold);outline-offset:2px}.lw-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.lw-btn--sm{padding:5px 12px;font-size:.78rem}.lw-btn--md{padding:8px 16px;font-size:.875rem}.lw-btn--lg{padding:11px 22px;font-size:1rem}.lw-btn--primary{background:var(--lw-gold);color:#080810}.lw-btn--primary:hover:not(:disabled){opacity:.88;box-shadow:var(--lw-shadow-gold)}.lw-btn--brand{background:var(--lw-purple);color:#fff}.lw-btn--brand:hover:not(:disabled){background:#6d28d9}.lw-btn--secondary{background:var(--lw-surface-3);color:var(--lw-text-muted);border:1px solid var(--lw-border-2)}.lw-btn--secondary:hover:not(:disabled){background:var(--lw-surface-2);color:var(--lw-text);border-color:var(--lw-text-dim)}.lw-btn--ghost{background:transparent;color:var(--lw-text-muted)}.lw-btn--ghost:hover:not(:disabled){background:var(--lw-surface-3);color:var(--lw-text)}.lw-btn--danger{background:var(--lw-danger-bg);color:#fca5a5;border:1px solid var(--lw-danger-border)}.lw-btn--danger:hover:not(:disabled){background:#5a0d0d;border-color:#ef4444}.lw-btn--success{background:var(--lw-success-bg);color:#86efac;border:1px solid var(--lw-success-border)}.lw-btn--success:hover:not(:disabled){background:#064e1e}.lw-btn--warning{background:var(--lw-warning-bg);color:#fcd34d;border:1px solid #713f12}.lw-btn--warning:hover:not(:disabled){background:#291a00}.lw-btn--outline{background:transparent;color:var(--lw-text-muted);border:1px solid var(--lw-border-2)}.lw-btn--outline:hover:not(:disabled){border-color:var(--lw-text-muted);color:var(--lw-text)}.lw-btn--copy{background:transparent;color:#60a5fa;border:1px solid #1e3a5f}.lw-btn--copy:hover:not(:disabled){background:var(--lw-info-bg)}.lw-btn--export{background:transparent;color:var(--lw-gold);border:1px solid var(--lw-gold-dim)}.lw-btn--export:hover:not(:disabled){background:var(--lw-gold-glow)}.lw-btn--loading{pointer-events:none}.lw-btn__spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:lw-spin .6s linear infinite;flex-shrink:0}.lw-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--lw-radius-full);font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.lw-badge--lobby{background:#1e3a5f;color:#93c5fd}.lw-badge--active{background:#052e16;color:#86efac;border:1px solid #166534}.lw-badge--paused{background:#1c1200;color:#fcd34d;border:1px solid #713f12}.lw-badge--ended{background:var(--lw-surface-3);color:var(--lw-text-dim)}.lw-badge--trial{background:var(--lw-tier-trial);color:#fcd34d}.lw-badge--starter{background:var(--lw-tier-starter);color:#93c5fd}.lw-badge--pro{background:var(--lw-tier-pro);color:#86efac}.lw-badge--enterprise{background:var(--lw-tier-enterprise);color:#d8b4fe}.lw-badge--success{background:var(--lw-success-bg);color:#86efac;border:1px solid var(--lw-success-border)}.lw-badge--warning{background:#1c1200;color:#fcd34d}.lw-badge--danger{background:var(--lw-danger-bg);color:#fca5a5}.lw-badge--neutral{background:var(--lw-surface-3);color:var(--lw-text-muted);border:1px solid var(--lw-border-2)}.lw-badge--info{background:var(--lw-info-bg);color:#93c5fd}.lw-badge--brand{background:#2e1065;color:#c4b5fd}.lw-badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.lw-card{background:var(--lw-surface);border:1px solid var(--lw-border);border-radius:var(--lw-radius-lg);overflow:hidden;position:relative}.lw-card--elevated{background:var(--lw-surface-2);box-shadow:var(--lw-shadow)}.lw-card--interactive{cursor:pointer;transition:border-color var(--lw-transition),box-shadow var(--lw-transition)}.lw-card--interactive:hover{border-color:var(--lw-border-2);box-shadow:var(--lw-shadow-sm)}.lw-card__header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--lw-border);gap:var(--lw-space-3)}.lw-card__header-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--lw-text-dim)}.lw-card__body{padding:16px}.lw-card__body--compact{padding:10px 14px}.lw-card__footer{padding:10px 16px;border-top:1px solid var(--lw-border);display:flex;align-items:center;gap:var(--lw-space-2)}.lw-field{display:flex;flex-direction:column;gap:6px}.lw-label{font-size:.8rem;font-weight:600;color:var(--lw-text-muted);letter-spacing:.02em}.lw-label--required:after{content:" *";color:var(--lw-danger)}.lw-input,.lw-select,.lw-textarea{background:var(--lw-surface-2);border:1px solid var(--lw-border-2);border-radius:var(--lw-radius);padding:9px 12px;color:var(--lw-text);font-family:var(--lw-font-sans);font-size:.925rem;width:100%;outline:none;transition:border-color var(--lw-transition),box-shadow var(--lw-transition);-moz-appearance:none;appearance:none;-webkit-appearance:none}.lw-input::placeholder,.lw-textarea::placeholder{color:var(--lw-text-dim)}.lw-input:focus,.lw-select:focus,.lw-textarea:focus{border-color:var(--lw-gold);box-shadow:0 0 0 3px var(--lw-gold-glow)}.lw-input--error,.lw-select--error,.lw-textarea--error{border-color:var(--lw-danger)}.lw-input--error:focus,.lw-select--error:focus,.lw-textarea--error:focus{box-shadow:0 0 0 3px #ef444426}.lw-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239090a8' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.lw-select option{background:var(--lw-surface-3);color:var(--lw-text)}.lw-textarea{resize:vertical;min-height:80px;line-height:1.5}.lw-field__hint{font-size:.78rem;color:var(--lw-text-dim);line-height:1.4}.lw-field__error{font-size:.78rem;color:var(--lw-danger);display:flex;align-items:center;gap:4px}.lw-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--lw-text-dim)}.lw-status-dot--connected{background:var(--lw-success)}.lw-status-dot--connecting{background:var(--lw-gold);animation:lw-pulse 1.2s ease-in-out infinite}.lw-status-dot--error{background:var(--lw-danger)}.lw-status-dot--idle{background:var(--lw-text-dim)}.lw-status-dot--warning{background:var(--lw-warning)}.lw-status-dot--sm{width:6px;height:6px}.lw-status-dot--lg{width:10px;height:10px}.lw-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--lw-space-3);padding:40px 24px;color:var(--lw-text-muted)}.lw-empty__icon{font-size:2.5rem;opacity:.5;line-height:1}.lw-empty__title{font-size:.95rem;font-weight:600;color:var(--lw-text-muted)}.lw-empty__desc{font-size:.85rem;color:var(--lw-text-dim);max-width:280px;line-height:1.5}.lw-spinner{display:inline-block;border-radius:50%;border-style:solid;border-top-color:transparent;animation:lw-spin .7s linear infinite;flex-shrink:0}.lw-spinner--sm{width:14px;height:14px;border-width:2px}.lw-spinner--md{width:20px;height:20px;border-width:2px}.lw-spinner--lg{width:32px;height:32px;border-width:3px}.lw-spinner--gold{border-color:var(--lw-gold-dim);border-top-color:var(--lw-gold)}.lw-spinner--muted{border-color:var(--lw-border-2);border-top-color:var(--lw-text-muted)}.lw-spinner--white{border-color:#ffffff40;border-top-color:#fff}.lw-loading-row{display:flex;align-items:center;justify-content:center;gap:var(--lw-space-3);padding:40px 24px;color:var(--lw-text-dim);font-size:.875rem}.lw-toast-portal{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--lw-space-2);z-index:9999;pointer-events:none;align-items:center}.lw-toast{display:flex;align-items:center;gap:var(--lw-space-2);padding:10px 18px;border-radius:var(--lw-radius-lg);font-size:.875rem;font-weight:500;box-shadow:var(--lw-shadow-lg);pointer-events:auto;white-space:nowrap;max-width:420px;animation:lw-toast-in .25s ease}.lw-toast--default{background:var(--lw-surface-3);border:1px solid var(--lw-border-2);color:var(--lw-text)}.lw-toast--success{background:var(--lw-success-bg);border:1px solid var(--lw-success-border);color:#86efac}.lw-toast--error{background:var(--lw-danger-bg);border:1px solid var(--lw-danger-border);color:#fca5a5}.lw-toast--warning{background:var(--lw-warning-bg);border:1px solid #713f12;color:#fcd34d}@keyframes lw-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.lw-alert{display:flex;align-items:flex-start;gap:var(--lw-space-3);padding:12px 16px;border-radius:var(--lw-radius);font-size:.875rem;line-height:1.5}.lw-alert--error{background:var(--lw-danger-bg);border:1px solid var(--lw-danger-border);color:#fca5a5}.lw-alert--success{background:var(--lw-success-bg);border:1px solid var(--lw-success-border);color:#86efac}.lw-alert--warning{background:#1c1200;border:1px solid #713f12;color:#fcd34d}.lw-alert--info{background:var(--lw-info-bg);border:1px solid #1e3a8a;color:#93c5fd}.lw-table{width:100%;border-collapse:collapse;font-size:.875rem}.lw-table th{text-align:left;padding:8px 14px;color:var(--lw-text-dim);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--lw-border);white-space:nowrap}.lw-table td{padding:12px 14px;border-bottom:1px solid var(--lw-border);vertical-align:middle;color:var(--lw-text)}.lw-table tr:last-child td{border-bottom:none}.lw-table tr:hover td{background:#ffffff04}.lw-table--compact th{padding:6px 12px}.lw-table--compact td{padding:8px 12px}.lw-section-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--lw-text-dim);padding-bottom:10px;border-bottom:1px solid var(--lw-border);margin-bottom:16px}.lw-divider{border:none;border-top:1px solid var(--lw-border);margin:20px 0}.lw-mono{font-family:var(--lw-font-mono);font-size:.85em}.lw-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lw-text-muted{color:var(--lw-text-muted)}.lw-text-dim{color:var(--lw-text-dim)}.lw-text-gold{color:var(--lw-gold)}.lw-text-danger{color:var(--lw-danger)}.lw-text-success{color:var(--lw-success)}@keyframes lw-spin{to{transform:rotate(360deg)}}@keyframes lw-pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes lw-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.lw-animate-fade-in{animation:lw-fade-in .2s ease forwards}html,body,#root{height:100%;background:var(--lw-bg);color:var(--lw-text);font-family:var(--lw-font-sans);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.portal-nav{display:flex;align-items:center;gap:8px;padding:0 24px;height:56px;background:var(--lw-surface);border-bottom:1px solid var(--lw-border);position:sticky;top:0;z-index:100}.portal-nav__brand{display:flex;align-items:center;gap:10px;text-decoration:none;margin-right:auto}.portal-nav__logo{width:28px;height:28px;background:linear-gradient(135deg,var(--lw-gold) 0%,#e8c56a 100%);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;box-shadow:0 0 10px var(--lw-gold-glow)}.portal-nav__name{font-size:.925rem;font-weight:700;color:var(--lw-gold);letter-spacing:.02em}.portal-nav__subtitle{font-size:.72rem;color:var(--lw-text-dim);text-transform:uppercase;letter-spacing:.1em}.portal-nav__links{display:flex;gap:4px;margin-right:16px}.portal-nav__link{padding:6px 12px;border-radius:var(--lw-radius);font-size:.875rem;font-weight:500;color:var(--lw-text-muted);text-decoration:none;transition:background var(--lw-transition),color var(--lw-transition)}.portal-nav__link:hover{background:var(--lw-surface-3);color:var(--lw-text)}.portal-nav__link--active{color:var(--lw-text);background:var(--lw-surface-3)}.portal-page{min-height:calc(100vh - 56px);padding:28px 24px;max-width:1040px;margin:0 auto}.portal-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.portal-page__title{font-size:1.5rem;font-weight:700;color:var(--lw-text);margin:0}.portal-page__subtitle{font-size:.875rem;color:var(--lw-text-muted);margin:4px 0 0}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.character-card{background:var(--lw-surface);border:1px solid var(--lw-border);border-radius:var(--lw-radius-lg);overflow:hidden;transition:border-color var(--lw-transition),box-shadow var(--lw-transition);cursor:pointer;text-decoration:none;display:flex;flex-direction:column}.character-card:hover{border-color:var(--lw-gold);box-shadow:0 0 16px var(--lw-gold-glow)}.character-card__portrait{width:100%;aspect-ratio:3/2;object-fit:cover;background:var(--lw-surface-2);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--lw-text-dim)}.character-card__portrait img{width:100%;height:100%;object-fit:cover}.character-card__body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:4px}.character-card__name{font-size:1rem;font-weight:700;color:var(--lw-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.character-card__meta{font-size:.78rem;color:var(--lw-text-muted)}.character-card__system{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 8px;border-radius:var(--lw-radius-sm);background:var(--lw-surface-2);color:var(--lw-purple-light);border:1px solid var(--lw-border);margin-top:6px}.character-card__add{border:2px dashed var(--lw-border-2);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:180px;color:var(--lw-text-dim);font-size:.875rem;transition:border-color var(--lw-transition),color var(--lw-transition)}.character-card__add:hover{border-color:var(--lw-gold);color:var(--lw-gold)}.character-card__add-icon{font-size:1.75rem;line-height:1}.builder-steps{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap}.builder-step{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--lw-text-dim)}.builder-step--active{color:var(--lw-gold);font-weight:600}.builder-step--done{color:var(--lw-success, #4ade80)}.builder-step__num{width:20px;height:20px;border-radius:50%;background:var(--lw-surface-2);border:1px solid var(--lw-border);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}.builder-step--active .builder-step__num{background:var(--lw-gold);border-color:var(--lw-gold);color:#000}.builder-step--done .builder-step__num{background:var(--lw-success, #4ade80);border-color:var(--lw-success, #4ade80);color:#000}.builder-step__sep{color:var(--lw-border-2);margin:0 2px}.builder-panel{background:var(--lw-surface);border:1px solid var(--lw-border);border-radius:var(--lw-radius-lg);padding:28px}.builder-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--lw-border)}.drop-zone{border:2px dashed var(--lw-border-2);border-radius:var(--lw-radius-lg);padding:48px 24px;text-align:center;cursor:pointer;transition:border-color var(--lw-transition),background var(--lw-transition)}.drop-zone:hover,.drop-zone--over{border-color:var(--lw-gold);background:#d4af370a}.drop-zone__icon{font-size:2.5rem;margin-bottom:12px}.drop-zone__title{font-size:1rem;font-weight:600;color:var(--lw-text)}.drop-zone__sub{font-size:.82rem;color:var(--lw-text-muted);margin-top:4px}.history-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--lw-border)}.history-row:last-child{border-bottom:none}.history-row__icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.history-row__body{flex:1;min-width:0}.history-row__title{font-size:.95rem;font-weight:600;color:var(--lw-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-row__meta{font-size:.78rem;color:var(--lw-text-muted);margin-top:2px}.character-detail{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}.character-detail__portrait{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--lw-radius-lg);background:var(--lw-surface-2);display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--lw-text-dim);overflow:hidden}.character-detail__portrait img{width:100%;height:100%;object-fit:cover}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--lw-border);margin-bottom:20px}.tab{padding:8px 16px;font-size:.875rem;font-weight:500;color:var(--lw-text-muted);border-bottom:2px solid transparent;cursor:pointer;background:none;border-top:none;border-left:none;border-right:none;transition:color var(--lw-transition),border-color var(--lw-transition);margin-bottom:-1px}.tab:hover{color:var(--lw-text)}.tab--active{color:var(--lw-gold);border-bottom-color:var(--lw-gold)}.backstory-textarea{width:100%;min-height:180px;background:var(--lw-surface-2);border:1px solid var(--lw-border);border-radius:var(--lw-radius);color:var(--lw-text);font-family:var(--lw-font-sans);font-size:.9rem;line-height:1.6;padding:12px 14px;resize:vertical;transition:border-color var(--lw-transition);box-sizing:border-box}.backstory-textarea:focus{outline:none;border-color:var(--lw-gold)}.portrait-upload-wrap{position:relative}.portrait-upload-btn{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--lw-radius);padding:5px 10px;font-size:.75rem;cursor:pointer;transition:background var(--lw-transition)}.portrait-upload-btn:hover{background:#000000e6}@media (max-width: 768px){.character-detail{grid-template-columns:1fr}.character-detail__portrait{aspect-ratio:16/9}}@media (max-width: 640px){.portal-page{padding:20px 16px}.portal-page__header{flex-direction:column;align-items:flex-start}.character-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.portal-nav__subtitle{display:none}.builder-panel{padding:20px 16px}}
