:root{--bg: #050816;--bg-soft: #0b1020;--accent: #fbbf24;--accent-soft: rgba(251, 191, 36, .1);--text: #f9fafb;--muted: #9ca3af;--error: #f97373;--radius-lg: 18px;--radius-md: 14px;--radius-pill: 999px;--shadow-soft: 0 18px 40px rgba(15, 23, 42, .65)}*{scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}*::-webkit-scrollbar{width:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}*::-webkit-scrollbar-thumb:hover{background:#94a3b880}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}button,a,[role=button],[onclick]{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}html,body{margin:0;padding:0;background:radial-gradient(circle at top,#1f2937 0,#020617 55%);color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;position:relative;overflow-x:hidden;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100)}body{min-height:100vh;min-height:100dvh;min-height:calc(var(--vh, 1vh) * 100)}#root{height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);display:flex;justify-content:center;align-items:stretch;overflow:hidden;position:relative;z-index:1}.app-shell{width:100%;max-width:480px;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);padding:12px;display:flex;flex-direction:column;gap:8px;overflow:hidden}.card{background:radial-gradient(circle at top left,#111827 0,#020617 65%);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:12px;border:1px solid rgba(148,163,184,.2)}.edit-characters-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:16px}.edit-characters-screen{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;gap:16px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.edit-characters-screen::-webkit-scrollbar{width:6px}.edit-characters-screen::-webkit-scrollbar-track{background:transparent}.edit-characters-screen::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.edit-characters-screen::-webkit-scrollbar-thumb:hover{background:#94a3b880}.edit-characters-back-button{position:sticky;bottom:0;margin-top:auto;padding-top:16px;border-top:1px solid rgba(148,163,184,.1);z-index:10;flex-shrink:0}.characters-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:8px 0}.character-grid-item{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;padding:12px;border-radius:var(--radius-md);transition:background .15s ease,transform .15s ease;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.character-grid-item:hover{background:#94a3b81a;transform:translateY(-2px)}.character-grid-avatar.character-add-avatar{width:64px;height:64px;background:#94a3b84d;border:3px dashed rgba(255,255,255,.4);color:#fffc;font-size:1.2rem;font-weight:300;line-height:1;transition:all .15s ease}.character-grid-avatar.character-add-avatar:hover{background:#94a3b880!important;border-color:#fff9!important;transform:scale(1.1)}.character-grid-name{font-size:.85rem;font-weight:500;text-align:center;line-height:1.3;color:var(--text);max-width:100px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.character-edit-modal .character-modal-content{padding:24px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.brand{display:flex;flex-direction:column;gap:2px}.brand-title{font-size:1.2rem;font-weight:700;letter-spacing:.03em}.brand-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;font-size:.68rem;border-radius:var(--radius-pill);background:radial-gradient(circle at top left,#f59e0b,#eab308);color:#020617;font-weight:600}.brand-pill-dot{width:7px;height:7px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 3px #22c55e59}.avatar-orb{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 30% 0,#fbbf24,#4f46e5 60%,#0f172a);border:2px solid rgba(248,250,252,.7);position:relative;box-shadow:0 16px 40px #0f172ab3}.avatar-orb:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:inherit;border:1px solid rgba(248,250,252,.4);opacity:.6}.stepper{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-top:10px}.step-pill{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 0;border-radius:var(--radius-pill);font-size:.7rem;background:#0f172ab3;color:var(--muted)}.step-pill.active{background:linear-gradient(90deg,#fbbf24,#eab308);color:#020617;font-weight:600}.step-pill-dot{width:6px;height:6px;border-radius:999px;background:#94a3b8e6}.step-pill.active .step-pill-dot{background:#16a34a}.screen{display:flex;flex-direction:column;gap:16px}.screen-title{font-size:1.06rem;font-weight:650}.screen-subtitle{font-size:.8rem;color:var(--muted)}.two-col-inline{display:flex;gap:10px}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.field-label-row{display:flex;justify-content:space-between;align-items:baseline}.field label{font-size:.75rem;font-weight:500;color:#e5e7eb}.field-helper{font-size:.7rem;color:var(--muted)}.input,.select{border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.4);padding:9px 11px;font-size:.85rem;background:#0f172ae6;color:var(--text);outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;-webkit-user-select:text;user-select:text}.input::placeholder{color:#94a3b8cc}.input:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 1px #fbbf2480;background:#0f172a}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.pill{border-radius:var(--radius-pill);padding:6px 11px;font-size:.78rem;border:1px solid rgba(148,163,184,.65);color:var(--muted);background:#0f172acc;cursor:pointer;display:inline-flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.pill.active{border-color:var(--accent);background:radial-gradient(circle at top left,#fbbf2440,#0f172af2);color:var(--text)}.pill-dot{width:6px;height:6px;border-radius:999px;background:#94a3b8e6}.pill.active .pill-dot{background:#22c55e}.badge{display:inline-flex;align-items:center;gap:6px;border-radius:var(--radius-pill);padding:4px 9px;font-size:.68rem;background:#0f172ae6;border:1px dashed rgba(148,163,184,.6);color:var(--muted)}.story-length-row{display:flex;flex-direction:column;gap:8px;margin-top:0;margin-bottom:8px}.length-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted)}.length-labels span{flex:1}.length-labels span:first-child{text-align:left}.length-labels span:last-child{text-align:right}.length-labels span:not(:first-child):not(:last-child){text-align:center}.length-labels span[data-active=true]{color:var(--accent);font-weight:600}.slider-wrapper{position:relative;padding:10px 4px 0}.slider-track{position:absolute;left:18px;right:18px;top:22px;height:4px;border-radius:999px;background:linear-gradient(90deg,#374151e6,#0f172ae6)}.slider-fill{position:absolute;left:18px;top:22px;height:4px;border-radius:999px;background:linear-gradient(90deg,#fbbf24,#22c55e);max-width:calc(100% - 36px);box-sizing:border-box}.slider-input{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;position:relative;margin:0}.slider-input:focus{outline:none}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:transparent;border:none;box-shadow:none;cursor:pointer;font-size:24px;line-height:1;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'><text x='50%' y='50%' font-size='24' text-anchor='middle' dominant-baseline='central'>⭐</text></svg>");background-size:28px 28px;background-repeat:no-repeat;background-position:center center}.slider-input::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:transparent;border:none;box-shadow:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'><text x='50%' y='50%' font-size='24' text-anchor='middle' dominant-baseline='central'>⭐</text></svg>");background-size:28px 28px;background-repeat:no-repeat;background-position:center center}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{border-radius:var(--radius-pill);padding:4px 9px;font-size:.7rem;background:#0f172ae6;border:1px solid rgba(148,163,184,.4);display:inline-flex;align-items:center;gap:6px}.chip-dot{width:6px;height:6px;border-radius:999px;background:#fbbf24}.chip-delete{cursor:pointer;font-size:.75rem;color:var(--muted)}.error-text{color:var(--error);font-size:.7rem}.button-row{display:flex;gap:10px;margin-top:6px}.btn{flex:1;border-radius:var(--radius-pill);padding:10px 14px;border:none;font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.btn-primary{background:linear-gradient(90deg,#fbbf24,#eab308);color:#020617;box-shadow:none}.btn-secondary{background:#0f172af2;color:var(--muted);border:1px solid rgba(148,163,184,.6)}.btn:disabled{opacity:.5;cursor:default;box-shadow:none}.footer{margin-top:auto;font-size:.7rem;color:#94a3b8cc;text-align:center}.footer span{color:#f8fafce6}.chat-window{margin-top:8px;padding:10px 10px 12px;border-radius:var(--radius-md);background:radial-gradient(circle at top left,#020617,#020617 55%,#020617);border:1px solid rgba(148,163,184,.35)}.chat-messages{max-height:260px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-top:8px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#94a3b880}.chat-bubble{padding:8px 10px;border-radius:14px;font-size:.8rem;line-height:1.4}.chat-bubble p{white-space:pre-wrap;margin:0}.chat-bubble-assistant{background:radial-gradient(circle at top left,#fbbf2429,#0f172af2);border:1px solid rgba(251,191,36,.45)}.chat-bubble-system{background:#0f172af2;border:1px dashed rgba(148,163,184,.6);color:var(--muted)}.chat-bubble p{margin:0 0 .5em}.chat-bubble p:last-child{margin-bottom:0}.chat-bubble strong,.chat-bubble b{font-weight:600;color:inherit}.chat-bubble em,.chat-bubble i{font-style:italic}.chat-bubble code{background:#0000004d;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.85em;color:#fbbf24}.chat-bubble pre{background:#0000004d;padding:8px 12px;border-radius:6px;overflow-x:auto;margin:.5em 0}.chat-bubble pre code{background:transparent;padding:0;color:inherit;font-size:.85em}.chat-bubble a{color:#fbbf24;text-decoration:underline;text-underline-offset:2px}.chat-bubble a:hover{color:#fcd34d}.chat-bubble ul,.chat-bubble ol{margin:.5em 0;padding-left:1.5em}.chat-bubble li{margin:.25em 0}.chat-bubble h1,.chat-bubble h2,.chat-bubble h3,.chat-bubble h4,.chat-bubble h5,.chat-bubble h6{margin:.75em 0 .5em;font-weight:600;line-height:1.3}.chat-bubble h1:first-child,.chat-bubble h2:first-child,.chat-bubble h3:first-child,.chat-bubble h4:first-child,.chat-bubble h5:first-child,.chat-bubble h6:first-child{margin-top:0}.chat-bubble h1{font-size:1.3em}.chat-bubble h2{font-size:1.2em}.chat-bubble h3{font-size:1.1em}.chat-bubble blockquote{border-left:3px solid rgba(251,191,36,.5);padding-left:1em;margin:.5em 0;color:var(--muted);font-style:italic}.chat-bubble hr{border:none;border-top:1px solid rgba(148,163,184,.3);margin:1em 0}.chat-bubble img{max-width:100%;height:auto;border-radius:6px;margin:.5em 0}.chat-bubble table{border-collapse:collapse;margin:.5em 0;width:100%}.chat-bubble th,.chat-bubble td{border:1px solid rgba(148,163,184,.3);padding:6px 8px;text-align:left}.chat-bubble th{background:#fbbf241a;font-weight:600}.chat-author{font-size:.7rem;font-weight:600;margin-bottom:4px;color:#fde68a}.chat-header{padding:8px 0;border-bottom:1px solid rgba(148,163,184,.2);margin-bottom:8px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.chat-header-top{display:flex;align-items:center;width:100%}.chat-header-brand{display:flex;align-items:center;gap:12px;flex:1}.chat-header-separator{height:1px;background:#94a3b833;width:100%;margin:4px 0 0}.chat-header-characters-row{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}.chat-header-characters{display:flex;align-items:center;justify-content:center;gap:8px;flex:1;flex-wrap:wrap}.chat-header-characters-label{font-size:.85rem;color:var(--muted);font-weight:500;white-space:nowrap}.tonights-heroes-layout{display:flex;align-items:center;gap:0;flex-wrap:wrap;justify-content:center}.heroes-section{display:flex;align-items:center;gap:8px;padding:0 8px}.heroes-section-divider{width:1px;height:36px;background:#94a3b833;flex-shrink:0}.character-section-with-label{display:flex;flex-direction:column;align-items:center;gap:4px}.heroes-section-label{font-size:.65rem;color:var(--muted);font-weight:400;text-transform:uppercase;letter-spacing:.3px;opacity:.6;white-space:nowrap;margin-top:0;height:14px;display:flex;align-items:center}.characters-avatar-list{display:flex;align-items:center;justify-content:center;gap:6px;height:48px;min-height:48px}.characters-empty-message{font-size:.8rem;color:var(--muted);font-style:italic}.character-avatar-item{display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s ease;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.character-avatar-item:hover{transform:scale(1.1)}.character-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.7rem;color:#fff;box-shadow:0 2px 6px #00000040;border:2px solid rgba(255,255,255,.3);flex-shrink:0}.character-avatar.character-grid-avatar{width:64px;height:64px;font-size:1.2rem;border:3px solid rgba(255,255,255,.3);box-shadow:0 2px 6px #00000040}.character-add-container{position:relative}.character-add-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.character-add-avatar{background:#94a3b84d!important;border:2px dashed rgba(255,255,255,.4)!important;color:#fffc;font-size:1.2rem;font-weight:300;transition:all .15s ease}.character-add-avatar:hover{background:#94a3b880!important;border-color:#fff9!important;transform:scale(1.1)}.character-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000}.character-popup{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:500px;background:radial-gradient(circle at top left,#111827 0,#020617 65%);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);border:1px solid rgba(148,163,184,.2);z-index:1001;display:flex;flex-direction:column;overflow:hidden}.character-popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgba(148,163,184,.2)}.character-popup-header h3{margin:0;font-size:1rem;font-weight:600}.character-popup-header-sublabel{font-size:.7rem;color:var(--muted);margin-top:2px;font-weight:400}.character-popup-close{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .15s ease}.character-popup-close:hover{color:var(--text)}.character-popup-list{flex:1;overflow-y:auto;padding:8px;max-height:300px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.character-popup-list::-webkit-scrollbar{width:6px}.character-popup-list::-webkit-scrollbar-track{background:transparent}.character-popup-list::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.character-popup-list::-webkit-scrollbar-thumb:hover{background:#94a3b880}.character-popup-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease;margin-bottom:4px;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.character-popup-item:hover{background:#94a3b81a}.character-popup-item.selected{background:#fbbf2426;border:1px solid rgba(251,191,36,.3)}.character-popup-item.disabled{opacity:.5;cursor:not-allowed!important}.character-popup-item.disabled:hover{background:transparent}.character-popup-item.disabled .character-popup-item-name,.character-popup-item.disabled .character-popup-item-description{color:var(--muted);opacity:.6}.character-popup-item-info{flex:1;min-width:0}.character-popup-item-name{font-weight:600;font-size:.9rem;margin-bottom:2px}.character-popup-item-description{font-size:.75rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.character-popup-check{color:var(--accent);font-size:1.2rem;font-weight:600}.character-popup-add-section{padding:16px;border-top:1px solid rgba(148,163,184,.2);display:flex;flex-direction:column;gap:10px}.character-popup-add-header{font-size:.85rem;font-weight:600;color:var(--muted);margin-bottom:4px}.character-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}.character-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:400px;max-height:90vh;background:radial-gradient(circle at top left,#111827 0,#020617 65%);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);border:1px solid rgba(148,163,184,.2);z-index:10001;display:flex;flex-direction:column;overflow:hidden}.character-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 16px;position:relative}.character-modal-avatar-container{display:flex;align-items:center;justify-content:center;width:100%}.character-modal-avatar{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.5rem;color:#fff;box-shadow:0 4px 12px #0000004d;border:3px solid rgba(255,255,255,.3)}.character-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .15s ease}.character-modal-close:hover{color:var(--text);background:#94a3b81a}.character-modal-content{padding:0 24px 24px;flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.character-modal-content::-webkit-scrollbar{width:6px}.character-modal-content::-webkit-scrollbar-track{background:transparent}.character-modal-content::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.character-modal-content::-webkit-scrollbar-thumb:hover{background:#94a3b880}.character-modal-name{font-size:1.3rem;font-weight:700;margin:0 0 12px;text-align:center}.character-modal-description{font-size:.9rem;color:var(--muted);line-height:1.6;margin:0;text-align:center}.character-modal-actions{display:flex;gap:12px;padding:16px 24px 24px;border-top:1px solid rgba(148,163,184,.2)}.character-modal-actions .btn{flex:1}.chat-header-avatar{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 30% 0,#fbbf24,#4f46e5 60%,#0f172a);border:2px solid rgba(248,250,252,.7);flex-shrink:0}.luna-logo-container{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;padding:0;box-shadow:0 2px 8px #00000026;border:1px solid rgba(15,23,42,.1);overflow:hidden;text-align:left}.luna-logo,.luna-logo-small{display:block;object-fit:contain;border-radius:50%}.chat-header-title{font-size:1.1rem;font-weight:700;letter-spacing:.03em;text-align:left}.chat-header-subtitle{font-size:.75rem;color:var(--muted);margin-top:2px}.chat-container{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.chat-messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0;display:flex;flex-direction:column;gap:12px;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.chat-messages-container::-webkit-scrollbar{width:6px}.chat-messages-container::-webkit-scrollbar-track{background:transparent}.chat-messages-container::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.chat-messages-container::-webkit-scrollbar-thumb:hover{background:#94a3b880}.chat-message{display:flex;gap:8px;align-items:flex-start}.chat-message-user,.chat-message-dobby{flex-direction:row-reverse}.chat-message-avatar{width:32px;height:32px;border-radius:50%;background:#fff;border:1.5px solid rgba(248,250,252,.5);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:2px;box-shadow:0 2px 4px #0000001a}.chat-message-avatar svg{width:100%;height:100%;border-radius:50%}.chat-message-avatar img{width:100%;height:100%;object-fit:contain;border-radius:50%}.chat-message-content{flex:1;min-width:0}.chat-message-user .chat-message-content,.chat-message-dobby .chat-message-content{display:flex;flex-direction:column;align-items:flex-end}.chat-message-author{font-size:.7rem;font-weight:600;margin-bottom:2px;color:#fde68a}.chat-message-user .chat-message-author,.chat-message-dobby .chat-message-author{color:var(--muted)}.chat-message-text{padding:8px 12px;border-radius:var(--radius-md);font-size:.9rem;line-height:1.5;word-wrap:break-word;white-space:pre-wrap;max-width:85%;-webkit-user-select:text;user-select:text}.chat-message .chat-message-text{background:radial-gradient(circle at top left,#fbbf2429,#0f172af2);border:1px solid rgba(251,191,36,.45);color:var(--text)}.chat-message-user .chat-message-text,.chat-message-dobby .chat-message-text{background:#0f172af2;border:1px solid rgba(148,163,184,.4);color:var(--text)}.chat-message-text p{margin:0 0 .5em}.chat-message-text p:last-child{margin-bottom:0}.chat-message-text p:has(+ul),.chat-message-text p:has(+ol){margin-bottom:0}.chat-message-text p+ul,.chat-message-text p+ol{margin-top:0;margin-bottom:.1em}.chat-message-text ul+p,.chat-message-text ol+p{margin-top:.1em}.chat-message-text strong,.chat-message-text b{font-weight:600;color:inherit}.chat-message-text em,.chat-message-text i{font-style:italic}.chat-message-text code{background:#0000004d;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.85em;color:#fbbf24}.chat-message-text pre{background:#0000004d;padding:8px 12px;border-radius:6px;overflow-x:auto;margin:.5em 0}.chat-message-text pre code{background:transparent;padding:0;color:inherit;font-size:.85em}.chat-message-text a{color:#fbbf24;text-decoration:underline;text-underline-offset:2px}.chat-message-text a:hover{color:#fcd34d}.chat-message-text ul,.chat-message-text ol{margin:.1em 0;padding-left:1.5em;white-space:normal}.chat-message-text li{margin:.25em 0;white-space:normal}.chat-message-text li p{white-space:normal;margin:0}.chat-message-text h1,.chat-message-text h2,.chat-message-text h3,.chat-message-text h4,.chat-message-text h5,.chat-message-text h6{margin:.75em 0 .5em;font-weight:600;line-height:1.3}.chat-message-text h1:first-child,.chat-message-text h2:first-child,.chat-message-text h3:first-child,.chat-message-text h4:first-child,.chat-message-text h5:first-child,.chat-message-text h6:first-child{margin-top:0}.chat-message-text h1{font-size:1.3em}.chat-message-text h2{font-size:1.2em}.chat-message-text h3{font-size:1.1em}.chat-message-text blockquote{border-left:3px solid rgba(251,191,36,.5);padding-left:1em;margin:.5em 0;color:var(--muted);font-style:italic}.chat-message-text hr{border:none;border-top:1px solid rgba(148,163,184,.3);margin:1em 0}.chat-message-form{margin-top:1em;padding-top:1em;border-top:1px solid rgba(148,163,184,.2)}.contact-form{display:flex;flex-direction:column;gap:12px}.contact-form-field{display:flex;flex-direction:column;gap:6px}.contact-form-field label{font-size:.85rem;font-weight:500;color:var(--text);opacity:.9}.contact-form-field input,.contact-form-field textarea{padding:10px 12px;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.3);background:#0f172a99;color:var(--text);font-size:.9rem;font-family:inherit;transition:border-color .2s,background .2s}.contact-form-field input:focus,.contact-form-field textarea:focus{outline:none;border-color:#fbbf2480;background:#0f172acc}.contact-form-field input::placeholder,.contact-form-field textarea::placeholder{color:#94a3b880}.contact-form-field textarea{resize:vertical;min-height:80px}.contact-form-success{margin-top:1em;padding:12px;border-radius:var(--radius-md);background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:var(--text)}.contact-form-success p{margin:0;font-size:.9rem;line-height:1.5}.chat-message-text img{max-width:100%;height:auto;border-radius:6px;margin:.5em 0}.chat-message-text table{border-collapse:collapse;margin:.5em 0;width:100%}.chat-message-text th,.chat-message-text td{border:1px solid rgba(148,163,184,.3);padding:6px 8px;text-align:left}.chat-message-text th{background:#fbbf241a;font-weight:600}.chat-input-form{flex-shrink:0;padding-top:8px;border-top:1px solid rgba(148,163,184,.2)}.story-settings-trigger{transition:all .2s ease}.story-settings-trigger:hover{transform:translateY(-1px)}.story-settings-drawer{scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.story-settings-drawer::-webkit-scrollbar{width:6px}.story-settings-drawer::-webkit-scrollbar-track{background:transparent}.story-settings-drawer::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.story-settings-drawer::-webkit-scrollbar-thumb:hover{background:#94a3b880}.chat-input-wrapper{display:flex;gap:8px;align-items:center;background:#0f172ae6;border:1px solid rgba(148,163,184,.4);border-radius:var(--radius-pill);padding:6px 6px 6px 12px;transition:border-color .15s ease,box-shadow .15s ease}.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px #fbbf2480}.chat-input{flex:1;border:none;background:transparent;color:var(--text);font-size:.9rem;outline:none;padding:4px 0;-webkit-user-select:text;user-select:text}.chat-input::placeholder{color:#94a3b8cc}.chat-send-button{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#020617;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .15s ease,transform .15s ease;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.chat-send-button:hover:not(:disabled){transform:scale(1.05)}.chat-send-button:disabled{opacity:.4;cursor:not-allowed}.chat-typing-indicator{display:flex;gap:4px;padding:8px 12px;background:radial-gradient(circle at top left,#fbbf2429,#0f172af2);border:1px solid rgba(251,191,36,.45);border-radius:var(--radius-md);width:fit-content}.chat-typing-indicator span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:typing 1.4s infinite}.chat-typing-indicator span:nth-child(2){animation-delay:.2s}.chat-typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.btn-google{width:100%;background:#fff;color:#1f2937;border:1px solid rgba(148,163,184,.3);display:flex;align-items:center;justify-content:center;gap:10px;font-weight:500;transition:box-shadow .15s ease,transform .15s ease}.btn-google:hover:not(:disabled){box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.btn-google svg{flex-shrink:0}.divider{display:flex;align-items:center;text-align:center;margin:16px 0;color:var(--muted);font-size:.75rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid rgba(148,163,184,.3)}.divider span{padding:0 12px}.spinner{width:16px;height:16px;border:2px solid rgba(31,41,55,.3);border-top-color:#1f2937;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.luna-logo-pulse{animation:pulse 1.5s ease-in-out infinite;will-change:transform,opacity;animation-fill-mode:both}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.sidebar,.navigation-panel{position:fixed;top:0;left:0;width:320px;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);max-height:100vh;max-height:100dvh;max-height:calc(var(--vh, 1vh) * 100);background:radial-gradient(circle at top left,#111827 0,#020617 65%);border-right:1px solid rgba(148,163,184,.2);box-shadow:var(--shadow-soft);z-index:1000;transform:translate3d(-100%,0,0);transition:transform .2s cubic-bezier(.4,0,.2,1);will-change:transform;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden}.sidebar-open,.navigation-panel-open{transform:translateZ(0)}.sidebar-overlay,.navigation-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;transition:opacity .2s ease;will-change:opacity}.sidebar-header,.navigation-panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 18px;border-bottom:1px solid rgba(148,163,184,.2)}.sidebar-header h2,.navigation-panel-header h2{margin:0;font-size:1.2rem;font-weight:700;color:var(--text)}.sidebar-close,.navigation-panel-close{background:transparent;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;padding:4px 8px;line-height:1;transition:color .15s ease}.sidebar-close:hover,.navigation-panel-close:hover{color:var(--text)}.sidebar-actions{padding:16px 18px;display:flex;flex-direction:column;gap:10px;border-bottom:1px solid rgba(148,163,184,.2)}.sidebar-action-btn{width:100%;justify-content:flex-start;gap:10px}.sidebar-action-btn span{font-size:1.1rem}.sidebar-stories{flex:1;min-height:0;padding:16px 18px;overflow-y:auto;contain:layout style;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.sidebar-stories::-webkit-scrollbar{width:6px}.sidebar-stories::-webkit-scrollbar-track{background:transparent}.sidebar-stories::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.sidebar-stories::-webkit-scrollbar-thumb:hover{background:#94a3b880}.sidebar-stories h3{margin:0 0 12px;font-size:.85rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.sidebar-footer{flex-shrink:0;min-height:fit-content;width:100%}.sidebar-empty{text-align:center;padding:40px 20px;color:var(--muted)}.sidebar-empty p{margin:0;font-size:.85rem}.story-list{display:flex;flex-direction:column;gap:12px}.story-item{padding:12px;background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease;will-change:transform;contain:layout style paint;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.story-item:hover{background:#0f172ae6;border-color:var(--accent);transform:translate(2px)}.story-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.story-title{font-weight:600;font-size:.9rem;color:var(--text)}.story-length{font-size:.7rem;color:var(--accent);background:#fbbf2426;padding:2px 8px;border-radius:var(--radius-pill)}.story-item-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.75rem;color:var(--muted)}.story-date{font-size:.7rem}.story-preview{margin:0;font-size:.8rem;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sidebar-toggle{background:transparent;border:none;color:var(--text);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background .15s ease;margin-right:8px;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.sidebar-toggle:hover{background:#94a3b81a}.navigation-panel-content{flex:1;padding:16px 18px;overflow-y:auto}.navigation-menu{display:flex;flex-direction:column;gap:8px}.navigation-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);color:var(--text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.navigation-item:hover{background:#0f172ae6;border-color:var(--accent);transform:translate(2px)}.navigation-item-icon{font-size:1.2rem;flex-shrink:0}.navigation-item-text{flex:1}.chat-header-brand{display:flex;align-items:center;gap:8px}@media(min-width:640px){.app-shell{padding-top:16px;padding-bottom:16px}.card{padding:12px}.chat-message-text{max-width:75%}.sidebar,.navigation-panel{width:360px}}.story-view{flex:1;display:flex;flex-direction:column;min-height:0}.story-view-content{display:flex;flex-direction:column;gap:20px;flex:1}.story-view-header{display:flex;align-items:center}.story-view-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.story-view-meta{display:flex;flex-wrap:wrap;gap:16px;padding:16px;background:#0f172a99;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.2)}.story-view-meta-item{display:flex;flex-direction:column;gap:4px}.story-view-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.story-view-value{font-size:.9rem;color:var(--text);font-weight:500}.story-view-text{flex:1;padding:0 4px}.story-paragraph{margin:0 0 20px;font-size:1rem;line-height:1.8;color:var(--text);text-align:left;-webkit-user-select:text;user-select:text}.story-paragraph:last-child{margin-bottom:0}.parent-profile-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:16px}.parent-profile-screen{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;gap:16px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.parent-profile-screen::-webkit-scrollbar{width:6px}.parent-profile-screen::-webkit-scrollbar-track{background:transparent}.parent-profile-screen::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.parent-profile-screen::-webkit-scrollbar-thumb:hover{background:#94a3b880}.profile-section{padding:16px;background:#0f172a99;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.2);display:flex;flex-direction:column;gap:12px;margin-top:8px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#0f172a66;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.15);transition:all .15s ease}.setting-item:hover{background:#0f172a99;border-color:#94a3b84d}.setting-item-content{flex:1;display:flex;flex-direction:column;gap:4px}.setting-item-label{font-size:.85rem;font-weight:600;color:var(--text)}.setting-item-description{font-size:.75rem;color:var(--muted)}.settings-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:16px}.settings-screen{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;gap:16px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.settings-screen::-webkit-scrollbar{width:6px}.settings-screen::-webkit-scrollbar-track{background:transparent}.settings-screen::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.settings-screen::-webkit-scrollbar-thumb:hover{background:#94a3b880}.settings-section{display:flex;flex-direction:column;gap:8px;margin-top:8px}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#0f172a66;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.15);transition:all .15s ease;cursor:pointer;width:100%;text-align:left;border:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.settings-item:hover{background:#0f172a99;border-color:#94a3b84d}.settings-item-content{flex:1;display:flex;align-items:center;gap:12px}.settings-item-icon{font-size:1.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-item-text{flex:1;display:flex;flex-direction:column;gap:4px}.settings-item-label{font-size:.85rem;font-weight:600;color:var(--text)}.settings-item-description{font-size:.75rem;color:var(--muted)}.settings-item-arrow{font-size:1.25rem;color:var(--muted);flex-shrink:0}.subscription-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:16px}.subscription-screen{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;gap:16px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.subscription-screen::-webkit-scrollbar{width:6px}.subscription-screen::-webkit-scrollbar-track{background:transparent}.subscription-screen::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.subscription-screen::-webkit-scrollbar-thumb:hover{background:#94a3b880}.onboarding-screen{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;gap:16px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.onboarding-screen::-webkit-scrollbar{width:6px}.onboarding-screen::-webkit-scrollbar-track{background:transparent}.onboarding-screen::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.onboarding-screen::-webkit-scrollbar-thumb:hover{background:#94a3b880}.subscription-card{padding:1.5rem;background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);margin-bottom:1rem}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#94a3b84d;transition:.2s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 2px #fbbf244d}.status-message-shimmer{position:relative;display:inline-block;background:linear-gradient(90deg,currentColor 0%,currentColor 40%,rgba(251,191,36,.8) 48%,rgba(251,191,36,1) 50%,rgba(251,191,36,.8) 52%,currentColor 60%,currentColor 100%);background-size:300% 100%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer-slide 2s linear infinite}@keyframes shimmer-slide{0%{background-position:100% 0}to{background-position:0% 0}}.landing-page{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.landing-content{max-width:600px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:48px}.landing-section{display:flex;flex-direction:column;gap:16px;background:radial-gradient(circle at top left,#111827 0,#020617 65%);border-radius:var(--radius-lg);padding:32px 24px;border:1px solid rgba(148,163,184,.2)}.landing-heading{font-size:2rem;font-weight:600;line-height:1.3;color:var(--text);text-align:center;margin:0}.landing-subline{font-size:1.125rem;color:var(--muted);text-align:center;margin:0;line-height:1.6}.landing-section-title{font-size:1.5rem;font-weight:600;color:var(--text);text-align:left;margin:0 0 16px}.landing-section-subtitle{font-size:.875rem;color:var(--muted);text-align:center;margin:0}.social-proof{display:flex;flex-direction:column;gap:24px;align-items:center}.social-proof-header{font-size:1rem;color:var(--muted);text-align:center;margin:0;font-weight:500}.testimonials{display:flex;flex-direction:column;gap:16px;width:100%}.testimonial{background:#ffffff08;border-radius:var(--radius-md);padding:20px;border:1px solid rgba(148,163,184,.1)}.testimonial-text{font-size:1rem;color:var(--text);line-height:1.6;margin:0;font-style:italic}.safety-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.safety-item{display:flex;align-items:flex-start;gap:12px;font-size:1rem;color:var(--text);line-height:1.6}.safety-icon{color:var(--accent);font-weight:600;font-size:1.25rem;flex-shrink:0;margin-top:2px}.how-it-works{display:flex;flex-direction:column;gap:32px;align-items:center}.how-it-works-step{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;max-width:300px}.step-number{width:48px;height:48px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;flex-shrink:0}.step-text{font-size:1.125rem;color:var(--text);margin:0;line-height:1.5}.personalization-text{font-size:1.125rem;color:var(--muted);text-align:center;line-height:1.7;margin:0}.pricing-section{text-align:center}.pricing-text{font-size:1.125rem;color:var(--text);font-weight:500;margin:0}.hero-section{text-align:center;align-items:center}.landing-hero-title{font-size:2.5rem;font-weight:600;line-height:1.2;color:var(--text);margin:0 0 16px}.landing-hero-subtitle{font-size:1.25rem;color:var(--text);font-weight:500;margin:0 0 16px;line-height:1.4}.landing-hero-description{font-size:1.125rem;color:var(--muted);line-height:1.7;margin:0 0 24px;max-width:500px}.landing-body-text{font-size:1.125rem;color:var(--text);line-height:1.7;margin:0 0 16px;text-align:left}.landing-body-text:last-child{margin-bottom:0}.landing-features-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.landing-feature-item{font-size:1.125rem;color:var(--text);line-height:1.6;padding-left:24px;position:relative}.landing-feature-item:before{content:"•";color:var(--accent);font-weight:600;position:absolute;left:0}.landing-steps-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px;counter-reset:step-counter}.landing-step-item{font-size:1.125rem;color:var(--text);line-height:1.7;padding-left:40px;position:relative;counter-increment:step-counter}.landing-step-item:before{content:counter(step-counter);position:absolute;left:0;top:0;width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;flex-shrink:0}.landing-step-text{display:block}.cta-section{align-items:center;text-align:center}.cta-section .landing-section-title{text-align:center}.landing-cta-text{font-size:1.25rem;color:var(--text);font-weight:500;margin:0 0 20px}.landing-cta-button{background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius-pill);padding:16px 48px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #fbbf244d}.landing-cta-button:hover:not(:disabled){background:#f59e0b;transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2466}.landing-cta-button:active:not(:disabled){transform:translateY(0)}.landing-cta-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.landing-hero-title{font-size:2rem}.landing-hero-subtitle{font-size:1.125rem}.landing-hero-description{font-size:1rem}.landing-heading{font-size:1.75rem}.landing-subline{font-size:1rem}.landing-section-title{font-size:1.25rem}.landing-body-text,.landing-feature-item,.landing-step-item{font-size:1rem}.landing-content{gap:40px}.landing-section{padding:24px 20px}}.character-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;z-index:10002;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.character-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:400px;max-height:90vh;background:radial-gradient(circle at top left,#111827 0,#020617 65%);border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;overflow:hidden;z-index:10003;animation:modalPop .3s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalPop{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.character-modal-header{padding:16px;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:1px solid rgba(148,163,184,.1);min-height:60px}.character-modal-content{padding:24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.character-modal-actions{padding:16px 24px;border-top:1px solid rgba(148,163,184,.15);display:flex;gap:12px;background:#0f172a4d}.character-modal-close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1}.character-modal-close:hover{background:#ffffff1a;color:var(--text)}.character-modal-avatar-container{display:flex;justify-content:center;margin-bottom:20px}.character-modal-avatar{width:80px;height:80px;border-radius:50%;border:4px solid rgba(255,255,255,.1);box-shadow:0 0 20px #0000004d;overflow:hidden}.character-modal-name{font-size:1.5rem;font-weight:700;text-align:center;margin:0 0 8px;color:var(--text)}.character-modal-description{font-size:.95rem;text-align:center;margin:0 0 24px;color:var(--muted);line-height:1.6}.avatar-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:50%;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sparkle-pulse{font-size:1.5rem;animation:sparkle-pulse-anim 1.5s infinite ease-in-out;display:inline-block}@keyframes sparkle-pulse-anim{0%,to{transform:scale(.85);opacity:.6}50%{transform:scale(1.15);opacity:1}}.spinner{border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.luna-tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;pointer-events:none}.luna-tour-bubble{background:radial-gradient(circle at top left,#1f2937 0,#020617 75%);border:1px solid rgba(251,191,36,.4);border-radius:var(--radius-lg);padding:20px;box-shadow:0 20px 50px #0009,0 0 20px #fbbf241a;display:flex;flex-direction:column;gap:12px;pointer-events:auto;animation:lunaFloat 3s ease-in-out infinite,lunaScaleIn .3s ease-out;position:relative}.luna-tour-avatar{position:absolute;top:-30px;left:-20px;background:var(--bg);border-radius:50%;padding:4px;border:2px solid var(--accent);box-shadow:0 4px 12px #0000004d}.luna-tour-content p{margin:0;font-size:.95rem;line-height:1.5;color:var(--text);font-weight:450}.luna-tour-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.luna-tour-skip{background:none;border:none;color:var(--muted);font-size:.8rem;cursor:pointer;padding:4px 8px;transition:color .2s}.luna-tour-skip:hover{color:var(--text)}.luna-tour-next{background:linear-gradient(90deg,#fbbf24,#eab308);border:none;border-radius:var(--radius-pill);padding:6px 16px;color:#020617;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.luna-tour-next:hover{transform:translateY(-1px);box-shadow:0 4px 12px #fbbf244d}.luna-tour-arrow{position:absolute;width:0;height:0;border-style:solid}.luna-tour-arrow-top{bottom:-10px;left:50%;transform:translate(-50%);border-width:10px 10px 0 10px;border-color:rgba(251,191,36,.4) transparent transparent transparent}.luna-tour-arrow-bottom{top:-10px;left:50%;transform:translate(-50%);border-width:0 10px 10px 10px;border-color:transparent transparent rgba(251,191,36,.4) transparent}.luna-tour-arrow-left{right:-10px;top:50%;transform:translateY(-50%);border-width:10px 0 10px 10px;border-color:transparent transparent transparent rgba(251,191,36,.4)}.luna-tour-arrow-right{left:-10px;top:50%;transform:translateY(-50%);border-width:10px 10px 10px 0;border-color:transparent rgba(251,191,36,.4) transparent transparent}@keyframes lunaFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.02)}}@keyframes lunaScaleIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.luna-tour-highlight{position:relative;animation:lunaTourPulse 2s ease-in-out infinite;box-shadow:0 0 0 4px #fbbf2466,0 0 20px #fbbf244d!important;border-radius:8px;z-index:9999}@keyframes lunaTourPulse{0%,to{box-shadow:0 0 0 4px #fbbf2466,0 0 20px #fbbf244d}50%{box-shadow:0 0 0 6px #fbbf2499,0 0 30px #fbbf2480}}
