*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #FAF6F1;--bg-secondary: #F0EBE3;--bg-input: #F5F0E8;--text-primary: #2C2C2C;--text-secondary:#6B6357;--text-muted: #9C9080;--accent: #B8860B;--accent-hover: #996F0A;--accent-light: #D4A843;--accent-bg: #FDF3DC;--border: #E0D8CE;--border-focus: #B8860B;--night: #1A1714;--font-serif: "Lora", Georgia, "Times New Roman", serif;--font-sans: "Poppins", system-ui, -apple-system, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(44, 44, 44, .08);--shadow-md: 0 4px 12px rgba(44, 44, 44, .1);--shadow-lg: 0 8px 24px rgba(44, 44, 44, .12);--transition: .2s ease}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.narrative-text{font-family:var(--font-serif);font-size:19px;line-height:1.75;color:var(--text-primary)}h1,h2,h3{font-family:var(--font-serif);color:var(--text-primary);line-height:1.25}h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:500}h2{font-size:clamp(1.4rem,3vw,2rem);font-weight:500}h3{font-size:1.2rem;font-weight:500}p{color:var(--text-secondary);line-height:1.65}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-family:var(--font-sans);font-size:.95rem;font-weight:500;padding:.65rem 1.5rem;border-radius:var(--radius-md);border:none;cursor:pointer;transition:background-color var(--transition),color var(--transition),opacity var(--transition);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--accent);color:#faf6f1}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover);color:#faf6f1}.btn-outline{background-color:transparent;color:var(--accent);border:1.5px solid var(--accent)}.btn-outline:hover:not(:disabled){background-color:var(--accent-bg)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-secondary);color:var(--text-primary)}.btn-lg{padding:.85rem 2rem;font-size:1.05rem}.btn-sm{padding:.45rem 1rem;font-size:.85rem}.btn-full{width:100%}.input{width:100%;font-family:var(--font-sans);font-size:1rem;color:var(--text-primary);background-color:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:.7rem 1rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none;line-height:1.5}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #b8860b1f}.input-label{display:block;font-family:var(--font-sans);font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.4rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem}.container-narrow{width:100%;max-width:480px;margin:0 auto;padding:0 1.5rem}.alert{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;font-family:var(--font-sans)}.alert-error{background-color:#fef2f2;color:#b91c1c;border:1px solid #FECACA}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.divider{display:flex;align-items:center;gap:1rem;color:var(--text-muted);font-size:.8rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease forwards}@keyframes voicePulse{0%{box-shadow:0 0 #b8860b73}60%{box-shadow:0 0 0 14px #b8860b00}to{box-shadow:0 0 #b8860b00}}.voice-pulse{animation:voicePulse 1.4s ease-out infinite}:root{--app-height: 100dvh}@supports not (height: 100dvh){:root{--app-height: 100vh}}.offline-banner{background:var(--night);color:#faf6f1;text-align:center;padding:.55rem 1.5rem;font-family:var(--font-sans);font-size:.82rem;letter-spacing:.01em}@media(max-width:480px){.session-input-zone{padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px))}}@media(max-width:480px){.session-content{padding:1.5rem 1rem 1rem}}
