*{margin:0;padding:0;box-sizing:border-box}:root{--color-cream: #f5f0e8;--color-ink: #1a1a1a;--color-ink-light: #555;--color-ink-faint: #999;--color-border: #d4cfc5;--color-accent: #1a1a1a;--color-danger: #933;--color-overlay: rgba(245, 240, 232, .92);--color-panel: rgba(245, 240, 232, .95);--color-scrim: rgba(26, 26, 26, .85);--font-display: "Crimson Text", Georgia, "Times New Roman", serif;--font-body: "Crimson Text", Georgia, "Times New Roman", serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--radius: 0;--z-header: 50;--z-overlay: 1000;--z-modal: 1100;--z-toggle: 1200;--transition: .2s ease;--transition-slow: .6s ease;font-size:clamp(16px,1rem + .4vw,22px);--text-hero: clamp(1.9rem, 1.4rem + 2.4vw, 2.6rem);--text-h1: clamp(1.5rem, 1.2rem + 1.4vw, 1.9rem);--text-h2: clamp(1.2rem, 1.05rem + .7vw, 1.5rem);--text-xs: .8rem;font-family:var(--font-body);line-height:1.6;font-weight:400;color:var(--color-ink);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--color-cream: #141417;--color-ink: #e0dbd2;--color-ink-light: #a09a90;--color-ink-faint: #605c55;--color-border: #2a2824;--color-accent: #e0dbd2;--color-danger: #d98a8a;--color-overlay: rgba(20, 20, 23, .92);--color-panel: rgba(20, 20, 23, .95);--color-scrim: rgba(8, 8, 10, .88)}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden;background:var(--color-cream);transition:background-color .3s ease,color .3s ease}#root{width:100vw;height:100vh;margin:0;padding:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.browse{max-width:1080px;margin:0 auto;padding:40px 32px 80px}.browse-hero{text-align:center;padding:32px 0 40px}.browse-headline{font-family:var(--font-display);font-weight:400;font-size:var(--text-hero);line-height:1.15;letter-spacing:.01em;color:var(--color-ink, #1a1a1a);margin-bottom:var(--space-3)}.browse-tagline{font-style:italic;color:var(--color-ink-light, #555);font-size:1.1rem;margin-bottom:28px}.browse-search-row{display:flex;gap:12px;max-width:620px;margin:0 auto}.browse-search{flex:1;padding:12px 16px;border:1px solid var(--color-border, #d4cfc5);border-radius:0;background:transparent;font-family:var(--font-body);font-size:1rem;color:var(--color-ink, #1a1a1a);outline:none;transition:border-color .2s ease}.browse-search:focus{border-color:var(--color-ink, #1a1a1a)}.browse-search::placeholder{color:var(--color-ink-faint, #999)}.browse-create-cta{padding:12px 18px;white-space:nowrap;background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);font-family:var(--font-body);font-size:.95rem;letter-spacing:.04em;text-transform:lowercase;cursor:pointer;transition:opacity .2s ease}.browse-create-cta:hover{opacity:.85}.browse-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}.tag-chip{padding:5px 14px;background:transparent;border:1px solid var(--color-border, #d4cfc5);border-radius:999px;font-family:var(--font-body);font-size:.85rem;color:var(--color-ink-light, #555);cursor:pointer;text-transform:lowercase;transition:border-color .2s ease,background .2s ease,color .2s ease}.tag-chip:hover{border-color:var(--color-ink, #1a1a1a)}.tag-chip.active{background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border-color:var(--color-ink, #1a1a1a)}.browse-tabs{display:flex;gap:24px;justify-content:center;border-bottom:1px solid var(--color-border, #d4cfc5);margin-bottom:32px}.browse-tab{background:transparent;border:none;border-bottom:2px solid transparent;padding:10px 4px;margin-bottom:-1px;font-family:var(--font-body);font-size:1rem;color:var(--color-ink-faint, #999);cursor:pointer;text-transform:lowercase;letter-spacing:.04em;transition:color .2s ease,border-color .2s ease}.browse-tab:hover{color:var(--color-ink, #1a1a1a)}.browse-tab.active{color:var(--color-ink, #1a1a1a);border-bottom-color:var(--color-ink, #1a1a1a)}.browse-status{text-align:center;color:var(--color-ink-faint, #999);font-style:italic;padding:48px 0}.browse-error{color:var(--color-danger)}.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-5)}.story-card{display:flex;flex-direction:column;text-align:left;background:transparent;border:1px solid var(--color-border, #d4cfc5);border-radius:0;padding:0;cursor:pointer;overflow:hidden;transition:border-color .2s ease,transform .15s ease}.story-card:hover{border-color:var(--color-ink, #1a1a1a);transform:translateY(-2px)}.story-cover{position:relative;aspect-ratio:16 / 10;background-size:cover;background-position:center;background-color:var(--color-border, #d4cfc5);display:flex;align-items:center;justify-content:center}.story-cover-fallback{font-family:var(--font-display);font-size:1.1rem;color:var(--color-ink-light, #555);padding:12px;text-align:center}.story-mode-tag{position:absolute;top:8px;right:8px;font-size:var(--text-xs);letter-spacing:.04em;text-transform:lowercase;font-style:italic;color:#f5f0e8;background:#1a1a1ab3;padding:2px 8px}.story-progress-tag{position:absolute;bottom:8px;left:8px;font-size:var(--text-xs);letter-spacing:.04em;text-transform:lowercase;color:#f5f0e8;background:#225a3cd9;padding:2px 8px}.story-card-body{padding:14px 16px 18px;display:flex;flex-direction:column;gap:6px}.story-card-title{font-family:var(--font-display);font-weight:400;font-size:1.15rem;color:var(--color-ink, #1a1a1a);line-height:1.3}.story-card-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-ink-faint, #999)}.story-handle{font-style:italic}.story-card-blurb{font-size:.88rem;color:var(--color-ink-light, #555);line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.browse-pagination{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:40px}.browse-pagination button{background:transparent;border:1px solid var(--color-border, #d4cfc5);padding:8px 16px;font-family:var(--font-body);font-size:.9rem;color:var(--color-ink, #1a1a1a);cursor:pointer;text-transform:lowercase;transition:border-color .2s ease}.browse-pagination button:hover:not(:disabled){border-color:var(--color-ink, #1a1a1a)}.browse-pagination button:disabled{opacity:.3;cursor:not-allowed}.browse-pagination span{font-size:.9rem;color:var(--color-ink-light, #555)}@media (max-width: 560px){.browse{padding:var(--space-5) var(--space-4) var(--space-8)}.browse-search-row{flex-direction:column}.story-grid{grid-template-columns:1fr}}.detail{max-width:820px;margin:0 auto;padding:32px 32px 80px}.detail-back{background:transparent;border:none;color:var(--color-ink-faint, #999);font-family:var(--font-body);font-size:.9rem;text-transform:lowercase;cursor:pointer;padding:0;margin-bottom:24px;transition:color .2s ease}.detail-back:hover{color:var(--color-ink, #1a1a1a)}.detail-hero{display:flex;gap:28px;margin-bottom:36px}.detail-cover{flex:0 1 300px;width:100%;max-width:300px;aspect-ratio:16 / 10;background-size:cover;background-position:center;background-color:var(--color-border, #d4cfc5);border:1px solid var(--color-border, #d4cfc5);display:flex;align-items:center;justify-content:center}.detail-cover span{font-family:var(--font-display);color:var(--color-ink-light, #555);text-align:center;padding:12px}.detail-meta{flex:1;min-width:0}.detail-meta h1{font-family:var(--font-display);font-weight:400;font-size:var(--text-h1);line-height:1.2;color:var(--color-ink, #1a1a1a);margin-bottom:8px}.detail-byline{color:var(--color-ink-light, #555);font-size:.9rem;display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:14px}.detail-byline .dot{color:var(--color-ink-faint, #999)}.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.detail-tag{font-size:var(--text-xs);text-transform:lowercase;color:var(--color-ink-light, #555);border:1px solid var(--color-border, #d4cfc5);border-radius:999px;padding:3px 10px}.detail-protagonist{color:var(--color-ink-light, #555);margin-bottom:18px;line-height:1.5}.detail-actions{display:flex;gap:12px;flex-wrap:wrap}.detail-play{padding:12px 28px;background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);font-family:var(--font-body);font-size:1rem;letter-spacing:.04em;text-transform:lowercase;cursor:pointer;transition:opacity .2s ease}.detail-play:hover{opacity:.85}.detail-play-secondary{padding:12px 22px;background:transparent;color:var(--color-ink, #1a1a1a);border:1px solid var(--color-border, #d4cfc5);font-family:var(--font-body);font-size:1rem;text-transform:lowercase;cursor:pointer;transition:border-color .2s ease}.detail-play-secondary:hover{border-color:var(--color-ink, #1a1a1a)}.detail-section{border-top:1px solid var(--color-border, #d4cfc5);padding-top:24px;margin-bottom:32px}.detail-section h2{font-family:var(--font-display);font-weight:400;font-size:var(--text-h2);text-transform:lowercase;letter-spacing:.04em;color:var(--color-ink, #1a1a1a);margin-bottom:14px}.detail-description{color:var(--color-ink, #1a1a1a);line-height:1.65;white-space:pre-wrap}.detail-characters{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.detail-character:after{content:"";display:block;clear:both}.detail-character-portrait{float:left;width:80px;height:80px;margin:2px 14px 6px 0;background-color:var(--color-border, #d4cfc5);background-size:200% auto;background-position:center 6%;background-repeat:no-repeat;border-radius:2px}.detail-character h3{font-family:var(--font-display);font-weight:400;font-size:1.05rem;color:var(--color-ink, #1a1a1a);margin-bottom:4px}.detail-character p{color:var(--color-ink-light, #555);font-size:.9rem;line-height:1.5}.comment-form{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.comment-form textarea{padding:12px;border:1px solid var(--color-border, #d4cfc5);border-radius:0;background:transparent;color:var(--color-ink, #1a1a1a);font-family:var(--font-body);font-size:1rem;resize:vertical;outline:none;transition:border-color .2s ease}.comment-form textarea:focus{border-color:var(--color-ink, #1a1a1a)}.comment-post{align-self:flex-start;padding:8px 20px;background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);font-family:var(--font-body);text-transform:lowercase;cursor:pointer;transition:opacity .2s ease}.comment-post:hover:not(:disabled){opacity:.85}.comment-post:disabled{opacity:.35;cursor:not-allowed}.comment-signin,.comment-empty{color:var(--color-ink-faint, #999);font-style:italic;margin-bottom:18px}.link-btn{background:transparent;border:none;color:var(--color-ink, #1a1a1a);text-decoration:underline;cursor:pointer;font-family:var(--font-body);font-size:inherit;padding:0}.comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}.comment-list li{border-bottom:1px solid var(--color-border, #d4cfc5);padding-bottom:14px}.comment-head{display:flex;justify-content:space-between;margin-bottom:4px}.comment-handle{font-style:italic;color:var(--color-ink-light, #555);font-size:.9rem}.comment-time{color:var(--color-ink-faint, #999);font-size:var(--text-xs)}.comment-body{color:var(--color-ink, #1a1a1a);line-height:1.55;white-space:pre-wrap}@media (max-width: 640px){.detail{padding:24px 16px 60px}.detail-hero{flex-direction:column;gap:18px}.detail-cover{flex-basis:auto;width:100%}}.detail-restart-confirm{display:flex;flex-direction:column;gap:10px}.detail-restart-confirm p{font-size:.9rem;font-style:italic;color:var(--color-ink-light, #555);margin:0}.detail-restart-buttons{display:flex;gap:10px}.page{margin:0 auto;padding:var(--space-7) var(--space-6) 80px}.page--narrow{max-width:640px}.page--medium{max-width:820px}.page--wide{max-width:980px}.page-header{margin-bottom:var(--space-6)}.page-header__row{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3)}.page-title{margin:0;font-family:var(--font-display);font-weight:400;font-size:var(--text-h1);letter-spacing:.04em;text-transform:lowercase;color:var(--color-ink)}.page-subtitle{margin:var(--space-2) 0 0;color:var(--color-ink-light);font-style:italic}.page-header__actions{display:flex;align-items:center;gap:var(--space-2)}@media (max-width: 640px){.page{padding:var(--space-6) var(--space-4) var(--space-7)}}.create-form{display:flex;flex-direction:column;gap:28px}.create-group{display:flex;flex-direction:column;gap:6px}.create-group label{color:var(--color-ink-light, #555);font-size:.95rem;font-style:italic}.create-group input{padding:8px 0;border:none;border-bottom:1px solid var(--color-border, #d4cfc5);border-radius:0;font-size:1.1rem;font-family:var(--font-body);background:transparent;color:var(--color-ink, #1a1a1a);outline:none;transition:border-color .2s ease}.create-group input:focus{border-bottom-color:var(--color-ink, #1a1a1a)}.create-group input::placeholder{color:var(--color-ink-faint, #999)}.create-mode{display:flex;flex-direction:column;gap:6px}.create-endless{display:flex;align-items:center;gap:10px;cursor:pointer}.create-endless input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-ink, #1a1a1a)}.create-endless-label{font-family:var(--font-body);font-size:.95rem;color:var(--color-ink, #1a1a1a)}.create-endless-hint{margin:0;font-family:var(--font-body);font-size:.8rem;color:var(--color-ink-faint, #999)}.create-btn{padding:12px 24px;background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);border-radius:0;font-size:1rem;font-family:var(--font-body);letter-spacing:.06em;text-transform:lowercase;cursor:pointer;transition:opacity .2s ease}.create-btn:hover:not(:disabled){opacity:.85}.create-btn:disabled{opacity:.35;cursor:not-allowed}.create-btn-secondary{padding:12px 24px;background:transparent;color:var(--color-ink, #1a1a1a);border:1px solid var(--color-border, #d4cfc5);border-radius:0;font-size:1rem;font-family:var(--font-body);letter-spacing:.06em;text-transform:lowercase;cursor:pointer;transition:border-color .2s ease}.create-btn-secondary:hover:not(:disabled){border-color:var(--color-ink, #1a1a1a)}.create-error{color:var(--color-danger);font-size:.9rem;font-style:italic}.create-hint{color:var(--color-ink-faint, #999);font-style:italic;font-size:.85rem}.create-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 0;text-align:center;color:var(--color-ink-light, #555)}.create-loading .loading-spinner{width:28px;height:28px;border:2px solid var(--color-border, #d4cfc5);border-top-color:var(--color-ink, #1a1a1a);border-radius:50%;animation:create-spin .8s linear infinite}@keyframes create-spin{to{transform:rotate(360deg)}}.create-preview{display:flex;flex-direction:column;gap:20px}.create-cover{aspect-ratio:16 / 10;background-size:cover;background-position:center;background-color:var(--color-border, #d4cfc5);display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border, #d4cfc5)}.create-cover span{font-family:var(--font-display);color:var(--color-ink-light, #555);padding:16px;text-align:center}.create-preview-body h2{font-family:var(--font-display);font-weight:400;font-size:1.5rem;color:var(--color-ink, #1a1a1a);margin-bottom:8px}.create-title-label{display:block;font-size:var(--text-xs);text-transform:lowercase;letter-spacing:.04em;color:var(--color-ink-faint, #999);margin-bottom:4px}.create-title-input{width:100%;font-family:var(--font-display);font-weight:400;font-size:1.5rem;color:var(--color-ink, #1a1a1a);background:transparent;border:none;border-bottom:1px solid var(--color-border, #d4cfc5);padding:2px 0 6px;margin-bottom:12px;transition:border-color .2s ease}.create-title-input:focus{outline:none;border-bottom-color:var(--color-ink, #1a1a1a)}.create-title-input:disabled{opacity:.6}.create-genre{display:inline-block;font-size:var(--text-xs);text-transform:lowercase;font-style:italic;color:var(--color-ink-faint, #999);border:1px solid var(--color-border, #d4cfc5);padding:2px 8px;margin-bottom:12px}.create-blurb{color:var(--color-ink, #1a1a1a);margin-bottom:12px;line-height:1.5}.create-intro{color:var(--color-ink-light, #555);font-style:italic;line-height:1.6;margin-bottom:20px}.create-actions{display:flex;gap:12px;flex-wrap:wrap}.create-published{text-align:center;padding:40px 0}.create-published-msg{font-family:var(--font-display);font-size:1.3rem;color:var(--color-ink, #1a1a1a);margin-bottom:24px}.create-published .create-actions{justify-content:center}@media (max-width: 560px){.create{padding:var(--space-6) var(--space-4) var(--space-8)}.create-actions{flex-direction:column}.create-actions .create-btn,.create-actions .create-btn-secondary{width:100%}}.my-stories-status{color:var(--color-ink-faint, #999);font-style:italic;padding:32px 0}.my-stories-error{color:var(--color-danger)}.my-stories-list{display:flex;flex-direction:column;gap:24px}.my-story{display:flex;gap:20px;border:1px solid var(--color-border, #d4cfc5);padding:16px}.my-story-cover{flex:0 1 160px;width:100%;max-width:160px;aspect-ratio:16 / 10;background-size:cover;background-position:center;background-color:var(--color-border, #d4cfc5);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:8px;transition:opacity .2s ease}.my-story-cover:hover{opacity:.85}.my-story-cover span{font-family:var(--font-display);font-size:.85rem;color:var(--color-ink-light, #555);text-align:center}.my-story-info{flex:1;min-width:0}.my-story-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.my-story-top h3{font-family:var(--font-display);font-weight:400;font-size:1.2rem;color:var(--color-ink, #1a1a1a)}.my-story-count{white-space:nowrap;font-size:.9rem;color:var(--color-ink-light, #555)}.my-story-vis{display:inline-block;font-size:var(--text-xs);text-transform:lowercase;font-style:italic;color:var(--color-ink-faint, #999);border:1px solid var(--color-border, #d4cfc5);padding:1px 6px;margin-top:4px}.my-story-players{margin-top:14px}.my-story-players-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-ink-faint, #999)}.my-story-empty{color:var(--color-ink-faint, #999);font-style:italic;font-size:.85rem;margin-top:6px}.my-story-players ul{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.my-story-players li{display:flex;justify-content:space-between;font-size:.88rem;color:var(--color-ink, #1a1a1a);border-bottom:1px solid var(--color-border, #d4cfc5);padding-bottom:3px}.player-handle{font-style:italic}.player-time{color:var(--color-ink-faint, #999)}@media (max-width: 560px){.my-story{flex-direction:column}.my-story-cover{flex-basis:auto;width:100%}}.forum-crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-2);font-size:var(--text-xs)}.forum-crumb{background:none;border:none;color:var(--color-ink-light);cursor:pointer;font-family:var(--font-body);font-size:var(--text-xs);padding:0;text-decoration:underline}.forum-crumb:hover{color:var(--color-ink)}.forum-crumb.current{text-decoration:none;color:var(--color-ink);font-style:italic;cursor:default}.forum-crumb-sep{color:var(--color-ink-faint)}.forum-crumb-profile{margin-left:auto}.forum-status{color:var(--color-ink-light);font-style:italic;padding:var(--space-4) 0}.forum-error{color:var(--color-danger);font-size:.95rem}.forum-muted{color:var(--color-ink-faint);font-size:var(--text-xs)}.forum-link{background:none;border:none;padding:0;color:var(--color-ink);cursor:pointer;font-family:var(--font-body);font-size:inherit;text-decoration:underline}.forum-link:hover{color:var(--color-ink-light)}.forum-link-strong{font-weight:600;text-decoration:none}.forum-link-strong:hover{text-decoration:underline}.forum-h2{font-family:var(--font-display);font-weight:400;font-size:var(--text-h2);margin-bottom:var(--space-3)}.forum-h3{font-family:var(--font-display);font-weight:400;font-size:1.1rem;margin-bottom:var(--space-2)}.forum-btn{border:1px solid var(--color-ink);background:var(--color-ink);color:var(--color-cream);font-family:var(--font-body);font-size:.95rem;padding:8px 16px;cursor:pointer;transition:opacity var(--transition)}.forum-btn:hover:not(:disabled){opacity:.85}.forum-btn:disabled{opacity:.45;cursor:not-allowed}.forum-btn-ghost{background:transparent;color:var(--color-ink)}.forum-board{display:flex;flex-direction:column;gap:var(--space-4)}.forum-cat{border:1px solid var(--color-border);background:var(--color-panel);padding:var(--space-3) var(--space-4)}.forum-cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2);margin-bottom:var(--space-2)}.forum-cat-name{background:none;border:none;cursor:pointer;font-family:var(--font-display);font-size:1.2rem;color:var(--color-ink);padding:0}.forum-cat-name:hover{text-decoration:underline}.forum-cat-count{color:var(--color-ink-faint);font-size:var(--text-xs);white-space:nowrap}.forum-cat-desc{color:var(--color-ink-light);font-style:italic;margin-bottom:var(--space-2)}.forum-cat-latest{font-size:.95rem}.forum-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.forum-table{width:100%;border-collapse:collapse;border:1px solid var(--color-border);font-size:.95rem}.forum-table th{text-align:left;background:var(--color-ink);color:var(--color-cream);font-weight:400;font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;padding:6px 12px}.forum-table td{padding:10px 12px;border-top:1px solid var(--color-border);vertical-align:top}.forum-table tr.odd td{background:#00000006}.forum-col-num{text-align:center;width:5rem;white-space:nowrap}.forum-col-last{width:9rem;white-space:nowrap}.forum-row-sub{margin-top:2px}.forum-thread{display:flex;flex-direction:column;gap:var(--space-3)}.forum-post{display:grid;grid-template-columns:150px 1fr;border:1px solid var(--color-border);background:var(--color-panel)}.forum-post.op{border-color:var(--color-ink)}.forum-post-author{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-3);border-right:1px solid var(--color-border);background:#00000008;text-align:center}.forum-post-handle{font-size:var(--text-xs);word-break:break-word}.forum-op-tag{font-size:.7rem;letter-spacing:.08em;border:1px solid var(--color-ink-faint);color:var(--color-ink-light);padding:1px 6px}.forum-post-main{padding:var(--space-3) var(--space-4);min-width:0}.forum-post-time{margin-bottom:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px dotted var(--color-border)}.forum-post-body{white-space:pre-wrap;word-break:break-word;line-height:1.6}.forum-sig{margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px dotted var(--color-border);font-style:italic;font-size:var(--text-xs);color:var(--color-ink-light);white-space:pre-wrap}.forum-avatar-btn{background:none;border:none;padding:0;cursor:pointer}.forum-avatar{display:block;width:72px;height:72px;object-fit:cover;border:1px solid var(--color-border)}.forum-avatar-fallback{display:flex;align-items:center;justify-content:center;background:var(--color-ink);color:var(--color-cream);font-family:var(--font-display);font-size:1.8rem}.forum-avatar-lg{width:120px;height:120px}.forum-avatar-lg.forum-avatar-fallback{font-size:3rem}.forum-reply{margin-top:var(--space-4);border-top:1px solid var(--color-border);padding-top:var(--space-4)}.forum-form{display:flex;flex-direction:column;gap:var(--space-3)}.forum-label{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-ink-light)}.forum-form-actions{display:flex;gap:var(--space-3)}.forum-input,.forum-textarea{width:100%;border:1px solid var(--color-border);background:var(--color-cream);color:var(--color-ink);font-family:var(--font-body);font-size:1rem;padding:10px 12px;outline:none}.forum-input:focus,.forum-textarea:focus{border-color:var(--color-ink)}.forum-textarea{resize:vertical;margin-bottom:var(--space-2)}.forum-profile-card{display:grid;grid-template-columns:auto 1fr;gap:var(--space-5);border:1px solid var(--color-border);background:var(--color-panel);padding:var(--space-5)}.forum-profile-stats{display:flex;gap:var(--space-5);margin:var(--space-3) 0}.forum-profile-stats dt{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-ink-faint)}.forum-profile-stats dd{font-size:1.1rem}.forum-profile-bio{white-space:pre-wrap;margin:var(--space-3) 0}.forum-profile-sig{margin:var(--space-3) 0}.forum-editor-avatar{display:flex;align-items:center;gap:var(--space-4)}@media (max-width: 600px){.forum-post{grid-template-columns:84px 1fr}.forum-post-author{padding:var(--space-2)}.forum-avatar{width:56px;height:56px}.forum-profile-card{grid-template-columns:1fr;text-align:center}.forum-editor-avatar{flex-direction:column}.forum-col-last{display:none}}.dialog-box{position:fixed;bottom:0;left:0;right:0;background:var(--color-panel);color:var(--color-ink, #1a1a1a);padding:26px 28px;min-height:180px;max-height:46vh;overflow-y:auto;border-top:1px solid var(--color-border, #d4cfc5);z-index:20}.dialog-box.narrator .dialog-text{font-style:italic;color:var(--color-ink-light, #555)}.dialog-box.narrator .speaker-name{color:var(--color-ink-faint, #999)}.dialog-content{max-width:1200px;margin:0 auto}.dialog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;position:relative}.dialog-status{display:flex;gap:10px;align-items:center}.element-progress{display:flex;align-items:center;gap:8px}.progress-bar{width:80px;height:2px;background:var(--color-border, #d4cfc5);border-radius:1px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-ink, #1a1a1a);border-radius:1px;transition:width .4s ease}.speaker-name{font-size:1.4rem;font-weight:600;color:var(--color-ink, #1a1a1a);font-family:var(--font-display)}.dialog-text{font-size:clamp(1.25rem,1.05rem + .6vw,1.45rem);line-height:1.75;margin-bottom:20px;color:var(--color-ink, #1a1a1a);font-family:var(--font-display)}.waiting-ellipsis{color:var(--color-ink-faint, #999);font-style:italic;letter-spacing:.15em;animation:ellipsis-pulse 1.5s ease-in-out infinite}@keyframes ellipsis-pulse{0%,to{opacity:.2}50%{opacity:.7}}.typewriter-cursor{display:inline-block;width:2px;height:1.1em;background:var(--color-ink, #1a1a1a);margin-left:2px;vertical-align:text-bottom;animation:cursor-blink .7s step-end infinite}.click-to-continue{text-align:center;color:var(--color-ink-faint, #999);font-size:1rem;padding-top:4px;animation:pulse-continue 1.5s ease-in-out infinite;cursor:pointer;-webkit-user-select:none;user-select:none}@keyframes pulse-continue{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:.8;transform:translateY(3px)}}.choices-container{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.choice-button{background:transparent;color:var(--color-ink, #1a1a1a);border:1px solid var(--color-ink, #1a1a1a);padding:12px 22px;border-radius:0;cursor:pointer;font-size:1.1rem;font-family:var(--font-body);font-weight:400;transition:background .2s ease,color .2s ease;min-height:48px}.choice-button:hover{background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8)}.choice-button.custom-input{border-style:dashed}.choice-button.custom-input:hover{background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border-style:solid}.player-input-form{margin-top:15px}.input-container{display:flex;flex-direction:column;gap:10px}.input-container input{padding:8px 0;border:none;border-bottom:1px solid var(--color-border, #d4cfc5);border-radius:0;background:transparent;color:var(--color-ink, #1a1a1a);font-size:1rem;font-family:var(--font-body);outline:none;transition:border-color .2s ease}.input-container input::placeholder{color:var(--color-ink-faint, #999)}.input-container input:focus{border-bottom-color:var(--color-ink, #1a1a1a)}.input-actions{display:flex;gap:10px}.input-actions button{padding:8px 16px;border:1px solid var(--color-ink, #1a1a1a);border-radius:0;font-size:.9rem;font-family:var(--font-body);cursor:pointer;transition:background .2s ease,color .2s ease;min-height:44px;background:transparent;color:var(--color-ink, #1a1a1a)}.input-actions button[type=submit]:hover:not(:disabled){background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8)}.input-actions button[type=submit]:disabled{opacity:.25;cursor:not-allowed}.input-actions button[type=button]{border-color:var(--color-border, #d4cfc5);color:var(--color-ink-light, #555)}.input-actions button[type=button]:hover{border-color:var(--color-ink, #1a1a1a);color:var(--color-ink, #1a1a1a)}.dialog-loading{display:flex;align-items:center;gap:10px;margin-top:15px;color:var(--color-ink-faint, #999);font-size:.95rem;font-style:italic}.mini-spinner{width:2px;height:16px;background:var(--color-ink, #1a1a1a);animation:cursor-blink 1s step-end infinite}@media (max-width: 768px){.dialog-box{padding:16px;max-height:40vh}.choices-container{flex-direction:column}.choice-button{text-align:center;width:100%;min-height:48px;font-size:1rem}.input-actions{flex-direction:column}.input-actions button{min-height:48px}.dialog-header{flex-direction:column;align-items:flex-start;gap:5px}}.game-view{position:relative;width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column}.game-exit{position:fixed;top:16px;left:16px;z-index:var(--z-modal);background:var(--color-overlay, rgba(245, 240, 232, .92));color:var(--color-ink, #1a1a1a);border:1px solid var(--color-border, #d4cfc5);padding:7px 14px;font-family:var(--font-body);font-size:.95rem;letter-spacing:.04em;text-transform:lowercase;cursor:pointer;transition:border-color .2s ease,background .2s ease,color .2s ease}.game-exit:hover{border-color:var(--color-ink, #1a1a1a);background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8)}.game-background{flex:1;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:var(--color-cream, #f5f0e8);position:relative;display:flex;align-items:flex-end;justify-content:center;transition:opacity .6s ease}.game-background.scene-transitioning{animation:scene-crossfade .6s ease}@keyframes scene-crossfade{0%{opacity:1}40%{opacity:.3}to{opacity:1}}.characters-container{position:fixed;bottom:0;left:0;right:0;height:clamp(75vh,110vh - 22vw,94vh);display:flex;justify-content:center;align-items:flex-end;z-index:10;pointer-events:none}.character{width:clamp(280px,35vw,500px);height:clamp(75vh,110vh - 22vw,94vh);background-size:contain;background-position:bottom center;background-repeat:no-repeat;transition:transform .3s ease,opacity .3s ease,filter .3s ease}.character-center{margin-left:auto;margin-right:auto}.character.speaking{opacity:1;filter:brightness(1);transform:scale(1.05);animation:character-enter .4s ease}@keyframes character-enter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1.05) translateY(0)}}.status-overlay{position:fixed;inset:0;background:var(--color-overlay);display:flex;justify-content:center;align-items:center;z-index:var(--z-overlay)}.status-message{text-align:center;max-width:400px;padding:30px}.status-message p{margin:15px 0 0;font-size:1rem;color:var(--color-ink-light, #555);font-family:var(--font-display);font-style:italic}.loading-spinner{width:2px;height:24px;background:var(--color-ink, #1a1a1a);margin:0 auto;animation:cursor-blink 1s step-end infinite}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chapter-overlay{position:fixed;inset:0;background:var(--color-scrim);display:flex;justify-content:center;align-items:center;z-index:var(--z-overlay);animation:chapter-fade 3s ease forwards}@keyframes chapter-fade{0%{opacity:0}15%{opacity:1}75%{opacity:1}to{opacity:0}}.chapter-title-display{text-align:center;color:#f5f0e8;font-family:var(--font-display)}.chapter-title-display .chapter-number{font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;opacity:.6;margin:0 0 8px}.chapter-title-display h2{font-size:1.6rem;font-weight:400;letter-spacing:.06em;margin:0}.story-complete-overlay{position:fixed;inset:0;display:flex;justify-content:center;align-items:flex-start;padding-top:15vh;z-index:var(--z-overlay);pointer-events:none}.the-end{font-family:var(--font-display);font-size:2rem;font-weight:400;letter-spacing:.12em;color:var(--color-ink, #1a1a1a);text-transform:lowercase;animation:end-fade-in 2s ease forwards;opacity:0}@keyframes end-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.character{width:clamp(300px,96vw,460px)}.status-message{padding:20px;margin:20px}}.game-credits{position:fixed;top:16px;right:16px;z-index:var(--z-modal);background:var(--color-overlay, rgba(245, 240, 232, .92));color:var(--color-ink, #1a1a1a);border:1px solid var(--color-border, #d4cfc5);padding:7px 14px;font-family:var(--font-body);font-size:.95rem;letter-spacing:.04em}.paywall-message{background:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);padding:32px}.paywall-actions{display:flex;gap:12px;justify-content:center;margin-top:22px}.paywall-btn{padding:10px 20px;background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);font-family:var(--font-body);font-size:.95rem;letter-spacing:.04em;text-transform:lowercase;cursor:pointer;transition:opacity .2s ease}.paywall-btn:hover{opacity:.85}.paywall-btn--ghost{background:transparent;color:var(--color-ink, #1a1a1a);border-color:var(--color-border, #d4cfc5)}.paywall-btn--ghost:hover{border-color:var(--color-ink, #1a1a1a);opacity:1}.auth-modal-overlay{position:fixed;inset:0;background:var(--color-overlay, rgba(245, 240, 232, .92));display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4)}.auth-modal{position:relative;width:100%;max-width:380px;background:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);padding:40px 32px 32px}.auth-close{position:absolute;top:12px;right:16px;background:transparent;border:none;color:var(--color-ink-faint, #999);font-size:1.6rem;line-height:1;cursor:pointer;transition:color .2s ease}.auth-close:hover{color:var(--color-ink, #1a1a1a)}.auth-modal h2{font-family:var(--font-display);font-weight:400;font-size:1.5rem;letter-spacing:.08em;text-transform:lowercase;color:var(--color-ink, #1a1a1a);margin-bottom:4px}.auth-sub{color:var(--color-ink-faint, #999);font-style:italic;font-size:.85rem;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-input-group{display:flex;flex-direction:column;gap:6px}.auth-input-group label{color:var(--color-ink-light, #555);font-size:.9rem;font-style:italic;text-transform:lowercase}.auth-input-group input{padding:8px 0;border:none;border-bottom:1px solid var(--color-border, #d4cfc5);border-radius:0;font-size:1.1rem;font-family:var(--font-body);background:transparent;color:var(--color-ink, #1a1a1a);outline:none;transition:border-color .2s ease}.auth-input-group input::placeholder{color:var(--color-ink-faint, #999)}.auth-input-group input:focus{border-bottom-color:var(--color-ink, #1a1a1a)}.auth-btn{padding:12px 0;background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);border-radius:0;font-size:1rem;font-family:var(--font-body);letter-spacing:.06em;cursor:pointer;text-transform:lowercase;transition:opacity .2s ease}.auth-btn:hover:not(:disabled){opacity:.85}.auth-btn:disabled{opacity:.35;cursor:not-allowed}.auth-hint{font-size:.85rem;color:var(--color-ink-light, #555);font-style:italic}.auth-link{background:transparent;border:none;color:var(--color-ink-faint, #999);font-family:var(--font-body);font-size:.85rem;cursor:pointer;text-align:left;padding:0;text-transform:lowercase;transition:color .2s ease}.auth-link:hover{color:var(--color-ink, #1a1a1a)}.auth-error{margin-top:14px;color:var(--color-danger);font-size:.85rem;font-style:italic}.auth-divider{display:flex;align-items:center;gap:12px;margin:24px 0;color:var(--color-ink-faint, #999);font-size:.8rem;font-style:italic}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border, #d4cfc5)}.auth-google{width:100%;padding:12px 0;background:transparent;color:var(--color-ink, #1a1a1a);border:1px solid var(--color-border, #d4cfc5);border-radius:0;font-size:.95rem;font-family:var(--font-body);letter-spacing:.04em;cursor:pointer;transition:border-color .2s ease,background .2s ease,color .2s ease}.auth-google:hover:not(:disabled){border-color:var(--color-ink, #1a1a1a);background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8)}.auth-google:disabled{opacity:.35;cursor:not-allowed}.buy-modal-overlay{position:fixed;inset:0;background:var(--color-overlay, rgba(245, 240, 232, .92));display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 1000);padding:var(--space-4, 16px)}.buy-modal{position:relative;width:100%;max-width:380px;background:var(--color-cream, #f5f0e8);border:1px solid var(--color-ink, #1a1a1a);padding:40px 32px 32px}.buy-close{position:absolute;top:12px;right:16px;background:transparent;border:none;color:var(--color-ink-faint, #999);font-size:1.6rem;line-height:1;cursor:pointer;transition:color .2s ease}.buy-close:hover{color:var(--color-ink, #1a1a1a)}.buy-modal h2{font-family:var(--font-display);font-weight:400;font-size:1.5rem;letter-spacing:.08em;text-transform:lowercase;color:var(--color-ink, #1a1a1a);margin-bottom:4px}.buy-sub{color:var(--color-ink-faint, #999);font-style:italic;font-size:.85rem;margin-bottom:28px}.buy-status{color:var(--color-ink-light, #555);font-style:italic;font-size:.9rem}.buy-packs{display:flex;flex-direction:column;gap:12px}.buy-pack{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:transparent;border:1px solid var(--color-border, #d4cfc5);border-radius:0;cursor:pointer;font-family:var(--font-body);color:var(--color-ink, #1a1a1a);transition:border-color .2s ease,background .2s ease}.buy-pack:hover:not(:disabled){border-color:var(--color-ink, #1a1a1a);background:#1a1a1a0a}.buy-pack:disabled{opacity:.45;cursor:not-allowed}.buy-pack-credits{font-size:1.05rem;letter-spacing:.02em}.buy-pack-price{font-family:var(--font-display);font-size:1.15rem}.buy-error{margin-top:14px;color:var(--color-danger, #b00020);font-size:.85rem;font-style:italic}.theme-toggle{position:fixed;top:14px;right:14px;z-index:var(--z-toggle);width:28px;height:28px;border:none;background:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;opacity:.4;transition:opacity .2s ease}.theme-toggle:hover{opacity:.8}.theme-icon{display:block;width:14px;height:14px;border-radius:50%;border:2px solid var(--color-ink);transition:background .3s ease,border-color .3s ease}.theme-icon--light{background:linear-gradient(to right,var(--color-ink) 50%,transparent 50%)}.theme-icon--dark{background:var(--color-ink)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-4);border-radius:var(--radius);font-family:var(--font-body);font-size:1rem;font-weight:400;letter-spacing:.04em;text-transform:lowercase;cursor:pointer;border:1px solid transparent;transition:background var(--transition),color var(--transition),border-color var(--transition),opacity var(--transition)}.btn--primary{background:var(--color-ink);color:var(--color-cream);border-color:var(--color-ink)}.btn--primary:hover:not(:disabled){opacity:.85}.btn--secondary{background:transparent;color:var(--color-ink);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){border-color:var(--color-ink)}.btn--ghost{background:transparent;color:var(--color-ink-faint);border-color:transparent}.btn--ghost:hover:not(:disabled){color:var(--color-ink)}.btn:disabled{opacity:.35;cursor:not-allowed}.input{padding:var(--space-2) 0;border:none;border-bottom:1px solid var(--color-border);border-radius:var(--radius);background:transparent;color:var(--color-ink);font-family:var(--font-body);font-size:1rem;outline:none;transition:border-color var(--transition)}.input::placeholder{color:var(--color-ink-faint)}.input:focus{border-bottom-color:var(--color-ink)}.card{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color var(--transition),transform .15s ease}.card:hover{border-color:var(--color-ink);transform:translateY(-2px)}.cover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-5)}:focus-visible{outline:2px solid var(--color-ink);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.app{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.app--shell{height:100vh;overflow-y:auto;overflow-x:hidden;background:var(--color-cream, #f5f0e8)}.app-header{position:sticky;top:0;z-index:var(--z-header);display:flex;align-items:center;gap:var(--space-5);padding:var(--space-4) var(--space-6);background:var(--color-cream, #f5f0e8);border-bottom:1px solid var(--color-border, #d4cfc5)}.brand{background:transparent;border:none;cursor:pointer;font-family:var(--font-display);font-size:1.25rem;font-weight:400;letter-spacing:.08em;text-transform:lowercase;color:var(--color-ink, #1a1a1a)}.app-nav{display:flex;gap:4px;flex:1}.nav-link-signout,.nav-toggle{display:none}.nav-link{background:transparent;border:none;cursor:pointer;font-family:var(--font-body);font-size:.95rem;letter-spacing:.04em;text-transform:lowercase;color:var(--color-ink-faint, #999);padding:6px 10px;border-bottom:1px solid transparent;transition:color .2s ease,border-color .2s ease}.nav-link:hover{color:var(--color-ink, #1a1a1a)}.nav-link.active{color:var(--color-ink, #1a1a1a);border-bottom-color:var(--color-ink, #1a1a1a)}.app-account{display:flex;align-items:center;gap:14px}.account-chip{display:flex;align-items:center;gap:12px}.account-handle{font-size:.85rem;font-style:italic;color:var(--color-ink-light, #555)}.account-handle-btn{background:transparent;border:none;cursor:pointer;font-family:var(--font-body);text-transform:lowercase;transition:color .2s ease}.account-handle-btn:hover{color:var(--color-ink, #1a1a1a);text-decoration:underline}.account-btn{background:transparent;border:1px solid var(--color-border, #d4cfc5);cursor:pointer;font-family:var(--font-body);font-size:.85rem;letter-spacing:.04em;text-transform:lowercase;color:var(--color-ink, #1a1a1a);padding:6px 14px;transition:border-color .2s ease,background .2s ease,color .2s ease}.account-btn:hover{border-color:var(--color-ink, #1a1a1a);background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8)}.app-main{min-height:calc(100vh - 65px)}.app-account .theme-toggle{position:static}@media (max-width: 768px){.app-header{flex-wrap:wrap;gap:var(--space-3)}.brand{margin-right:auto}.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:4px;width:34px;height:34px;padding:7px;order:2;background:transparent;border:none;cursor:pointer}.nav-toggle span{display:block;width:100%;height:2px;background:var(--color-ink, #1a1a1a);transition:transform .2s ease,opacity .2s ease}.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.app-account{order:1}.app-nav{display:none;flex:0 0 100%;order:99}.app-nav.open{display:flex;flex-direction:column;gap:0;padding-top:var(--space-2)}.app-nav.open .nav-link{padding:12px 4px;font-size:1rem;border-bottom:1px solid var(--color-border, #d4cfc5)}.app-nav.open .nav-link.active{border-bottom-color:var(--color-ink, #1a1a1a)}.app-nav.open .nav-link-signout{display:block;color:var(--color-ink, #1a1a1a)}.account-btn-signout{display:none}}@media (max-width: 640px){.app-header{padding:var(--space-3) var(--space-4);gap:var(--space-3)}.account-handle{display:none}}.account-credits{background:transparent;border:1px solid var(--color-border, #d4cfc5);cursor:pointer;font-family:var(--font-body);font-size:.85rem;letter-spacing:.04em;color:var(--color-ink, #1a1a1a);padding:6px 12px;transition:border-color .2s ease,background .2s ease,color .2s ease}.account-credits:hover{border-color:var(--color-ink, #1a1a1a);background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8)}.app-notice{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:var(--z-modal, 1000);background:var(--color-ink, #1a1a1a);color:var(--color-cream, #f5f0e8);padding:10px 20px;font-family:var(--font-body);font-size:.9rem;letter-spacing:.03em;border-radius:2px}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-bg, #111);color:var(--color-text, #eee)}.error-boundary__card{max-width:28rem;text-align:center;background:var(--color-surface, #1d1d1d);border:1px solid var(--color-border, #333);border-radius:12px;padding:2rem}.error-boundary__actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.25rem}.error-boundary__actions button{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--color-border, #444);background:var(--color-accent, #5b8def);color:#fff;cursor:pointer}.error-boundary__actions button:last-child{background:transparent;color:inherit}
