@import"https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;1,400&family=Courier+Prime:ital,wght@0,400;0,700;1,400&display=swap";:root{--paper-cream: #F9F7F4;--paper-beige: #F5F1E8;--charcoal: #2C2C2C;--ink-blue: #4A5568;--sepia: #8B7355;--shadow: rgba(0, 0, 0, .1);--shadow-medium: rgba(0, 0, 0, .15);--font-serif: "Crimson Text", Georgia, serif;--font-mono: "Courier Prime", "Courier New", monospace;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-serif);background-color:var(--paper-cream);color:var(--charcoal);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.01) 2px,rgba(0,0,0,.01) 4px);pointer-events:none;z-index:-1}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:600;line-height:1.2;margin-bottom:var(--spacing-sm)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}p{margin-bottom:var(--spacing-sm)}a{color:var(--ink-blue);text-decoration:none;transition:color .2s ease}a:hover{color:var(--sepia);text-decoration:underline}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-family:var(--font-serif);font-size:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px var(--shadow)}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow-medium)}.btn:active{transform:translateY(0);box-shadow:0 1px 2px var(--shadow)}.btn-primary{background-color:var(--ink-blue);color:#fff}.btn-primary:hover{background-color:#3a4558}.btn-secondary{background-color:var(--paper-beige);color:var(--charcoal);border:1px solid var(--sepia)}.btn-secondary:hover{background-color:var(--paper-cream)}.input{width:100%;padding:.75rem;border:1px solid var(--sepia);border-radius:4px;font-family:var(--font-serif);font-size:1rem;background-color:#fff;color:var(--charcoal);transition:border-color .2s ease,box-shadow .2s ease}.input:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 3px #4a55681a}.input::placeholder{color:#999;font-style:italic}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;color:var(--charcoal)}.form-error{color:#c53030;font-size:.875rem;margin-top:var(--spacing-xs);font-style:italic}.paper-card{background-color:#fff;padding:var(--spacing-lg);border-radius:8px;box-shadow:0 2px 4px var(--shadow),0 8px 16px #0000000d;position:relative}.paper-card:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(139,115,85,.02) 2px,rgba(139,115,85,.02) 4px);pointer-events:none;border-radius:8px}.container{max-width:1200px;margin:0 auto;padding:var(--spacing-lg)}.spinner{border:3px solid var(--paper-beige);border-top-color:var(--ink-blue);border-radius:50%;width:40px;height:40px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dismiss-btn{background:none;border:none;color:inherit;font-size:1.25rem;line-height:1;cursor:pointer;padding:0 0 0 var(--spacing-sm);margin-left:auto;opacity:.7;flex-shrink:0}.dismiss-btn:hover{opacity:1}.error-message,.auth-error,.editor-error-banner{display:flex;align-items:center}.text-center{text-align:center}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}@media(max-width:600px){html{overflow-x:hidden}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.container{padding:var(--spacing-sm)}.paper-card{padding:var(--spacing-md)}.btn{padding:.625rem 1.25rem;font-size:.9rem}}.landing-page{min-height:100vh}.landing-nav{position:absolute;top:0;left:0;right:0;z-index:10;padding:var(--spacing-md) 0}.nav-content{display:flex;justify-content:space-between;align-items:center}.landing-hero{min-height:90vh;display:flex;align-items:center;padding:calc(var(--spacing-xl) * 2) 0 var(--spacing-xl)}.hero-content{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--spacing-xl);align-items:center;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.hero-copy h1{font-size:3.25rem;line-height:1.1;margin-bottom:var(--spacing-md);color:var(--charcoal);letter-spacing:-.02em}.hero-subtitle{font-size:1.2rem;color:var(--sepia);line-height:1.7;margin-bottom:var(--spacing-lg);max-width:520px}.hero-value-pills{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.value-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background-color:#fff;border:1px solid var(--paper-beige);border-radius:24px;font-size:.9rem;color:var(--ink-blue);font-weight:600;box-shadow:0 1px 3px var(--shadow)}.value-pill svg{flex-shrink:0;opacity:.7}.hero-auth-card{width:100%;max-width:420px;justify-self:end}.auth-tabs{display:flex;border-bottom:2px solid var(--paper-beige);margin-bottom:var(--spacing-lg)}.auth-tab{flex:1;padding:var(--spacing-sm) var(--spacing-xs);border:none;background:none;font-family:var(--font-serif);font-size:1.05rem;cursor:pointer;color:var(--sepia);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s ease}.auth-tab:hover{color:var(--charcoal)}.auth-tab.active{color:var(--ink-blue);border-bottom-color:var(--ink-blue);font-weight:600}.landing-how-it-works{padding:calc(var(--spacing-xl) * 1.5) 0;background-color:var(--paper-beige)}.steps-grid{display:flex;align-items:flex-start;justify-content:center;gap:0;max-width:900px;margin:0 auto}.step-card{flex:1;text-align:center;padding:0 var(--spacing-md)}.step-number{width:48px;height:48px;margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center;background-color:var(--ink-blue);color:#fff;font-family:var(--font-serif);font-size:1.25rem;font-weight:700;border-radius:50%}.step-card h3{color:var(--charcoal);font-size:1.15rem;margin-bottom:var(--spacing-xs)}.step-card p{color:var(--sepia);font-size:.95rem;line-height:1.6;font-style:italic}.step-connector{width:60px;height:2px;background-color:var(--sepia);opacity:.3;flex-shrink:0;margin-top:24px}.landing-features{padding:calc(var(--spacing-xl) * 1.5) 0}.section-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.section-title{text-align:center;font-size:2rem;margin-bottom:var(--spacing-xs);color:var(--charcoal)}.section-subtitle{text-align:center;color:var(--sepia);font-style:italic;font-size:1.1rem;margin-bottom:var(--spacing-xl)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.feature-card{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 4px 8px var(--shadow),0 12px 24px #00000014}.feature-icon{width:56px;height:56px;margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center;background-color:var(--paper-beige);border-radius:50%}.feature-card h3{color:var(--ink-blue);font-size:1.2rem;margin-bottom:var(--spacing-sm)}.feature-card p{color:var(--sepia);font-style:italic;line-height:1.6;font-size:.95rem}.landing-games{padding:calc(var(--spacing-xl) * 1.5) 0;background-color:var(--paper-beige)}.game-categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-lg)}.game-category-card{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg);transition:transform .2s ease,box-shadow .2s ease}.game-category-card:hover{transform:translateY(-3px);box-shadow:0 4px 8px var(--shadow),0 12px 24px #00000014}.game-category-card .category-badge{align-self:flex-start;font-size:.8rem;font-weight:600;padding:.3rem .8rem;border-radius:12px;text-transform:uppercase;letter-spacing:.05em}.category-badge.turn-based{background-color:#e8f4fd;color:#2b6cb0}.category-badge.constraint{background-color:#f0fff4;color:#276749}.category-badge.timed{background-color:#fff5f5;color:#c53030}.category-badge.collaborative{background-color:#faf5ff;color:#6b46c1}.category-desc{color:var(--charcoal);font-size:.95rem;line-height:1.6;flex:1;margin:0}.category-count{font-size:.8rem;color:var(--sepia);font-style:italic}.landing-cta{padding:calc(var(--spacing-xl) * 2) 0;text-align:center}.cta-quote{font-size:1.75rem;font-style:italic;color:var(--charcoal);max-width:600px;margin:0 auto var(--spacing-sm);line-height:1.4;border:none;padding:0}.cta-attribution{color:var(--sepia);font-size:.9rem;font-style:italic;margin-bottom:var(--spacing-lg)}.cta-subtitle{color:var(--sepia);font-size:1.05rem;margin-bottom:var(--spacing-lg)}.landing-cta .btn{font-size:1.1rem;padding:1rem 2.5rem}.landing-footer{padding:var(--spacing-lg) 0;text-align:center;color:var(--sepia);font-size:.85rem;border-top:1px solid var(--paper-beige)}@media(max-width:768px){.landing-hero{min-height:auto;padding:calc(var(--spacing-xl) * 2) 0 var(--spacing-lg)}.hero-content{grid-template-columns:1fr;text-align:center;gap:var(--spacing-lg)}.hero-copy h1{font-size:2.25rem}.hero-subtitle{max-width:none}.hero-value-pills{justify-content:center}.hero-auth-card{justify-self:center}.steps-grid{flex-direction:column;align-items:center;gap:var(--spacing-md)}.step-connector{width:2px;height:32px;margin:0}.step-card{max-width:320px}.cta-quote{font-size:1.4rem}}@media(max-width:600px){.landing-nav{padding:var(--spacing-sm) 0}.hero-content{padding:0 var(--spacing-sm)}.hero-copy h1{font-size:1.75rem}.hero-subtitle{font-size:1rem}.hero-value-pills{gap:var(--spacing-xs)}.value-pill{font-size:.8rem;padding:.4rem .75rem}.hero-auth-card{max-width:100%}.section-container{padding:0 var(--spacing-sm)}.section-title{font-size:1.5rem}.section-subtitle{font-size:.95rem}.landing-how-it-works,.landing-features{padding:var(--spacing-xl) 0}.features-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.feature-card{padding:var(--spacing-lg) var(--spacing-md)}.landing-games{padding:var(--spacing-xl) 0}.game-categories-grid{grid-template-columns:1fr}.landing-cta{padding:var(--spacing-xl) 0}.cta-quote{font-size:1.2rem}.landing-cta .btn{font-size:1rem;padding:.75rem 2rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.auth-card{width:100%;max-width:450px}.auth-title{text-align:center;font-size:2rem;margin-bottom:var(--spacing-xs);color:var(--charcoal)}.auth-subtitle{text-align:center;color:var(--sepia);font-style:italic;margin-bottom:var(--spacing-lg)}.auth-error{background-color:#fed7d7;color:#c53030;padding:var(--spacing-sm);border-radius:4px;margin-bottom:var(--spacing-md);border-left:4px solid #c53030}.auth-form{margin-top:var(--spacing-lg)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.btn-full{width:100%;margin-top:var(--spacing-md)}.auth-footer{text-align:center;margin-top:var(--spacing-lg);color:var(--sepia)}.input-hint{display:block;margin-top:var(--spacing-xs);font-size:.875rem;color:var(--sepia);font-style:italic}.password-strength{margin-top:var(--spacing-xs);font-size:.875rem;padding:.25rem .5rem;border-radius:4px;display:inline-block}.password-strength.weak{background-color:#fed7d7;color:#c53030}.password-strength.medium{background-color:#feebc8;color:#c05621}.password-strength.strong{background-color:#c6f6d5;color:#22543d}@media(max-width:600px){.auth-container{padding:var(--spacing-sm)}.auth-title{font-size:1.5rem}}.dashboard{min-height:100vh}.dashboard-header{background-color:#fff;border-bottom:1px solid var(--sepia);box-shadow:0 2px 4px var(--shadow);position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.header-content h1{font-size:1.75rem;margin:0}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.user-greeting{color:var(--sepia);font-style:italic}.dashboard-main{padding-top:var(--spacing-xl)}.dashboard-intro{text-align:center;margin-bottom:var(--spacing-xl)}.dashboard-intro h2{font-size:2rem;margin-bottom:var(--spacing-xs)}.subtitle{color:var(--sepia);font-style:italic;font-size:1.125rem}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.action-card{text-align:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:2px solid transparent;text-decoration:none;color:var(--charcoal);display:block;background:none;width:100%}.action-card:hover{transform:translateY(-4px);box-shadow:0 4px 8px var(--shadow),0 12px 24px #00000014;border-color:var(--ink-blue);text-decoration:none}.action-card h3{margin-bottom:var(--spacing-xs);color:var(--ink-blue)}.action-card p{margin:0;color:var(--sepia);font-style:italic}.poems-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--paper-beige)}.poems-section h2{margin-bottom:var(--spacing-lg)}.poems-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.poem-card{display:block;text-decoration:none;color:var(--charcoal);transition:transform .2s ease,box-shadow .2s ease;height:200px;display:flex;flex-direction:column}.poem-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow),0 12px 24px #00000014;text-decoration:none}.poem-title{font-size:1.25rem;margin-bottom:var(--spacing-sm);color:var(--ink-blue)}.poem-preview{flex:1;font-family:var(--font-mono);font-size:.875rem;line-height:1.6;color:var(--charcoal);margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.poem-meta{margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--paper-beige);display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--sepia)}.poem-date{font-style:italic}.poem-collab{background-color:var(--paper-beige);padding:.25rem .5rem;border-radius:4px;font-size:.75rem}.poem-owner{font-style:italic}.loading-container{display:flex;justify-content:center;padding:var(--spacing-xl)}.error-message{background-color:#fed7d7;color:#c53030;padding:var(--spacing-sm);border-radius:4px;margin-bottom:var(--spacing-md);border-left:4px solid #c53030}@media(max-width:600px){.header-content{flex-wrap:wrap;gap:var(--spacing-xs)}.header-content h1{font-size:1.35rem}.header-actions{gap:var(--spacing-sm)}.user-greeting{display:none}.dashboard-main{padding-top:var(--spacing-lg)}.dashboard-intro h2{font-size:1.5rem}.action-cards{grid-template-columns:1fr;gap:var(--spacing-md)}.poems-grid{grid-template-columns:1fr}.poem-card{height:auto;min-height:160px}}.collaborative-editor{width:100%}.collaboration-toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm);background-color:var(--paper-beige);border-radius:4px 4px 0 0;border-bottom:1px solid var(--sepia)}.connection-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;color:var(--charcoal)}.status-icon{font-size:.75rem}.active-collaborators{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem}.active-collaborators>span:first-child{color:var(--sepia);font-style:italic}.collaborator-badge{padding:.25rem .75rem;border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;box-shadow:0 1px 3px #0003}.collab-codemirror{border:1px solid var(--sepia);border-radius:0 0 4px 4px;overflow:hidden}.cm-editor{background-color:#fff!important;color:var(--charcoal)!important}.cm-gutters{background-color:var(--paper-beige)!important;border-right:1px solid var(--sepia)!important}.cm-activeLineGutter{background-color:#8b73551a!important}.cm-cursor{border-left-color:var(--ink-blue)!important;border-left-width:2px!important}.cm-selectionBackground{background-color:#4a556833!important}.cm-ySelection{opacity:.3}.cm-ySelectionInfo{position:absolute;top:-1.5em;left:0;font-size:.75em;font-family:var(--font-serif);padding:2px 6px;border-radius:3px;color:#fff;opacity:1;transition:opacity .3s ease-in-out}@media(max-width:600px){.collaboration-toolbar{flex-wrap:wrap;gap:var(--spacing-xs);padding:var(--spacing-xs)}.connection-status,.active-collaborators{font-size:.8rem}.collaborator-badge{padding:.15rem .5rem;font-size:.7rem}}.editor-container{min-height:100vh;display:flex;flex-direction:column}.editor-header{background-color:#fff;border-bottom:1px solid var(--sepia);box-shadow:0 2px 4px var(--shadow);padding:var(--spacing-sm) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.editor-header-left,.editor-header-right{display:flex;gap:var(--spacing-sm)}.editor-header-center{flex:1;text-align:center}.save-status{color:var(--sepia);font-style:italic;font-size:.875rem;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.saving-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--paper-beige);border-top-color:var(--ink-blue);border-radius:50%;animation:spin .6s linear infinite}.editor-main{flex:1;padding:var(--spacing-xl);max-width:900px;width:100%;margin:0 auto}.editor-paper{min-height:calc(100vh - 200px);padding:var(--spacing-xl)}.editor-title{width:100%;border:none;font-family:var(--font-serif);font-size:2rem;font-weight:600;color:var(--charcoal);background:transparent;margin-bottom:var(--spacing-lg);padding:var(--spacing-sm);border-bottom:2px solid transparent;transition:border-color .2s ease}.editor-title:focus{outline:none;border-bottom-color:var(--ink-blue)}.editor-title::placeholder{color:#aaa;font-style:italic}.editor-content{width:100%;min-height:500px;border:none;font-family:var(--font-mono);font-size:1.125rem;line-height:1.8;color:var(--charcoal);background:transparent;resize:vertical;padding:var(--spacing-sm)}.editor-content:focus{outline:none}.editor-content::placeholder{color:#aaa;font-style:italic;font-family:var(--font-serif)}.editor-loading,.editor-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg)}.editor-error-banner{background-color:#fed7d7;color:#c53030;padding:var(--spacing-sm) var(--spacing-lg);text-align:center;border-bottom:2px solid #c53030}.prompt-epigraph{margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);border-left:3px solid var(--sepia);background-color:var(--paper-beige);border-radius:0 4px 4px 0}.prompt-label{display:inline-block;font-family:var(--font-serif);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--sepia);margin-bottom:var(--spacing-xs)}.prompt-body{font-family:var(--font-serif);font-size:1.1rem;font-style:italic;color:var(--charcoal);line-height:1.6;margin:0}.editor-paper.lined{background-image:repeating-linear-gradient(transparent,transparent 31px,var(--sepia) 31px,var(--sepia) 32px);background-size:100% 32px;line-height:32px}.invite-modal{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.invite-modal-content{max-width:500px;width:90%}.invite-modal-content h3{margin-bottom:var(--spacing-md)}.modal-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.editor-layout{display:grid;gap:var(--spacing-lg);transition:grid-template-columns .3s ease}.editor-layout.with-image{grid-template-columns:400px 1fr}.inspiration-image{position:sticky;top:80px;height:fit-content;max-height:calc(100vh - 120px);border-radius:8px;overflow:hidden;box-shadow:0 4px 12px var(--shadow-medium);position:relative}.inspiration-image img{width:100%;height:auto;max-height:calc(100vh - 120px);object-fit:cover;display:block}.hide-image-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;border-radius:50%;border:none;background-color:#ffffffe6;color:var(--charcoal);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px var(--shadow)}.hide-image-btn:hover{background-color:#fff;transform:scale(1.1)}.clickable-image{cursor:pointer;transition:opacity .2s ease}.clickable-image:hover{opacity:.85}.show-image-btn{margin-bottom:var(--spacing-md)}.image-lightbox{position:fixed;inset:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;cursor:pointer}.image-lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;box-shadow:0 0 40px #00000080}.lightbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;border:none;background-color:#fff3;color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.lightbox-close:hover{background-color:#fff6}@media(max-width:1024px){.editor-layout.with-image{grid-template-columns:1fr}.inspiration-image{position:relative;top:0;max-height:400px}.inspiration-image img{max-height:400px}}@media(max-width:600px){.editor-header{padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-xs)}.editor-header-left,.editor-header-right{gap:var(--spacing-xs)}.editor-header-left .btn,.editor-header-right .btn{padding:.5rem .75rem;font-size:.85rem}.save-status{font-size:.75rem}.editor-main{padding:var(--spacing-sm)}.editor-paper{padding:var(--spacing-sm);min-height:calc(100vh - 150px)}.editor-title{font-size:1.5rem;margin-bottom:var(--spacing-md)}.editor-content{font-size:1rem;min-height:300px}.prompt-epigraph{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md)}.prompt-body{font-size:1rem}.invite-modal-content{width:95%}.inspiration-image,.inspiration-image img{max-height:250px}}.prompts-page{min-height:100vh}.prompts-header{background-color:#fff;border-bottom:1px solid var(--sepia);box-shadow:0 2px 4px var(--shadow);position:sticky;top:0;z-index:100}.prompts-main{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.prompts-intro{text-align:center;margin-bottom:var(--spacing-xl)}.prompts-intro h2{font-size:2rem;margin-bottom:var(--spacing-xs)}.prompts-controls{margin-bottom:var(--spacing-xl)}.controls-group{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--spacing-md);align-items:end}.prompts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.prompt-card{display:flex;flex-direction:column;gap:var(--spacing-sm)}.prompt-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.prompt-difficulty{padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.prompt-difficulty.easy{background-color:#c6f6d5;color:#22543d}.prompt-difficulty.medium{background-color:#feebc8;color:#c05621}.prompt-difficulty.hard{background-color:#fed7d7;color:#c53030}.prompt-category{padding:.25rem .75rem;background-color:var(--paper-beige);border-radius:4px;font-size:.75rem;color:var(--sepia);text-transform:capitalize}.prompt-text{font-family:var(--font-serif);font-size:1.125rem;line-height:1.6;color:var(--charcoal);font-style:italic;flex:1;margin:var(--spacing-sm) 0}.prompt-author{font-size:.875rem;color:var(--sepia);font-style:italic;text-align:right;margin:0}@media(max-width:768px){.controls-group,.prompts-grid{grid-template-columns:1fr}}.images-page{min-height:100vh}.images-header{background-color:#fff;border-bottom:1px solid var(--sepia);box-shadow:0 2px 4px var(--shadow);position:sticky;top:0;z-index:100}.images-main{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.images-intro{text-align:center;margin-bottom:var(--spacing-xl)}.images-intro h2{font-size:2rem;margin-bottom:var(--spacing-xs)}.images-controls{margin-bottom:var(--spacing-xl)}.controls-group{display:grid;grid-template-columns:1fr auto;gap:var(--spacing-md);align-items:end}.random-btn{white-space:nowrap}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.image-card{display:flex;flex-direction:column;overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.image-card:hover{transform:translateY(-4px);box-shadow:0 6px 12px var(--shadow),0 16px 32px #0000001a}.image-preview{width:100%;height:200px;overflow:hidden;background-color:var(--paper-beige)}.image-preview img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.image-card:hover .image-preview img{transform:scale(1.05)}.image-info{padding:var(--spacing-md);flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.image-title{font-size:1.125rem;margin:0;color:var(--ink-blue)}.image-description{font-size:.875rem;color:var(--sepia);font-style:italic;margin:0;line-height:1.4}.image-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--spacing-xs);border-top:1px solid var(--paper-beige);font-size:.75rem}.image-category{padding:.25rem .75rem;background-color:var(--paper-beige);border-radius:4px;text-transform:capitalize;color:var(--charcoal)}.image-photographer{color:var(--sepia);font-style:italic}.image-modal{position:fixed;inset:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.image-modal-content{position:relative;max-width:1200px;width:100%;max-height:90vh;display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-lg);overflow:hidden}.modal-close{position:absolute;top:-40px;right:0;background:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;transition:transform .2s ease}.modal-close:hover{transform:scale(1.1)}.modal-image-container{background-color:var(--charcoal);display:flex;align-items:center;justify-content:center;border-radius:8px;overflow:hidden}.modal-image-container img{max-width:100%;max-height:80vh;object-fit:contain}.modal-info{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);overflow-y:auto}.modal-info h2{margin:0;color:var(--charcoal)}.modal-description{color:var(--sepia);font-style:italic;line-height:1.6}.modal-photographer{font-size:.875rem;color:var(--sepia);margin-top:auto}@media(max-width:768px){.controls-group,.images-grid{grid-template-columns:1fr}.image-modal-content{grid-template-columns:1fr;grid-template-rows:auto 1fr}.modal-close{top:var(--spacing-sm);right:var(--spacing-sm)}}.games-page{min-height:100vh}.games-header{background-color:#fff;border-bottom:1px solid var(--sepia);box-shadow:0 2px 4px var(--shadow);position:sticky;top:0;z-index:100}.games-header .header-content{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.games-header .header-content h1{font-size:1.75rem;margin:0}.games-main{padding-top:var(--spacing-xl)}.games-intro{text-align:center;margin-bottom:var(--spacing-xl)}.games-intro h2{font-size:2rem;margin-bottom:var(--spacing-xs)}.games-intro .subtitle{color:var(--sepia);font-style:italic;font-size:1.125rem}.category-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap;justify-content:center}.category-tab{padding:.5rem 1.25rem;border:2px solid var(--sepia);border-radius:20px;background:none;cursor:pointer;font-family:inherit;font-size:.9rem;color:var(--charcoal);transition:all .2s ease}.category-tab:hover{border-color:var(--ink-blue);color:var(--ink-blue)}.category-tab.active{background-color:var(--ink-blue);border-color:var(--ink-blue);color:#fff}.game-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.game-type-card{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:2px solid transparent;text-align:left;background:none;width:100%;color:var(--charcoal);font-family:inherit}.game-type-card:hover{transform:translateY(-4px);box-shadow:0 4px 8px var(--shadow),0 12px 24px #00000014;border-color:var(--ink-blue)}.game-type-card h3{margin-bottom:var(--spacing-xs);color:var(--ink-blue);font-size:1.1rem}.game-type-card p{margin:0 0 var(--spacing-sm);color:var(--sepia);font-style:italic;font-size:.9rem}.game-type-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.game-type-badge.turn-based{background-color:#e8f4fd;color:#2b6cb0}.game-type-badge.constraint{background-color:#f0fff4;color:#276749}.game-type-badge.timed{background-color:#fff5f5;color:#c53030}.game-type-badge.collaborative{background-color:#faf5ff;color:#6b46c1}.active-games-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--paper-beige)}.active-games-section h2{margin-bottom:var(--spacing-lg)}.games-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.game-card{display:flex;flex-direction:column;text-decoration:none;color:var(--charcoal);transition:transform .2s ease,box-shadow .2s ease}.game-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow),0 12px 24px #00000014;text-decoration:none}.game-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.game-card-header h3{font-size:1.1rem;margin:0;color:var(--ink-blue)}.game-status{padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.game-status.waiting{background-color:#fefcbf;color:#975a16}.game-status.active{background-color:#c6f6d5;color:#276749}.game-status.completed{background-color:#e2e8f0;color:#4a5568}.game-card-info{font-size:.875rem;color:var(--sepia);margin-bottom:var(--spacing-sm)}.game-card-meta{margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--paper-beige);display:flex;justify-content:space-between;font-size:.8rem;color:var(--sepia)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:var(--spacing-xl);max-width:500px;width:90%;max-height:80vh;overflow-y:auto}.modal-content h2{margin-bottom:var(--spacing-lg);color:var(--ink-blue)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.5rem;border:1px solid var(--sepia);border-radius:4px;font-family:inherit;font-size:.9rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 2px #2563eb1a}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--sepia)}.empty-state h3{margin-bottom:var(--spacing-sm);color:var(--charcoal)}@media(max-width:600px){.games-header .header-content h1{font-size:1.35rem}.games-intro h2{font-size:1.5rem}.category-tabs{gap:var(--spacing-xs)}.category-tab{padding:.4rem .9rem;font-size:.8rem}.game-types-grid,.games-list{grid-template-columns:1fr}.modal-content{width:95%;padding:var(--spacing-lg)}}.game-room{min-height:100vh}.game-room-header{background-color:#fff;border-bottom:1px solid var(--sepia);box-shadow:0 2px 4px var(--shadow);position:sticky;top:0;z-index:100}.game-room-header .header-content{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.game-room-header h1{font-size:1.5rem;margin:0}.game-room-main{padding-top:var(--spacing-lg);max-width:800px;margin:0 auto;padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.game-info-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-sm)}.game-info-bar .game-type-badge{font-size:.85rem}.players-section{margin-bottom:var(--spacing-lg)}.players-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.player-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:16px;font-size:.85rem;background-color:var(--paper-beige);color:var(--charcoal)}.player-chip.current-turn{background-color:var(--ink-blue);color:#fff;font-weight:600}.player-chip.finished{opacity:.6}.player-score{font-size:.75rem;opacity:.7}.turn-indicator{text-align:center;padding:var(--spacing-md);margin-bottom:var(--spacing-lg);border-radius:8px;font-size:1rem}.turn-indicator.your-turn{background-color:#c6f6d5;color:#276749;font-weight:600}.turn-indicator.waiting{background-color:#fefcbf;color:#975a16}.turn-indicator.game-over{background-color:#e2e8f0;color:#4a5568}.timer-display{text-align:center;margin-bottom:var(--spacing-lg)}.timer-value{font-size:2.5rem;font-weight:700;font-family:var(--font-mono);color:var(--charcoal)}.timer-value.urgent{color:#c53030;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.timer-label{font-size:.85rem;color:var(--sepia);font-style:italic}.entry-form{margin-bottom:var(--spacing-lg)}.entry-form textarea{width:100%;min-height:120px;padding:var(--spacing-sm);border:2px solid var(--sepia);border-radius:8px;font-family:var(--font-mono);font-size:1rem;line-height:1.6;resize:vertical;box-sizing:border-box}.entry-form textarea:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 3px #2563eb1a}.entry-form-hint{font-size:.8rem;color:var(--sepia);font-style:italic;margin-top:var(--spacing-xs)}.entry-form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.entries-section{margin-bottom:var(--spacing-lg)}.entries-section h3{margin-bottom:var(--spacing-md);font-size:1.1rem}.entries-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.entry-item{padding:var(--spacing-sm) var(--spacing-md);border-left:3px solid var(--ink-blue);background-color:var(--paper-beige);border-radius:0 4px 4px 0}.entry-item.hidden{border-left-color:var(--sepia);background-color:#f7f7f5}.entry-author{font-size:.8rem;color:var(--sepia);margin-bottom:.25rem}.entry-content{font-family:var(--font-mono);font-size:.95rem;line-height:1.6;white-space:pre-wrap}.entry-hidden-text{font-style:italic;color:var(--sepia)}.visible-hint{padding:var(--spacing-sm) var(--spacing-md);background-color:#f0f9ff;border:1px dashed var(--ink-blue);border-radius:4px;margin-bottom:var(--spacing-md);font-family:var(--font-mono);font-style:italic;color:var(--ink-blue)}.voting-section{margin-bottom:var(--spacing-lg)}.voting-section h3{margin-bottom:var(--spacing-md)}.vote-entry{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border:2px solid var(--paper-beige);border-radius:8px;cursor:pointer;transition:border-color .2s ease}.vote-entry:hover{border-color:var(--ink-blue)}.vote-entry.voted{border-color:var(--ink-blue);background-color:#f0f9ff}.vote-entry-content{font-family:var(--font-mono);font-size:.95rem;line-height:1.6;white-space:pre-wrap;margin-bottom:var(--spacing-sm)}.vote-entry-author{font-size:.8rem;color:var(--sepia)}.vote-count{font-size:.85rem;font-weight:600;color:var(--ink-blue)}.game-result{text-align:center;padding:var(--spacing-xl)}.game-result h2{color:var(--ink-blue);margin-bottom:var(--spacing-lg)}.result-poem{max-width:600px;margin:0 auto var(--spacing-lg);text-align:left;padding:var(--spacing-lg);border:2px solid var(--paper-beige);border-radius:8px}.result-poem-title{font-size:1.25rem;color:var(--ink-blue);margin-bottom:var(--spacing-md)}.result-poem-content{font-family:var(--font-mono);font-size:1rem;line-height:1.8;white-space:pre-wrap}.result-scores{margin-top:var(--spacing-lg)}.result-scores h3{margin-bottom:var(--spacing-sm)}.score-list{list-style:none;padding:0}.score-list li{padding:.3rem 0;font-size:.9rem}.result-actions{margin-top:var(--spacing-lg);display:flex;justify-content:center;gap:var(--spacing-md)}.blackout-editor{margin-bottom:var(--spacing-lg)}.blackout-source{line-height:2.2;font-size:1.1rem;padding:var(--spacing-md);background-color:#fff;border:2px solid var(--paper-beige);border-radius:8px}.blackout-word{cursor:pointer;padding:.15rem .1rem;border-radius:2px;transition:all .15s ease}.blackout-word:hover{background-color:#f0f9ff}.blackout-word.blacked-out{background-color:var(--charcoal);color:var(--charcoal);border-radius:2px;-webkit-user-select:none;user-select:none}.blackout-preview{margin-top:var(--spacing-md);padding:var(--spacing-md);border:1px dashed var(--sepia);border-radius:8px;min-height:60px}.blackout-preview h4{margin-bottom:var(--spacing-sm);color:var(--sepia);font-size:.85rem}.blackout-preview p{font-family:var(--font-mono);line-height:1.8;white-space:pre-wrap}.noun-replacer{margin-bottom:var(--spacing-lg)}.noun-source{padding:var(--spacing-md);background-color:#fff;border:2px solid var(--paper-beige);border-radius:8px;line-height:2;font-size:1rem}.noun-word{cursor:pointer;padding:.1rem .2rem;border-radius:3px;transition:all .15s ease}.noun-word.is-noun{background-color:#fef3c7;border-bottom:2px solid #d97706;cursor:pointer}.noun-word.is-noun:hover{background-color:#fde68a}.noun-word.replaced{background-color:#c6f6d5;border-bottom:2px solid #276749;font-weight:600}.noun-legend{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm);font-size:.8rem;color:var(--sepia)}.noun-legend span{display:flex;align-items:center;gap:.3rem}.noun-legend-swatch{display:inline-block;width:12px;height:12px;border-radius:2px}.waiting-room{text-align:center;padding:var(--spacing-xl)}.waiting-room h3{margin-bottom:var(--spacing-md)}.waiting-room .players-list{justify-content:center;margin-bottom:var(--spacing-lg)}.invite-section{margin:var(--spacing-md) 0;text-align:left}.invite-link-row{display:flex;gap:var(--spacing-xs)}.invite-link-input{flex:1;padding:.5rem;border:1px solid var(--sepia);border-radius:4px;font-family:var(--font-mono);font-size:.8rem;color:var(--charcoal);background-color:var(--paper-beige);cursor:text}.waiting-dots{font-size:1.5rem;color:var(--sepia);animation:waiting 1.5s infinite}@keyframes waiting{0%{content:"."}33%{content:".."}66%{content:"..."}}.constraint-display{text-align:center;padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background-color:#fff5f5;border:2px solid #fed7d7;border-radius:8px}.constraint-display .forbidden-letter{font-size:2rem;font-weight:700;color:#c53030;text-decoration:line-through}.constraint-display p{margin:var(--spacing-xs) 0 0;color:#c53030;font-size:.9rem}.source-display{padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background-color:#f0f9ff;border-left:4px solid var(--ink-blue);border-radius:0 8px 8px 0}.source-display h4{margin-bottom:var(--spacing-xs);color:var(--sepia);font-size:.85rem}.source-display p{font-family:var(--font-mono);font-size:1rem;font-style:italic;color:var(--ink-blue)}@media(max-width:600px){.game-room-header h1{font-size:1.2rem}.game-room-header .header-content{flex-wrap:wrap;gap:var(--spacing-xs)}.game-room-main{padding-left:var(--spacing-sm);padding-right:var(--spacing-sm)}.game-info-bar{flex-direction:column;align-items:flex-start}.timer-value{font-size:2rem}.blackout-source{font-size:.95rem;line-height:2;padding:var(--spacing-sm)}.noun-source{font-size:.9rem;padding:var(--spacing-sm)}.result-poem{padding:var(--spacing-md)}.result-actions{flex-direction:column;align-items:stretch}.invite-link-row{flex-direction:column}.invite-link-input{font-size:.75rem}}
