:root{--bg: #15101a;--bg-soft: #1c1623;--bg-elev: #221a2b;--bg-hover: #2a2034;--line: #2e2638;--line-soft: #251d2e;--ink: #efe6dc;--ink-dim: #b8a89d;--ink-mute: #7a6e75;--rose: #e8869b;--rose-soft: #d96f8a;--peach: #f0a87a;--gold: #c9a978;--bubble-user: #2d2236;--bubble-ai: #1f1828;--font-display: "Fraunces", "Iowan Old Style", Georgia, serif;--font-body: "Manrope", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--ink);background:var(--bg);background-image:radial-gradient(ellipse at 15% 0%,rgba(232,134,155,.08),transparent 50%),radial-gradient(ellipse at 85% 100%,rgba(240,168,122,.06),transparent 55%);background-attachment:fixed;overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}button{border:0;background:none;cursor:pointer;padding:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}.login{min-height:100dvh;display:grid;place-items:center;padding:24px;padding-top:calc(24px + var(--safe-top));padding-bottom:calc(24px + var(--safe-bottom))}.login-card{width:100%;max-width:360px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;text-align:center}.login h1{font-family:var(--font-display);font-weight:500;font-size:34px;letter-spacing:-.01em;margin:0 0 6px;background:linear-gradient(135deg,var(--rose),var(--peach));-webkit-background-clip:text;background-clip:text;color:transparent}.login p{color:var(--ink-dim);margin:0 0 24px;font-size:14px}.login input{width:100%;padding:14px 16px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);outline:none;margin-bottom:12px;transition:border-color .15s}.login input:focus{border-color:var(--rose)}.login button{width:100%;padding:14px;background:linear-gradient(135deg,var(--rose),var(--rose-soft));color:#1a0e16;border-radius:var(--radius);font-weight:600;letter-spacing:.01em;transition:transform .1s,opacity .2s}.login button:active{transform:scale(.98)}.login button:disabled{opacity:.5;cursor:not-allowed}.login-error{color:var(--rose);font-size:13px;margin-top:8px}.app{display:grid;grid-template-columns:1fr;height:100dvh;position:relative}@media (min-width: 900px){.app{grid-template-columns:300px 1fr}}.sidebar{background:var(--bg-soft);border-right:1px solid var(--line);display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;transform:translate(-100%);transition:transform .25s cubic-bezier(.32,.72,0,1);padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.sidebar.open{transform:translate(0)}@media (min-width: 900px){.sidebar{position:relative;transform:none;inset:auto}}.sidebar-header{padding:18px 20px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line-soft)}.sidebar-brand{font-family:var(--font-display);font-weight:500;font-size:22px;letter-spacing:-.01em;background:linear-gradient(135deg,var(--rose),var(--peach));-webkit-background-clip:text;background-clip:text;color:transparent}.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-sm);color:var(--ink-dim);transition:background .15s,color .15s}.icon-btn:hover{background:var(--bg-hover);color:var(--ink)}.icon-btn:active{transform:scale(.95)}.sidebar-actions{padding:12px 14px}.btn-new{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);font-weight:500;transition:background .15s,border-color .15s}.btn-new:hover{background:var(--bg-hover);border-color:var(--rose)}.character-list{flex:1;overflow-y:auto;padding:4px 10px 14px}.character-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:var(--radius);text-align:left;color:var(--ink);margin-bottom:2px;transition:background .15s}.character-item:hover{background:var(--bg-hover)}.character-item.active{background:var(--bg-elev)}.character-item.active:before{content:"";position:absolute;margin-left:-8px;width:3px;height:22px;background:linear-gradient(180deg,var(--rose),var(--peach));border-radius:3px}.character-item .avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;font-size:18px;flex-shrink:0}.character-item .name{font-weight:500;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.character-item .preview{font-size:12.5px;color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.character-item .text{flex:1;min-width:0}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity .2s}.sidebar-overlay.show{opacity:1;pointer-events:auto}@media (min-width: 900px){.sidebar-overlay{display:none}}.main{display:flex;flex-direction:column;min-width:0;height:100dvh}.topbar{display:flex;align-items:center;gap:10px;padding:12px 14px;padding-top:calc(12px + var(--safe-top));border-bottom:1px solid var(--line-soft);background:#15101ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.topbar .title{flex:1;min-width:0}.topbar .title h2{margin:0;font-family:var(--font-display);font-weight:500;font-size:19px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar .title .sub{font-size:11.5px;color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (min-width: 900px){.topbar .hamburger{display:none}}.empty{flex:1;display:grid;place-items:center;padding:32px;text-align:center}.empty-inner{max-width:420px}.empty h1{font-family:var(--font-display);font-weight:500;font-size:clamp(28px,6vw,38px);letter-spacing:-.02em;margin:0 0 10px}.empty p{color:var(--ink-dim);margin:0 0 24px;line-height:1.6}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;background:linear-gradient(135deg,var(--rose),var(--rose-soft));color:#1a0e16;border-radius:var(--radius);font-weight:600;transition:transform .1s}.btn-primary:active{transform:scale(.98)}.chat{flex:1;overflow-y:auto;padding:18px 14px 14px;scroll-behavior:smooth}.chat-inner{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:14px}.msg{display:flex;gap:10px;max-width:88%}.msg.user{align-self:flex-end;flex-direction:row-reverse}.msg .avatar{width:30px;height:30px;border-radius:50%;background:var(--bg-elev);display:grid;place-items:center;font-size:15px;flex-shrink:0;margin-top:2px}.msg.user .avatar{background:linear-gradient(135deg,var(--rose),var(--peach));color:#1a0e16;font-size:12px;font-weight:700}.msg .bubble{padding:11px 14px;border-radius:16px;background:var(--bubble-ai);border:1px solid var(--line-soft);white-space:pre-wrap;word-wrap:break-word;font-size:14.5px;line-height:1.55}.msg.user .bubble{background:var(--bubble-user);border-color:var(--line)}.typing{display:inline-flex;gap:4px;padding:4px 2px}.typing span{width:6px;height:6px;background:var(--ink-mute);border-radius:50%;animation:bounce 1.2s infinite ease-in-out}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}.composer{padding:10px 12px;padding-bottom:calc(10px + var(--safe-bottom));border-top:1px solid var(--line-soft);background:var(--bg)}.composer-inner{max-width:760px;margin:0 auto;display:flex;gap:8px;align-items:flex-end;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:6px 6px 6px 14px;transition:border-color .15s}.composer-inner:focus-within{border-color:var(--rose)}.composer textarea{flex:1;background:transparent;border:0;outline:0;padding:9px 0;resize:none;max-height:160px;line-height:1.5}.composer textarea::placeholder{color:var(--ink-mute)}.btn-send{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--rose-soft));color:#1a0e16;flex-shrink:0;transition:transform .1s,opacity .2s}.btn-send:disabled{background:var(--bg-hover);color:var(--ink-mute);cursor:not-allowed}.btn-send:not(:disabled):active{transform:scale(.92)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:grid;place-items:end center;padding:0;animation:fadeIn .2s}@media (min-width: 700px){.modal-overlay{place-items:center;padding:24px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:560px;max-height:92dvh;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;animation:slideUp .25s cubic-bezier(.32,.72,0,1);padding-bottom:var(--safe-bottom)}@media (min-width: 700px){.modal{border-radius:var(--radius-lg)}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--line-soft)}.modal-header h3{margin:0;font-family:var(--font-display);font-weight:500;font-size:22px}.modal-body{flex:1;overflow-y:auto;padding:16px 18px 4px}.modal-footer{display:flex;gap:8px;padding:12px 18px 16px;border-top:1px solid var(--line-soft)}.modal-footer button{flex:1}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:500;color:var(--ink-dim);margin-bottom:6px;letter-spacing:.02em}.field input,.field textarea,.field select{width:100%;padding:11px 13px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);outline:none;transition:border-color .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--rose)}.field textarea{resize:vertical;min-height:80px;font-family:inherit}.field .hint{font-size:11.5px;color:var(--ink-mute);margin-top:4px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn-secondary{padding:12px 16px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);font-weight:500}.btn-danger{padding:12px 16px;background:transparent;border:1px solid var(--line);border-radius:var(--radius);color:var(--rose);font-weight:500}.muted{color:var(--ink-mute)}.spacer{flex:1}
