:root{color-scheme:light;--bg-1:#f4eadc;--bg-2:#efe7fb;--ink:#1e1a2e;--muted:#7a6e8a;--panel:rgba(255,255,255,0.90);--line:#e3d9f0;--accent:#5b3d82;--accent-strong:#4f356f;--accent-light:#7c5aa6;--danger:#c0392b;--touch-min:48px;--radius:12px;--shadow:0 4px 16px rgba(63,41,94,0.12)}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:Avenir Next,Gill Sans,Segoe UI Variable,sans-serif;color:var(--ink);background:radial-gradient(circle at 15% 10%,rgba(255,255,255,.72) 0,transparent 38%),radial-gradient(circle at 82% 8%,rgba(200,180,230,.38) 0,transparent 32%),linear-gradient(135deg,var(--bg-1) 0,#f7f0e4 42%,var(--bg-2) 100%);min-height:100%}main.story-shell{min-height:100vh;display:flex;justify-content:center;padding:2rem 1rem}section.story-panel{width:min(980px,100%);background:var(--panel);border:1px solid var(--line);border-radius:20px;box-shadow:0 10px 32px rgba(63,41,94,.12);padding:1.5rem 1.5rem calc(1.5rem + .3rem);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.story-row{display:flex;justify-content:space-between;gap:.75rem;align-items:center}.story-title{margin:0;font-size:clamp(1.4rem,3.2vw,2rem)}.muted,.story-subtitle{color:var(--muted)}.section-title{margin:1.2rem 0 .4rem;font-size:1.05rem}.section-meta{color:var(--muted);font-size:.92rem}.field-label{display:block;margin-top:1rem;margin-bottom:.35rem;font-weight:600}.json-editor,.text-input{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:.7rem .8rem;font:inherit;background:#ffffff;color:var(--ink)}.json-editor{font-family:Consolas,Courier New,monospace}.character-grid{margin-top:.75rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:.7rem;gap:.7rem}.character-create-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));grid-gap:.7rem;gap:.7rem}.empty-closet-panel{margin-top:.5rem;display:flex;flex-direction:column;align-items:flex-start;gap:.55rem}.character-card{border:1px solid var(--line);border-radius:14px;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:start;grid-gap:.7rem;gap:.7rem;padding:.8rem;background:#fcfffd}.character-card>div{min-width:0}.character-card-thumb{width:48px;height:48px;border-radius:10px;object-fit:cover;border:1px solid var(--line);background:#fff}.character-card.selected{border-color:var(--accent);background:#f3eeff}.character-name{margin:0;font-weight:700;overflow-wrap:anywhere}.character-description,.character-meta,.job-meta{margin:.2rem 0 0;color:var(--muted);font-size:.92rem;overflow-wrap:anywhere}.story-character-card{grid-template-columns:auto 48px minmax(0,1fr);align-items:center}.story-character-card-thumb-placeholder{width:48px;height:48px;border-radius:10px;border:1px dashed var(--line);background:#fff}.button-row{display:flex;gap:.55rem;flex-wrap:wrap;align-items:flex-start;margin-top:.8rem;padding-bottom:.25rem}.action-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;min-height:var(--touch-min);border-radius:999px;border:2px solid var(--accent-strong);font:inherit;font-weight:600;line-height:1.3;white-space:nowrap;overflow:visible;padding:.62rem 1.2rem;cursor:pointer;transition:opacity .15s,transform .1s}.action-button{background:linear-gradient(135deg,var(--accent-strong) 0,var(--accent-light) 100%);color:#fff;border-color:var(--accent-strong);box-shadow:0 2px 10px rgba(79,53,111,.28)}.secondary-button{background:rgba(255,255,255,.85);color:var(--accent-strong);border-color:var(--line)}.action-button:hover:not(:disabled){opacity:.88}.secondary-button:hover:not(:disabled){border-color:var(--accent);background:rgba(255,255,255,.98)}.action-button:disabled,.secondary-button:disabled{opacity:.45;cursor:not-allowed}.progress-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:.5rem;gap:.5rem}.progress-grid p{margin:0;padding:.45rem .6rem;border:1px solid var(--line);border-radius:12px;background:#f8fbfa}.jobs-list{margin-top:.75rem;display:grid;grid-gap:.5rem;gap:.5rem}.job-row{border:1px solid var(--line);border-radius:12px;background:#fcfffd;padding:.6rem .7rem;display:flex;justify-content:space-between;gap:.6rem;align-items:center}.story-library-row{align-items:flex-start}.story-library-thumb-frame{width:120px;min-width:120px;height:90px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#f3eeff}.story-library-thumb-image,.story-library-thumb-placeholder{width:100%;height:100%}.story-library-thumb-image{display:block;object-fit:cover;object-position:center}.story-library-thumb-placeholder{display:grid;place-items:center;font-size:1.8rem}.story-library-main{flex:1 1;min-width:0}.story-library-status{margin-top:.25rem}.story-library-actions{margin-top:.45rem;align-items:center}.story-share-panel{margin-top:.7rem;display:grid;grid-gap:.55rem;gap:.55rem;border:1px solid var(--line);border-radius:12px;padding:.7rem;background:#fff;width:100%;min-width:0;overflow-wrap:anywhere}.story-share-panel .job-meta{margin:0;overflow-wrap:anywhere}.story-share-panel .character-grid{display:grid;grid-template-columns:1fr;grid-gap:.55rem;gap:.55rem;min-width:0}.story-share-panel .character-card{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:start;grid-gap:.6rem;gap:.6rem;min-width:0}.story-share-panel .character-card>div{min-width:0}.story-share-panel .character-meta,.story-share-panel .character-name{overflow-wrap:anywhere;word-break:break-word}.job-title{margin:0;font-weight:700}.benchmark-result-body{width:100%}.benchmark-score-row{margin-top:.5rem}.benchmark-approval-panel{margin-top:.75rem}.score-input{width:70px}.reader-panel{max-width:800px}.reader-panel.reader-panel--fullscreen{width:100%;max-width:none;min-height:100vh;margin:0;border-radius:0;box-shadow:none;background:#1a1025;color:#f0eafa}.reader-top-actions{display:flex;align-items:center;gap:.65rem}.reader-image-wrap{margin-top:1rem;border:1px solid var(--line);border-radius:14px;background:#fff;min-height:260px;display:grid;place-items:center;overflow:hidden}.reader-image{width:100%;height:auto;display:block}.reader-image-placeholder{color:var(--muted);padding:1rem;text-align:center}.reader-text{margin-top:.9rem;border:1px solid var(--line);background:#fff;border-radius:12px;padding:.75rem;line-height:1.45}.reader-text p{margin:0}.reader-progress-bar{margin-top:.75rem;width:100%;height:10px;border-radius:999px;background:#ede8f4;overflow:hidden;border:1px solid var(--line)}.reader-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent-strong),var(--accent-light))}.reader-controls{margin-top:.75rem;display:flex;justify-content:space-between;align-items:center;gap:.6rem}.reader-page-indicator{margin:0;color:var(--muted)}.reader-jump-label{font-size:.84rem;color:var(--muted)}.reader-page-select{width:130px;padding:.4rem .55rem}a.inline-link:not(.action-button):not(.secondary-button){color:var(--accent-strong);text-decoration:none;border-bottom:1px solid transparent}a.inline-link:not(.action-button):not(.secondary-button):hover{border-bottom-color:var(--accent-strong)}.error-text{color:var(--danger);font-weight:600;margin-top:.65rem}@media (max-width:700px){section.story-panel{padding:.95rem .95rem calc(.95rem + .35rem);border-radius:14px}.story-row{align-items:flex-start;flex-direction:column}.reader-top-actions{width:100%;justify-content:space-between}.reader-controls{flex-direction:column;align-items:stretch}}.story-edit-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,380px);grid-gap:1.25rem;gap:1.25rem;align-items:stretch;min-height:calc(100vh - 92px)}.story-edit-layout>.story-panel{width:auto;min-width:0}.story-edit-layout--writing{grid-template-columns:minmax(0,1fr)}.chat-panel{display:flex;flex-direction:column;gap:1rem;min-height:0}.story-edit-layout .chat-panel{max-height:calc(100vh - 92px);overflow-y:auto;overflow-x:hidden;padding-right:.2rem}.story-edit-layout .chat-panel .chat-thread-shell{height:auto}.chat-thread-shell{display:flex;flex-direction:column;flex:1 1;min-height:0;max-width:720px;margin:0 auto;width:100%}.chat-thread-header{padding:.5rem 0 .75rem;flex-shrink:0}.chat-step-dots{display:flex;gap:.5rem;align-items:center;justify-content:center}.chat-step-dot{width:10px;height:10px;border-radius:50%;background:var(--line);transition:background .2s}.chat-step-dot--active,.chat-step-dot--done{background:var(--accent-strong)}.chat-step-dot--done{opacity:.45}.chat-extra-controls,.chat-input-bar{flex-shrink:0;padding:.75rem 0 0}.chat-input-bar{display:flex;align-items:flex-end;gap:.5rem}.chat-suggestion-chips{display:flex;flex-wrap:wrap;gap:.4rem;padding:.5rem 0 .25rem;flex-shrink:0}.chat-suggestion-chip{background:var(--surface,#f8f7ff);border:1px solid var(--line,#e2e0f0);border-radius:999px;padding:.3rem .85rem;font-size:.82rem;color:var(--text);cursor:pointer;transition:background .15s ease,border-color .15s ease;white-space:nowrap}.chat-suggestion-chip:hover:not(:disabled){background:var(--accent-subtle,#ede9fe);border-color:var(--accent,#7c3aed)}.chat-suggestion-chip:disabled{opacity:.45;cursor:not-allowed}.chat-input-bar .chat-input{flex:1 1;min-width:0}.chat-mic-slot{flex:0 0 auto;align-self:flex-end;width:2.5rem;height:2.5rem;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--text);cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease}.chat-mic-slot:before{content:"\01F3A4";font-size:1rem}.chat-mic-slot:hover:not(:disabled){border-color:var(--accent-strong);background:#f5f3ff}.chat-mic-slot--listening{border-color:var(--accent-strong);background:#ede9fe;animation:micPulse 1s ease-in-out infinite}.chat-mic-slot:disabled{opacity:.45;cursor:not-allowed}.chat-footer-slot{flex-shrink:0;padding:.5rem 0 0}.chat-bubble-image{display:block;width:100%;max-width:280px;border-radius:10px;margin-top:.4rem}.chat-typing-dots{display:inline-flex;gap:4px;align-items:center;height:1rem}.chat-typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--accent-strong);opacity:.5;animation:typingBounce 1.2s infinite}.chat-typing-dots span:nth-child(2){animation-delay:.2s}.chat-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-5px);opacity:1}}@keyframes micPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.chat-seed-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:.75rem;gap:.75rem;padding:.5rem 0}.chat-seed-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.1rem .75rem;border:2px solid var(--line);border-radius:14px;background:#fff;cursor:pointer;text-align:center;font-family:inherit;font-size:.9rem;font-weight:600;transition:border-color .15s,background .15s}.chat-seed-card:hover:not(:disabled){border-color:var(--accent-strong);background:#f5f3ff}.chat-seed-card-icon{font-size:1.8rem;line-height:1}.trait-chips{display:flex;flex-wrap:wrap;gap:.4rem;padding:.25rem 0}.trait-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;border-radius:999px;border:2px solid var(--line);background:#fff;font-size:.85rem;cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.trait-chip--locked{border-color:var(--accent-strong);background:#f0ecff;font-weight:600}.trait-chip--ignored{opacity:.4}.style-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:.6rem;gap:.6rem}.style-tile{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.75rem .5rem;border:2px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;text-align:center;transition:border-color .15s,background .15s}.style-tile:hover:not(:disabled){border-color:var(--accent-strong);background:#f5f3ff}.style-tile--selected{border-color:var(--accent-strong);background:#f0ecff}.style-tile-icon{font-size:1.5rem}.character-card-preview{border:1px solid var(--line);border-radius:16px;padding:1rem;background:#fafafa;display:flex;flex-direction:column;gap:.6rem}.character-card-preview-image{width:100%;max-width:200px;border-radius:12px;align-self:center}.image-compare-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.image-compare-card{display:flex;flex-direction:column;gap:.35rem;align-items:center}@media (max-width:720px){.image-compare-grid{grid-template-columns:1fr}}.locked-trait-badges{display:flex;flex-wrap:wrap;gap:.35rem}.locked-trait-badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;background:var(--accent-strong);color:#fff;font-size:.78rem;font-weight:600}.chat-thread{display:flex;flex-direction:column;gap:.65rem;flex:1 1 auto;min-height:0;max-height:none;overflow-y:auto;padding:.5rem 0;border-bottom:1px solid var(--line)}.chat-bubble{padding:.55rem .75rem;border-radius:12px;max-width:88%;word-break:break-word}.chat-bubble--user{background:var(--accent-strong);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.chat-bubble--assistant{background:#f0f0f2;color:var(--foreground);align-self:flex-start;border-bottom-left-radius:4px}.chat-bubble-text{white-space:pre-wrap}.chat-bubble-markdown,.chat-bubble-text{margin:0;font-size:.95rem;line-height:1.45}.chat-bubble-markdown>:first-child{margin-top:0}.chat-bubble-markdown>:last-child{margin-bottom:0}.chat-bubble-markdown blockquote,.chat-bubble-markdown ol,.chat-bubble-markdown p,.chat-bubble-markdown pre,.chat-bubble-markdown ul{margin:.35rem 0}.chat-bubble-markdown code{font-family:Consolas,Courier New,monospace;font-size:.9em}.chat-bubble-markdown a{color:inherit}.chat-bubble-markdown img{display:block;width:100%;max-width:100%;max-height:min(46vh,320px);height:auto;object-fit:contain;border-radius:10px;margin:.4rem 0}.chat-input-row{display:flex;flex-direction:column;gap:.5rem}.chat-input{width:100%;border:1px solid var(--line);border-radius:10px;padding:.6rem .75rem;font-family:inherit;font-size:.95rem;resize:vertical;background:#fff;color:var(--foreground)}.chat-input:focus{outline:2px solid var(--accent-strong);outline-offset:1px}.proposed-outline-card,.saved-outline-card{border:1px solid var(--line);border-radius:14px;padding:.85rem 1rem;background:#fafafa}.outline-preview{display:flex;flex-direction:column;gap:.4rem}.outline-preview-title{font-weight:700;font-size:1rem;margin:0}.outline-page-list{margin:.4rem 0 0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.3rem}.outline-page-item{font-size:.88rem;color:var(--muted)}.generation-panel{display:flex;flex-direction:column;gap:1rem;position:-webkit-sticky;position:sticky;top:76px;align-self:start;max-height:calc(100vh - 92px);overflow-y:auto;padding-right:.2rem}.story-editor-status-card{position:static;background:#fafafa}.story-editor-steps{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.story-editor-step{display:inline-flex;align-items:center;min-height:38px;padding:0 .8rem;border-radius:999px;border:1.5px solid var(--line);background:rgba(255,255,255,.9);color:var(--muted);font-size:.82rem;font-weight:700}.story-editor-step--active{background:rgba(91,61,130,.12);border-color:var(--accent);color:var(--accent-strong)}.story-editor-step--done{background:rgba(91,61,130,.08);border-color:rgba(91,61,130,.3);color:var(--accent-strong);opacity:.72}.story-editor-inline-actions{display:flex;justify-content:flex-start}.story-editor-card{background:#fafafa}.story-editor-approval-card,.story-editor-image-card,.story-editor-page-card,.story-editor-plan-card{border:1px solid var(--line);border-radius:14px;padding:.85rem 1rem;background:#fff}.story-editor-card-title{margin:0 0 .35rem;font-size:.92rem;font-weight:700;color:var(--accent-strong)}.story-editor-gallery,.story-editor-plan-list{display:grid;grid-gap:.75rem;gap:.75rem}.story-editor-image-preview{display:block;width:100%;border-radius:12px;margin:.6rem 0}.story-editor-share-note{border-top:1px solid var(--line);padding-top:.75rem}.inpaint-modal-backdrop{position:fixed;inset:0;background:rgba(20,18,32,.72);display:flex;align-items:flex-start;justify-content:center;padding:1rem;z-index:1000;overflow-y:auto}.inpaint-modal{width:min(1100px,100%);height:min(96vh,1080px);max-height:calc(100vh - 2rem);overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;border-radius:18px;background:#fff;padding:.85rem 1rem 1rem;box-shadow:0 24px 80px rgba(0,0,0,.24);display:flex;flex-direction:column;gap:.7rem}.inpaint-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.inpaint-header-copy{min-width:0}.inpaint-close-button{margin-left:auto}.inpaint-stage{position:relative;width:100%;min-height:320px;flex:1 1 auto;min-width:0;display:flex;justify-content:center;align-items:center;background:linear-gradient(180deg,#f8f6fb,#f1edf8);border:1px solid var(--line);border-radius:16px;padding:.35rem;overflow:hidden}.inpaint-canvas-stack{position:relative;flex:0 0 auto}.inpaint-canvas{display:block;width:100%;height:100%;border-radius:12px}.inpaint-canvas--overlay{position:absolute;inset:0;touch-action:none;cursor:crosshair}.inpaint-controls{display:grid;grid-gap:.65rem;gap:.65rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (max-width:900px){.story-edit-layout{grid-template-columns:1fr;min-height:auto}.generation-panel,.story-edit-layout .chat-panel{max-height:none;overflow:visible}.generation-panel{position:static;top:auto;padding-right:0}.story-editor-status-card{position:static}}.auth-panel{width:min(460px,100%);margin-top:10vh;display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.auth-logo{text-align:center;margin-bottom:1rem}.auth-brand{margin:0;font-size:2rem;font-weight:800;color:var(--accent-strong);letter-spacing:-.02em}.auth-tagline{margin:.3rem 0 0;color:var(--muted);font-size:.97rem}.google-signin-button{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:.7rem 1rem;margin-top:1rem}.auth-note{text-align:center;font-size:.87rem;margin-top:.5rem}.pin-keypad{margin-top:.9rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.55rem;gap:.55rem}.pin-keypad-button{min-height:56px;border-radius:14px;border:1.5px solid var(--line);background:#fff;color:var(--accent-strong);font:inherit;font-size:1.05rem;font-weight:800;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .12s ease}.pin-keypad-button:hover:not(:disabled){background:#f7f2ff;border-color:var(--accent)}.pin-keypad-button:disabled{opacity:.45;cursor:not-allowed}.pin-keypad-button--secondary{font-size:.92rem;font-weight:700}.settings-sections{display:flex;flex-direction:column;gap:.65rem;margin-top:.5rem}.settings-section{border:1.5px solid var(--line);border-radius:16px;background:rgba(255,255,255,.78);overflow:hidden}.settings-section-header{display:flex;flex-direction:column;gap:.18rem;padding:.9rem 1.1rem;cursor:pointer;list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .12s ease}.settings-section-header::-webkit-details-marker{display:none}.settings-section-header:before{content:"▶";position:absolute;right:1.1rem;font-size:.7rem;color:var(--muted);transition:transform .18s ease}details.settings-section[open]>.settings-section-header:before{transform:rotate(90deg)}.settings-section-header{position:relative;padding-right:2.2rem}.settings-section-header:hover{background:#f7f2ff}.settings-section-title{font-weight:800;font-size:1rem;color:var(--accent-strong)}.settings-section-subtitle{font-size:.84rem;color:var(--muted);line-height:1.45}.settings-section-body{padding:0 1.1rem 1rem;border-top:1px solid var(--line)}.auth-error{text-align:center;margin-bottom:.5rem}.auth-error-title{margin-top:1rem;text-align:center}.auth-error-detail{margin-top:.5rem;text-align:center}.auth-back-link{margin-top:1.5rem;display:inline-block;text-decoration:none}.home-endpoint-note{margin-top:1rem}.onboarding-form{display:flex;flex-direction:column;gap:.25rem}.onboarding-form .action-button{margin-top:1.25rem}.onboarding-signout-row{margin-top:.3rem}.onboarding-hint{font-size:.88rem;margin:.25rem 0 0}.json-editor:focus,.text-input:focus{outline:2px solid var(--accent-strong);outline-offset:1px}.action-button.inline-link,.action-button.inline-link:hover{color:#fff;text-decoration:none}.secondary-button.inline-link,.secondary-button.inline-link:hover{color:var(--accent-strong);text-decoration:none}.nav-menu{position:relative}.nav-menu summary{list-style:none}.nav-menu summary::-webkit-details-marker{display:none}.nav-menu-trigger{display:inline-flex;align-items:center;gap:.7rem;padding:.6rem .85rem;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--ink);cursor:pointer}.nav-menu-icon{display:inline-flex;flex-direction:column;justify-content:center;gap:.18rem}.nav-menu-icon span{display:block;width:1rem;height:2px;border-radius:999px;background:var(--accent-strong)}.nav-menu-label{font-weight:600}.nav-menu-popover{position:absolute;right:0;top:calc(100% + .5rem);min-width:220px;display:flex;flex-direction:column;gap:.35rem;padding:.55rem;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.98);box-shadow:0 16px 40px rgba(7,28,25,.14);z-index:10}.nav-menu-link{display:block;padding:.65rem .8rem;border-radius:12px;color:var(--ink);text-decoration:none}.nav-menu-link:hover{background:#f3eeff}.app-banner{position:-webkit-sticky;position:sticky;top:0;z-index:40;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;background:linear-gradient(135deg,#4f356f,#6b4a95);color:#fff;box-shadow:0 2px 12px rgba(63,41,94,.28)}.app-banner-title{font-size:1.1rem;font-weight:800;letter-spacing:.01em;color:#fff;text-decoration:none}.app-banner-nav{display:flex;align-items:center;gap:.5rem}.app-banner-menu{position:relative}.app-banner-link{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 .85rem;border-radius:999px;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.12);color:#fff;font:inherit;font-size:.85rem;font-weight:600;text-decoration:none;cursor:pointer;transition:background .15s}.app-banner-link:hover{background:rgba(255,255,255,.22)}.app-banner-link--menu.is-open{background:rgba(255,255,255,.26)}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:1rem;gap:1rem;margin-top:1.25rem}.home-card{display:flex;flex-direction:column;gap:.5rem;padding:1.1rem 1.25rem;border:1.5px solid var(--line);border-radius:16px;background:rgba(255,255,255,.75);text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .12s,border-color .12s}.home-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(63,41,94,.14);border-color:var(--accent)}.home-card:focus-visible{outline:3px solid #f2bb00;outline-offset:3px;border-color:#f2bb00}.home-card-emoji{font-size:1.75rem;line-height:1}.home-card-title{margin:0;font-size:1rem;font-weight:700;color:var(--accent-strong)}.home-card-desc{margin:0;font-size:.85rem;color:var(--muted);line-height:1.4}.home-section-label{margin:1.5rem 0 .5rem;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.home-hero{display:flex;flex-direction:column;gap:.35rem;padding-bottom:1rem;border-bottom:1px solid var(--line);margin-bottom:.5rem}.home-hero .story-title{color:var(--accent-strong)}.library-controls{justify-content:space-between;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid var(--line);margin-bottom:1.25rem}.library-controls,.library-filter-row{display:flex;align-items:center;flex-wrap:wrap}.library-filter-row{gap:.5rem}.library-filter-chip{display:inline-flex;align-items:center;min-height:44px;border-radius:999px;border:1.5px solid var(--line);background:rgba(255,255,255,.8);color:var(--accent-strong);font:inherit;font-size:.82rem;font-weight:700;padding:0 1rem;cursor:pointer;transition:background .12s,border-color .12s}.library-filter-chip.is-active{background:rgba(91,61,130,.12);border-color:var(--accent);color:var(--accent-strong)}.library-filter-chip:hover:not(.is-active){background:rgba(255,255,255,.95);border-color:var(--accent)}.library-filter-chip:focus-visible{outline:3px solid #f2bb00;outline-offset:2px}.library-section{margin-bottom:1.5rem}.library-section-title{font-size:.92rem;font-weight:800;color:var(--accent-strong);letter-spacing:.05em;text-transform:uppercase;margin:0 0 .75rem}.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.story-card{display:flex;flex-direction:column;background:rgba(255,255,255,.9);border:1.5px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .12s,border-color .12s;box-shadow:0 2px 8px rgba(63,41,94,.08)}.story-card:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(63,41,94,.16);border-color:var(--accent)}.story-card-thumb{object-fit:cover;display:block}.story-card-thumb,.story-card-thumb-placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#ede8f4,#d5cce6)}.story-card-thumb-placeholder{display:flex;align-items:center;justify-content:center;font-size:2.5rem}.story-card-body{padding:.65rem .8rem .8rem;display:flex;flex-direction:column;gap:.2rem;flex:1 1}.story-card-title{margin:0;font-size:.9rem;font-weight:700;color:var(--accent-strong);line-height:1.2}.story-card-meta{margin:0;font-size:.75rem;color:var(--muted)}.story-card-actions{margin-top:.5rem;display:flex;gap:.4rem;flex-wrap:wrap}.story-card-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;border-radius:8px;border:1.5px solid var(--line);background:rgba(255,255,255,.9);color:var(--accent-strong);font:inherit;font-size:.75rem;font-weight:700;padding:0 .6rem;cursor:pointer;text-decoration:none;transition:background .12s,border-color .12s}.story-card-btn:hover{border-color:var(--accent);background:#f3eeff}.story-card-btn:focus-visible{outline:3px solid #f2bb00;outline-offset:2px}.story-card-btn.is-primary{background:linear-gradient(135deg,var(--accent-strong) 0,var(--accent-light) 100%);color:#fff;border-color:var(--accent-strong)}.story-card-btn.is-playing{background:#f0c14f;border-color:#d4a835;color:#23162f}.reader-split{display:grid;grid-template-columns:1fr 1fr;grid-gap:0;gap:0;min-height:480px;border-radius:14px;overflow:hidden;border:1px solid var(--line);margin-top:1rem}.reader-split-image{background:#1a1025;display:flex;align-items:center;justify-content:center;overflow:hidden}.reader-split-image img{width:100%;height:100%;object-fit:contain;display:block}.reader-split-image-empty{color:rgba(255,255,255,.35);font-size:.85rem;padding:2rem;text-align:center}.reader-split-text{background:#fffdf9;padding:2.5rem 2rem;overflow-y:auto;display:flex;flex-direction:column;justify-content:center;border-left:2px solid #2e1f46}.reader-split-text.is-speaking{background:#fff8e9;box-shadow:inset 0 0 0 3px rgba(223,162,34,.18)}.reader-split-page-num{font-size:.72rem;font-weight:800;color:#9a8aaa;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem}.reader-split-body{font-size:1.2rem;line-height:1.65;color:#2c2540;margin:0}@media (max-width:700px){.reader-split{grid-template-columns:1fr}.reader-split-image{min-height:240px}.reader-split-text{border-left:none;border-top:2px solid #2e1f46;padding:1.5rem}}.drawings-filter-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}.drawings-filter-btn{display:inline-flex;align-items:center;min-height:44px;border-radius:999px;border:1.5px solid var(--line);background:rgba(255,255,255,.8);color:var(--muted);font:inherit;font-size:.8rem;font-weight:700;padding:0 .85rem;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.drawings-filter-btn.is-active{background:rgba(91,61,130,.12);border-color:var(--accent);color:var(--accent-strong)}.drawings-filter-btn:focus-visible{outline:3px solid #f2bb00;outline-offset:2px}.drawings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:.85rem;gap:.85rem;margin-top:1rem}.drawing-card{padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:14px;background:rgba(255,255,255,.8);display:flex;flex-direction:column;gap:.35rem}.drawing-card-title{margin:0;font-weight:700;font-size:.92rem;color:var(--accent-strong)}.drawing-card-meta{margin:0;font-size:.78rem;color:var(--muted)}.drawing-status-chip{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 .6rem;font-size:.72rem;font-weight:700;background:#f3eeff;color:var(--accent-strong);border:1px solid var(--line)}.drawing-status-chip.is-approved{background:#e8f5e9;color:#2e7d32;border-color:#a5d6a7}.parent-mode-badge{display:inline-flex;align-items:center;min-height:var(--touch-min);border-radius:999px;border:2px solid #a5d6a7;background:#e8f5e9;color:#2e7d32;font:inherit;font-weight:600;padding:.62rem 1.2rem;white-space:nowrap}.device-status-chip{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 .6rem;font-size:.72rem;font-weight:700;border:1px solid var(--line);background:#f6f1ff;color:var(--accent-strong)}.device-status-chip.is-valid{background:#e8f5e9;color:#2e7d32;border-color:#a5d6a7}.device-status-chip.is-refresh{background:#fff4e5;color:#9a5c00;border-color:#f1c27d}.device-status-chip.is-expired{background:#fdecea;color:#b42318;border-color:#f5b5b0}.app-banner-link--menu{width:42px;padding:0}.app-banner-hamburger{display:inline-flex;flex-direction:column;gap:3px}.app-banner-hamburger span{width:16px;height:2px;border-radius:999px;background:#fff;transition:transform .15s ease,opacity .15s ease}.app-banner-link--menu.is-open .app-banner-hamburger span:first-child{transform:translateY(5px) rotate(45deg)}.app-banner-link--menu.is-open .app-banner-hamburger span:nth-child(2){opacity:0}.app-banner-link--menu.is-open .app-banner-hamburger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}.app-banner-popover{left:0;right:auto;top:calc(100% + .4rem)}.app-banner-user{display:inline-flex;align-items:center;gap:.4rem;min-height:36px;padding:0 .85rem;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);font-size:.85rem;font-weight:700}.app-banner-user-name{color:inherit}.app-banner-user-name--action{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:2px}.app-banner-user-name--action:hover{opacity:.9}.app-banner-user-name--action:focus-visible{outline:2px solid rgba(255,255,255,.95);outline-offset:2px;border-radius:6px}.app-banner-user--child{background:#7c3aed;border-color:#a78bfa;color:#fff}.app-banner-user--parent-mode{background:#166534;border-color:#4ade80;color:#fff}.app-banner-role-badge{display:inline-block;padding:.1rem .45rem;border-radius:999px;font-size:.68rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.35)}.app-banner-user-mode{opacity:.88}.setup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));grid-gap:1rem;gap:1rem}.setup-panel{padding:1rem 1.1rem;border-radius:16px;border:1.5px solid var(--line);background:rgba(255,255,255,.78);display:flex;flex-direction:column;gap:.75rem}.setup-panel--compact{min-height:0;max-width:100%}.setup-panel-header{display:flex;flex-direction:column;gap:.25rem}.setup-panel-title{margin:0;font-size:1rem;font-weight:800;color:var(--accent-strong)}.setup-panel-subtitle{margin:0;font-size:.84rem;line-height:1.45;color:var(--muted)}.setup-form{display:flex;flex-direction:column;gap:.55rem}.profile-chip-list{display:flex;flex-wrap:wrap;gap:.5rem}.profile-chip{display:flex;flex-direction:column;gap:.1rem;padding:.55rem .75rem;border-radius:12px;border:1.5px solid var(--line);background:#fff}.profile-chip-name{font-size:.82rem;font-weight:700;color:var(--accent-strong)}.profile-chip-meta{font-size:.74rem;color:var(--muted)}.canvas-editor{display:flex;flex-direction:column;gap:.75rem}.drawing-canvas{width:100%;max-width:100%;aspect-ratio:16/9;border-radius:14px;border:1.5px solid var(--line);background:transparent;touch-action:none;cursor:crosshair;box-shadow:inset 0 1px 8px rgba(63,41,94,.06)}.drawing-view{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:.75rem;gap:.75rem;align-items:stretch}.drawing-stage-wrap{min-height:0}.drawing-stage{position:relative;border:3px solid #d8c6eb;border-radius:16px;background:#fff;box-shadow:inset 0 0 0 1px #eee4f7;overflow:hidden}.drawing-tracer-image{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;pointer-events:none;z-index:0}.drawing-canvas--rpi{position:relative;z-index:1;border:0;border-radius:0;box-shadow:none;background:transparent}.drawing-tracer-panel{margin-top:.75rem;border:1px solid #d9caeb;border-radius:16px;background:linear-gradient(180deg,#fcf8ff,#f7f2ff);padding:.9rem;display:grid;grid-gap:.75rem;gap:.75rem}.drawing-tracer-panel__header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.drawing-tracer-card__title,.drawing-tracer-panel__label,.drawing-tracer-picker__title,.drawing-tracer-selection__title{margin:0;font-weight:700;color:#2e1f49}.drawing-tracer-card__caption,.drawing-tracer-panel__hint,.drawing-tracer-picker__hint,.drawing-tracer-selection__caption{margin:.2rem 0 0;color:#5f5074;font-size:.92rem}.drawing-tracer-selection{display:grid;grid-template-columns:92px minmax(0,1fr) auto;align-items:center;grid-gap:.9rem;gap:.9rem;padding:.8rem;border-radius:14px;background:rgba(255,255,255,.82);border:1px solid #ded1ef}.drawing-tracer-card__image,.drawing-tracer-selection__preview{width:100%;aspect-ratio:1/1;object-fit:contain;border-radius:12px;background:#fff;border:1px solid #e5daf3}.drawing-tracer-picker{position:relative;border-radius:18px;background:rgba(255,255,255,.98);border:1px solid #d8c8ec;box-shadow:0 18px 40px rgba(46,31,73,.12);padding:1rem;display:grid;grid-gap:.9rem;gap:.9rem}.drawing-tracer-picker__header{display:flex;justify-content:space-between;gap:.8rem;align-items:flex-start}.drawing-tracer-picker__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:.75rem;gap:.75rem}.drawing-tracer-card{border-radius:16px;border:2px solid #e3d8f1;background:#fff;padding:.8rem;display:grid;grid-gap:.6rem;gap:.6rem;text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.drawing-tracer-card.is-selected,.drawing-tracer-card:focus-visible,.drawing-tracer-card:hover{border-color:#9067bd;box-shadow:0 10px 24px rgba(96,63,148,.16);transform:translateY(-1px)}.drawing-rail{position:relative;border-radius:14px;border:1px solid #d7c7ea;background:#fff;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;padding:10px 8px;gap:8px}.drawing-tool{width:52px;min-height:52px;border-radius:12px;border:1px solid #dac8ef;background:#f8f2ff;color:#4b356a;font-size:1.1rem;font-weight:700;cursor:pointer}.drawing-tool.is-active{border-color:#8f6bb9;background:#eadbff}.action-button:focus-visible,.drawing-swatch:focus-visible,.drawing-tool:focus-visible,.field-input:focus-visible,.secondary-button:focus-visible,.text-input:focus-visible{outline:3px solid #f2bb00;outline-offset:2px}.drawing-color-toggle{padding:0;display:flex;align-items:center;justify-content:center}.drawing-color-dot{width:24px;height:24px;border-radius:999px;border:2px solid rgba(0,0,0,.2);background:#1f2937}.drawing-color-tray{position:absolute;right:calc(100% + 8px);bottom:8px;z-index:20;width:168px;border-radius:12px;border:1px solid #d7c5ea;background:#fff;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:6px;gap:6px;padding:8px 6px;max-height:min(52vh,320px);overflow:hidden;pointer-events:auto;box-shadow:0 12px 28px rgba(0,0,0,.2);transition:max-height .2s ease,opacity .2s ease,transform .2s ease}.drawing-color-tray.is-collapsed{max-height:0;opacity:0;transform:translateX(8px);pointer-events:none;border:none;padding:0}.drawing-swatch{width:100%;aspect-ratio:1/1;border-radius:10px;border:2px solid #fff;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);background:var(--swatch);cursor:pointer}@media (max-width:900px){.drawing-view{grid-template-columns:1fr}.drawing-rail{flex-direction:row;justify-content:flex-start;flex-wrap:wrap}.drawing-color-tray{right:auto;left:0;bottom:calc(100% + 8px)}.drawing-tracer-selection{grid-template-columns:72px minmax(0,1fr)}.drawing-tracer-selection .secondary-button{grid-column:1/-1}.drawing-tracer-panel__header,.drawing-tracer-picker__header{flex-direction:column}}.drawing-fullscreen-shell{position:relative;height:calc(100vh - 60px);overflow:hidden;background:radial-gradient(circle at 18% 22%,#fff5e7 0,#f6efdf 44%,#efe6d7 100%)}.drawing-workspace{position:relative;width:100%;height:100%}.drawing-stage-immersive{position:absolute;inset:0;padding:8px}.drawing-top-strip{position:absolute;top:14px;left:14px;z-index:7;width:min(320px,calc(100% - 130px))}.drawing-title-input{width:100%;min-height:42px;border-radius:12px;border:1px solid #d7c7ea;background:rgba(255,255,255,.95);color:#3f2a5d;font-size:1rem;padding:.5rem .7rem;outline:none}.drawing-title-input:focus{border-color:#8f66bc;box-shadow:0 0 0 2px rgba(143,102,188,.2)}.drawing-canvas-immersive{width:100%;height:100%;border-radius:16px;border:2px solid rgba(91,61,130,.22);background:#fff;box-shadow:inset 0 0 0 1px rgba(79,53,111,.06);touch-action:none;cursor:crosshair}.drawing-dock{position:absolute;top:12px;right:12px;bottom:12px;width:74px;display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px 8px;border:1px solid #d7c7ea;border-radius:16px;background:rgba(255,255,255,.96);box-shadow:0 10px 26px rgba(63,41,94,.2);z-index:6;overflow-y:auto}.drawing-dock.is-collapsed{width:54px;padding-left:6px;padding-right:6px}.drawing-dock-btn{width:100%;min-height:44px;border-radius:12px;border:1px solid #d9c8ee;background:#f8f2ff;color:#4b356a;font-size:1.2rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;cursor:pointer}.drawing-dock-btn.is-active{border-color:#7c55a7;background:#ebddff;box-shadow:inset 0 0 0 2px rgba(124,85,167,.26)}.drawing-dock-btn.is-save{margin-top:auto;background:#dff6d7;border-color:#8ed083}.drawing-size-control{width:100%;border:1px solid #d9c8ee;border-radius:12px;background:#f8f2ff;padding:.35rem .4rem}.drawing-size-control input[type=range]{width:100%}.drawing-overlay-panel{position:absolute;top:16px;right:96px;bottom:16px;width:min(440px,calc(100% - 128px));border-radius:18px;border:1px solid #d8c8ec;background:rgba(255,255,255,.98);box-shadow:0 18px 40px rgba(46,31,73,.18);padding:.8rem;z-index:7;overflow:auto}.drawing-overlay-panel--colors,.drawing-overlay-panel--sizes{width:min(300px,calc(100% - 128px));display:flex;flex-direction:column;gap:.8rem}.drawing-size-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:.45rem;gap:.45rem}.drawing-size-chip{min-height:44px;border-radius:12px;border:1px solid #d9c8ee;background:#f8f2ff;display:inline-flex;align-items:center;justify-content:center}.drawing-size-chip.is-selected{border-color:#7c55a7;box-shadow:inset 0 0 0 2px rgba(124,85,167,.22)}.drawing-size-dot{width:var(--dot-size,8px);height:var(--dot-size,8px);border-radius:999px;background:#4b356a}.drawing-overlay-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));grid-gap:.65rem;gap:.65rem}.drawing-overlay-card{border:2px solid #e4daf2;border-radius:14px;background:#fff;padding:.4rem;display:grid;grid-gap:.25rem;gap:.25rem;justify-items:center}.drawing-overlay-card.is-selected{border-color:#8d67b8;box-shadow:0 10px 20px rgba(96,63,148,.14)}.drawing-overlay-thumb{width:100%;aspect-ratio:1/1;object-fit:contain;border-radius:10px;background:#fff;border:1px solid #e8def3}.drawing-overlay-emoji{font-size:1.05rem}.drawing-color-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:.45rem;gap:.45rem}.drawing-swatch--recent{outline:2px solid #1f2937;outline-offset:1px}.drawing-native-color{width:100%;height:48px;border-radius:10px;border:1px solid #d7c5ea;background:#fff}.drawing-screen-message-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.8rem}.drawing-screen-message{margin:0;color:#56436f;font-size:1rem;font-weight:700}.drawing-mini-btn{min-width:44px;min-height:44px;border-radius:999px;border:1px solid #cfbee7;background:#fff;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.drawing-toast{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);margin:0;padding:.4rem .75rem;border-radius:999px;background:rgba(44,28,67,.82);color:#fff;font-size:.84rem;z-index:8}@media (max-width:900px){.drawing-top-strip{width:min(240px,calc(100% - 110px))}.drawing-overlay-panel{right:76px;width:min(320px,calc(100% - 88px))}.drawing-dock{width:62px}.drawing-dock-btn{min-height:40px;font-size:1rem}}