.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;border-radius:12px;padding:3rem;box-shadow:0 10px 40px #0003;max-width:500px;width:100%;text-align:center}.login-card h1{color:#202124;margin-bottom:.5rem}.login-subtitle{color:#5f6368;margin-bottom:1.5rem;font-size:1rem}.remember-me-container{margin-top:0;margin-bottom:1.5rem;text-align:left;padding:1rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.remember-me-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;color:#202124;font-size:1rem;font-weight:500;-webkit-user-select:none;user-select:none}.remember-me-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.remember-me-text{color:#202124}.remember-me-label:hover,.remember-me-label:hover .remember-me-text{color:#667eea}.google-login-button{display:flex;align-items:center;justify-content:center;gap:1rem;width:100%;padding:1rem;background:#fff;border:2px solid #ddd;border-radius:4px;font-size:1rem;font-weight:500;color:#5f6368;cursor:pointer;transition:all .2s}.google-login-button:hover{background:#f8f9fa;border-color:#4285f4}.google-icon{width:24px;height:24px}.login-info{margin-top:2rem;text-align:left}.login-info h3{color:#202124;margin-bottom:1rem}.login-info ul{list-style:none;padding:0}.login-info li{color:#5f6368;padding:.5rem 0 .5rem 1.5rem;position:relative}.login-info li:before{content:"✓";position:absolute;left:0;color:#34a853;font-weight:700}.dashboard{max-width:1200px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.dashboard-header h1{margin:0}.refresh-button{font-size:1rem;padding:.5rem 1rem;cursor:pointer;transition:opacity .2s}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.alert{padding:1rem;border-radius:4px;margin-bottom:1.5rem}.alert-warning{background-color:#fff3cd;border:1px solid #ffc107;color:#856404}.alert a{color:#004085;font-weight:600;text-decoration:underline}.stat-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f1f3f4;font-size:.9rem}.stat-item:last-child{border-bottom:none}.stat-label{color:#5f6368;font-weight:500;font-size:.875rem}.stat-value{color:#202124;font-weight:600;font-size:.875rem}.tier-badge{background-color:#e8f0fe;color:#1967d2;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;text-transform:capitalize}.status-active{color:#34a853;font-size:.875rem}.status-cancelled{color:#ea4335;font-size:.875rem}.status-expired{color:#f9ab00;font-size:.875rem}.credits-display{text-align:center;padding:1.5rem 0}.credits-number{font-size:2.5rem;font-weight:700;color:#4285f4}.credits-label{color:#5f6368;margin-top:.5rem;font-size:.875rem}.upgrade-hint{text-align:center;color:#5f6368;font-size:.8rem;margin-top:1rem}.storage-bar{width:100%;height:24px;background-color:#f1f3f4;border-radius:12px;overflow:hidden;margin-bottom:1rem}.storage-fill{height:100%;background:linear-gradient(90deg,#4285f4,#34a853);transition:width .3s ease}.action-buttons{display:flex;flex-direction:column;gap:.75rem}.action-buttons .button{text-align:center;text-decoration:none;display:block}.file-upload{max-width:800px;margin:0 auto}.drop-zone{border:2px dashed #ddd;border-radius:8px;padding:3rem;text-align:center;cursor:pointer;transition:all .3s;background-color:#fafafa}.drop-zone:hover{border-color:#4285f4;background-color:#f0f7ff}.drop-zone.drag-active{border-color:#4285f4;background-color:#e8f0fe}.drop-zone-content{pointer-events:none}.upload-icon{width:64px;height:64px;color:#5f6368;margin-bottom:1rem}.drop-zone-text{font-size:1.125rem;color:#202124;margin-bottom:.5rem}.drop-zone-hint{font-size:.875rem;color:#5f6368}.file-preview{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#f1f3f4;border-radius:4px;margin:1.5rem 0}.file-info{flex:1}.file-name{font-weight:600;color:#202124;margin-bottom:.25rem}.file-size{font-size:.875rem;color:#5f6368}.upload-button{width:100%;margin-top:1rem}.upload-button:disabled{background-color:#e8eaed;color:#9aa0a6;cursor:not-allowed}.upload-info{margin-top:2rem}.upload-info ul{list-style:none;padding:0}.upload-info li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#5f6368}.upload-info li:before{content:"•";position:absolute;left:0;color:#4285f4;font-weight:700;font-size:1.5rem;line-height:1}.file-metadata{margin:1.5rem 0;padding:1.5rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e8eaed}.file-metadata h3{margin:0 0 1rem;color:#202124;font-size:1rem;font-weight:600}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;color:#202124;font-weight:500;font-size:.875rem}.metadata-input{width:100%;padding:.75rem;border:1px solid #dadce0;border-radius:4px;font-size:.875rem;transition:border-color .2s;box-sizing:border-box}.metadata-input:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px #4285f41a}.form-group small{display:block;margin-top:.25rem;color:#5f6368;font-size:.75rem;line-height:1.4}.file-management{max-width:1200px;margin:0 auto;padding:2rem}.file-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.file-management-header h1{margin:0;color:#333}.file-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-box{flex:1;min-width:300px}.search-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.tag-filter{min-width:200px}.tag-select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;background-color:#fff}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.file-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .2s ease;position:relative}.file-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.file-icon{font-size:2rem;text-align:center;margin-bottom:1rem;position:relative;height:80px;display:flex;align-items:center;justify-content:center}.file-thumbnail{max-width:100%;max-height:80px;border-radius:8px;box-shadow:0 2px 8px #0000001a;object-fit:cover}.file-icon-text,.file-icon-fallback{font-size:2rem}.hidden{display:none}.file-info{margin-bottom:1rem}.file-name{font-weight:600;font-size:1.1rem;color:#333;margin-bottom:.5rem;word-break:break-word;line-height:1.3}.file-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.file-size{color:#666;font-size:.9rem}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:uppercase}.status-uploading{background-color:#fff3cd;color:#856404}.status-ready{background-color:#d4edda;color:#155724}.status-processing{background-color:#cce7ff;color:#004085}.status-failed{background-color:#f8d7da;color:#721c24}.file-label{margin-bottom:.5rem;font-size:.9rem;color:#555}.file-label strong{color:#333}.file-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem}.tag{background-color:#e9ecef;color:#495057;padding:.2rem .5rem;border-radius:12px;font-size:.8rem;font-weight:500}.file-dates{font-size:.8rem;color:#666;line-height:1.4}.file-actions{display:flex;gap:.5rem;justify-content:flex-end}.file-actions .button{padding:.5rem;min-width:auto;font-size:1rem;border-radius:6px}.button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;text-align:center;transition:all .2s ease}.button-primary{background-color:#007bff;color:#fff}.button-primary:hover{background-color:#0056b3}.button-secondary{background-color:#6c757d;color:#fff}.button-secondary:hover{background-color:#545b62}.button-danger{background-color:#dc3545;color:#fff}.button-danger:hover{background-color:#c82333}.empty-state{text-align:center;padding:3rem;background:#fff;border:1px solid #e0e0e0;border-radius:12px}.empty-state p{margin-bottom:1.5rem;color:#666;font-size:1.1rem}.loading{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.rendering-request{max-width:1000px;margin:0 auto}.form-section{margin-bottom:2rem}.form-section h3{margin-bottom:1rem;color:#202124}.prompt-toggle{display:flex;gap:2rem;margin-bottom:1.5rem}.prompt-toggle label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:#5f6368}.prompt-toggle input[type=radio]{cursor:pointer}.prompt-source-selector{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.prompt-source-selector label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:#5f6368}.prompt-source-selector input[type=radio]{margin:0;cursor:pointer}.user-prompts-section{margin-top:1rem}.empty-prompts{text-align:center;padding:2rem;background:#f8f9fa;border-radius:8px;color:#6c757d}.empty-prompts p{margin-bottom:1rem}.user-prompts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1rem}.user-prompt-card{background:#fff;border:2px solid #e8eaed;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s ease}.user-prompt-card:hover{border-color:#4285f4;box-shadow:0 2px 8px #4285f426}.user-prompt-card.selected{border-color:#4285f4;background:#e8f0fe;box-shadow:0 2px 8px #4285f440}.user-prompt-card h4{margin:0 0 .5rem;color:#202124;font-size:1rem}.prompt-preview{color:#5f6368;font-size:.875rem;line-height:1.4;margin:0 0 .75rem}.prompt-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#9aa0a6}.prompt-tags{display:flex;gap:.25rem}.tag{background:#f1f3f4;color:#5f6368;padding:.125rem .5rem;border-radius:12px;font-size:.625rem;font-weight:500}.prompt-library-link{text-align:center;margin-top:1rem}.custom-prompt-section{margin-top:1rem}.save-prompt-option{margin-top:.5rem;text-align:right}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.ai-models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1rem}.ai-model-card{border:2px solid #e8eaed;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s;background:#fff}.ai-model-card:hover{border-color:#4285f4;background-color:#f8f9fa}.ai-model-card.selected{border-color:#4285f4;background-color:#e8f0fe}.ai-model-card.disabled{opacity:.6;cursor:not-allowed;background-color:#f8f9fa}.ai-model-card.disabled:hover{border-color:#e8eaed;background-color:#f8f9fa}.model-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.model-header h4{color:#202124;margin:0;flex:1}.model-cost{font-size:.875rem;color:#34a853;font-weight:600;background:#e6f4ea;padding:.25rem .5rem;border-radius:4px}.model-provider{font-size:.875rem;color:#5f6368;margin-bottom:.75rem;font-weight:500}.model-description{font-size:.875rem;color:#5f6368;line-height:1.5;margin-bottom:1rem}.model-specs{display:flex;gap:1rem;font-size:.75rem;color:#9aa0a6}.model-specs span{background:#f1f3f4;padding:.25rem .5rem;border-radius:4px}.model-requirement{margin-bottom:1rem}.requirement-badge{display:inline-block;background:#fef7e0;color:#f9ab00;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;border:1px solid #fdd663;margin-bottom:.5rem}.requirement-text{font-size:.75rem;color:#ea4335;margin:0;font-style:italic}.reference-image-toggle{margin-bottom:1rem}.reference-image-toggle label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:#5f6368;margin-bottom:.5rem}.help-text{font-size:.875rem;color:#9aa0a6;margin:0;line-height:1.4}.warning-text{font-size:.875rem;color:#ea4335;margin:.5rem 0 0;line-height:1.4}.template-card{border:2px solid #e8eaed;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s}.template-card:hover{border-color:#4285f4;background-color:#f8f9fa}.template-card.selected{border-color:#4285f4;background-color:#e8f0fe}.template-card h4{color:#202124;margin-bottom:.5rem}.template-category{font-size:.875rem;color:#5f6368;margin-bottom:.75rem;font-weight:500}.template-description{font-size:.875rem;color:#5f6368;line-height:1.5}.custom-prompt-input{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;line-height:1.5;resize:vertical}.submit-button{width:100%;margin-top:1rem}.submit-button:disabled{background-color:#e8eaed;color:#9aa0a6;cursor:not-allowed}.rendering-info ul{list-style:none;padding:0}.rendering-info li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#5f6368}.rendering-info li:before{content:"ℹ";position:absolute;left:0;color:#4285f4;font-weight:700}.rendering-history{max-width:1200px;margin:0 auto}.empty-state{text-align:center;padding:3rem}.empty-state p{color:#5f6368;margin-bottom:1.5rem;font-size:1.125rem}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.rendering-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:transform .2s}.rendering-card:hover{transform:translateY(-4px);box-shadow:0 4px 8px #00000026}.rendering-thumbnail{width:100%;height:200px;background-color:#f1f3f4;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.thumbnail-image{width:100%;height:100%;object-fit:cover;transition:transform .2s}.rendering-card:hover .thumbnail-image{transform:scale(1.05)}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.thumbnail-placeholder.hidden{display:none}.thumbnail-placeholder svg{width:64px;height:64px}.thumbnail-placeholder.completed{color:#34a853}.thumbnail-placeholder.processing{color:#4285f4}.thumbnail-placeholder.failed{color:#ea4335}.thumbnail-placeholder.queued{color:#f9ab00}.spinner{border:4px solid #f3f3f3;border-top:4px solid #4285f4;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.rendering-info{padding:1rem}.rendering-status{margin-bottom:.5rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-queued{background-color:#fef7e0;color:#f9ab00}.status-processing{background-color:#e8f0fe;color:#1967d2}.status-completed{background-color:#e6f4ea;color:#1e8e3e}.status-failed{background-color:#fce8e6;color:#c5221f}.rendering-date{font-size:.875rem;color:#5f6368;margin-bottom:.5rem}.rendering-id{font-size:.75rem;color:#5f6368;margin-bottom:.5rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.rendering-id-value{cursor:pointer;padding:.2rem .4rem;border-radius:4px;background-color:#f8f9fa;border:1px solid #e9ecef;transition:all .2s ease;display:inline-block}.rendering-id-value:hover{background-color:#e9ecef;border-color:#007bff;color:#007bff}.rendering-id-copyable{cursor:pointer;padding:.4rem .6rem;border-radius:4px;background-color:#f8f9fa;border:1px solid #e9ecef;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;transition:all .2s ease;display:inline-block;word-break:break-all}.rendering-id-copyable:hover{background-color:#e9ecef;border-color:#007bff;color:#007bff}.rendering-prompt{font-size:.875rem;color:#202124;line-height:1.4}.rendering-actions{display:flex;gap:.5rem;padding:1rem;border-top:1px solid #f1f3f4}.rendering-actions .button{flex:1;padding:.5rem;font-size:.875rem}.variation-button{background-color:#1976d2!important;color:#fff!important}.variation-button:hover{background-color:#1565c0!important}.variation-badge{display:inline-block;padding:.2rem .5rem;background-color:#e3f2fd;color:#1976d2;border-radius:8px;font-size:.7rem;font-weight:600;margin-left:.5rem}.variation-prompt{border-left:3px solid #1976d2;padding-left:.5rem;margin-top:.5rem}.chain-info{font-size:.75rem;color:#666;font-style:italic;margin-top:.25rem}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:8px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;padding:2rem;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#5f6368;line-height:1;padding:0;width:32px;height:32px}.modal-close:hover{color:#202124}.modal-body{margin-top:1.5rem}.detail-row{display:flex;gap:1rem;padding:.75rem 0;border-bottom:1px solid #f1f3f4}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;color:#5f6368;min-width:140px}.ai-model-name{font-weight:500;color:#1976d2;background-color:#e3f2fd;padding:.25rem .75rem;border-radius:12px;font-size:.875rem}.rendering-preview{margin-top:1.5rem;text-align:center}.rendering-preview img{max-width:100%;border-radius:8px;box-shadow:0 2px 8px #0000001a}.variation-modal{max-width:600px}.original-rendering{margin-bottom:2rem;padding:1rem;background-color:#f8f9fa;border-radius:8px}.original-rendering h3{margin:0 0 1rem;color:#333;font-size:1rem}.original-thumbnail{max-width:200px;max-height:150px;border-radius:8px;margin-bottom:1rem;object-fit:cover}.original-info{font-size:.875rem;color:#666}.original-info div{margin-bottom:.5rem}.variation-form h3{margin:0 0 1rem;color:#333;font-size:1rem}.variation-help{font-size:.875rem;color:#666;margin-bottom:1rem;line-height:1.4}.variation-textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:.875rem;font-family:inherit;resize:vertical;min-height:100px;box-sizing:border-box}.variation-textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.character-count{text-align:right;font-size:.75rem;color:#666;margin-top:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-actions .button{min-width:120px}.ai-model-help{font-size:.9rem;color:#666;margin-bottom:1rem;line-height:1.4}.ai-model-selector{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.ai-model-option{border:2px solid #e0e0e0;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s ease;position:relative;background:#fff}.ai-model-option:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a}.ai-model-option.selected{border-color:#007bff;background:#f8f9ff;box-shadow:0 2px 8px #007bff26}.ai-model-option .model-name{font-weight:600;font-size:1rem;color:#333;margin-bottom:.25rem}.ai-model-option .model-description{font-size:.875rem;color:#666;line-height:1.4}.ai-model-option .model-badge{position:absolute;top:.5rem;right:.5rem;background:#28a745;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.ai-model-option{padding:.75rem}.ai-model-option .model-name{font-size:.9rem}.ai-model-option .model-description{font-size:.8rem}}.image-carousel{margin-top:1.5rem}.carousel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.carousel-header h3{margin:0;font-size:1.125rem;color:#202124}.carousel-indicators{display:flex;gap:.5rem}.carousel-indicators .indicator{width:32px;height:32px;border-radius:4px;border:2px solid #dadce0;background:#fff;cursor:pointer;font-size:.875rem;font-weight:500;color:#5f6368;transition:all .2s}.carousel-indicators .indicator:hover{border-color:#1a73e8;color:#1a73e8}.carousel-indicators .indicator.active{background:#1a73e8;border-color:#1a73e8;color:#fff}.carousel-container{position:relative;display:flex;align-items:center;gap:1rem}.carousel-nav{flex-shrink:0;width:40px;height:40px;border-radius:50%;border:2px solid #dadce0;background:#fff;cursor:pointer;font-size:1.5rem;color:#5f6368;display:flex;align-items:center;justify-content:center;transition:all .2s}.carousel-nav:hover:not(:disabled){border-color:#1a73e8;color:#1a73e8;background:#f8f9fa}.carousel-nav:disabled{opacity:.3;cursor:not-allowed}.carousel-image-container{flex:1;position:relative;min-height:400px;background:#f1f3f4;border-radius:8px;overflow:hidden}.carousel-image{width:100%;height:auto;display:block;transition:opacity .3s}.carousel-actions{display:flex;gap:1rem;margin-top:1rem;justify-content:center}.single-image{margin-top:1.5rem}.single-image img{width:100%;height:auto;border-radius:8px}@media(max-width:768px){.carousel-header{flex-direction:column;align-items:flex-start;gap:.75rem}.carousel-indicators{flex-wrap:wrap}.carousel-nav{width:36px;height:36px;font-size:1.25rem}.carousel-image-container{min-height:300px}.carousel-actions{flex-direction:column}.carousel-actions .button{width:100%}}.share-button{background-color:#10b981;color:#fff}.share-button:hover{background-color:#059669}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-2px}.tab:hover{color:#111827;border-bottom-color:#d1d5db}.tab.active{color:#2563eb;border-bottom-color:#2563eb}.shared-badge{background-color:#10b981;color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.shared-rendering{border-left:4px solid #10b981}.rendering-owner{font-size:.875rem;color:#6b7280;margin-bottom:.5rem}.share-modal{max-width:600px}.share-rendering-info{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background-color:#f9fafb;border-radius:.5rem}.share-thumbnail{width:120px;height:120px;object-fit:cover;border-radius:.5rem}.share-info{flex:1;display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.share-form{margin-bottom:1.5rem}.share-form h3{margin-bottom:.5rem;font-size:1.125rem}.share-help{color:#6b7280;font-size:.875rem;margin-bottom:1rem}.share-input-group{display:flex;gap:.5rem}.share-email-input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem}.share-email-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.existing-shares{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.existing-shares h3{margin-bottom:1rem;font-size:1.125rem}.shares-list{display:flex;flex-direction:column;gap:.75rem}.share-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f9fafb;border-radius:.5rem}.share-user-info{flex:1}.share-email{font-weight:500;color:#111827;margin-bottom:.25rem}.share-date{font-size:.75rem;color:#6b7280}.button-small{padding:.375rem .75rem;font-size:.875rem}.prompt-library{max-width:1200px;margin:0 auto;padding:2rem}.prompt-library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.prompt-library-header h1{margin:0;color:#2c3e50}.prompt-library-filters{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.search-box{margin-bottom:1rem}.search-box input{width:100%;max-width:400px}.tag-filters label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-flex;align-items:center;padding:.25rem .75rem;background:#e9ecef;border:1px solid #dee2e6;border-radius:20px;font-size:.875rem;color:#495057;cursor:pointer;transition:all .2s ease}.tag:hover{background:#dee2e6}.tag.selected{background:#007bff;color:#fff;border-color:#007bff}.tag-remove{background:none;border:none;color:inherit;margin-left:.5rem;cursor:pointer;font-size:1rem;line-height:1;padding:0}.tag-remove:hover{color:#dc3545}.prompts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.prompt-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s ease}.prompt-card:hover{box-shadow:0 4px 8px #00000026}.prompt-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.prompt-card-header h3{margin:0;color:#2c3e50;font-size:1.25rem;flex:1;margin-right:1rem}.prompt-card-actions{display:flex;gap:.5rem;flex-shrink:0}.prompt-card-content{margin-bottom:1rem}.prompt-text{background:#f8f9fa;padding:1rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;line-height:1.5;color:#495057;margin:0 0 .5rem;white-space:pre-wrap;word-break:break-word}.prompt-description{color:#6c757d;font-style:italic;margin:0}.prompt-card-footer{border-top:1px solid #e9ecef;padding-top:1rem}.prompt-tags{margin-bottom:.75rem}.prompt-meta{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#6c757d}.usage-count{font-weight:500}.privacy-indicator{font-size:.75rem}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem;color:#6c757d}.empty-state h3{margin-bottom:1rem;color:#495057}.empty-state p{margin-bottom:2rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:8px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;color:#2c3e50}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#495057}.modal form{padding:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057}.form-group small{display:block;margin-top:.25rem;color:#6c757d;font-size:.875rem}.tag-input{margin-bottom:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid #dee2e6}.button{padding:.5rem 1rem;border:1px solid transparent;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.button-primary{background:#007bff;color:#fff;border-color:#007bff}.button-primary:hover{background:#0056b3;border-color:#0056b3}.button-secondary{background:#6c757d;color:#fff;border-color:#6c757d}.button-secondary:hover{background:#545b62;border-color:#545b62}.button-danger{background:#dc3545;color:#fff;border-color:#dc3545}.button-danger:hover{background:#c82333;border-color:#c82333}.button-small{padding:.25rem .5rem;font-size:.75rem}.input{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;transition:border-color .2s ease}.input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.input:invalid{border-color:#dc3545}.loading{text-align:center;padding:3rem;color:#6c757d}.error{background:#f8d7da;color:#721c24;padding:.75rem;border-radius:4px;margin-bottom:1rem;border:1px solid #f5c6cb}@media(max-width:768px){.prompt-library{padding:1rem}.prompt-library-header{flex-direction:column;gap:1rem;align-items:stretch}.prompts-grid{grid-template-columns:1fr}.prompt-card-header{flex-direction:column;gap:1rem}.prompt-card-actions{align-self:stretch;justify-content:space-between}.modal{margin:1rem;max-height:calc(100vh - 2rem)}.modal-actions{flex-direction:column}}.subscription{max-width:1200px;margin:0 auto}.current-plan{margin-bottom:2rem}.current-plan-info{display:flex;align-items:center;gap:2rem}.plan-name{font-size:1.5rem;font-weight:600;color:#202124}.plan-status{color:#5f6368}.tiers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin:2rem 0}.tier-card{background:#fff;border:2px solid #e8eaed;border-radius:8px;padding:2rem;transition:all .2s}.tier-card:hover{border-color:#4285f4;transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.tier-card.current{border-color:#34a853;background-color:#e6f4ea}.tier-header{text-align:center;padding-bottom:1.5rem;border-bottom:2px solid #f1f3f4;margin-bottom:1.5rem}.tier-header h3{color:#202124;margin-bottom:1rem}.tier-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.price-amount{font-size:2.5rem;font-weight:700;color:#4285f4}.price-period{color:#5f6368;font-size:1rem}.tier-features{margin-bottom:1.5rem}.tier-highlight{background-color:#f8f9fa;padding:.75rem;border-radius:4px;text-align:center;margin-bottom:.75rem;color:#5f6368}.tier-highlight strong{color:#202124;font-size:1.125rem}.tier-features ul{list-style:none;padding:0;margin-top:1rem}.tier-features li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#5f6368;font-size:.875rem}.tier-features li:before{content:"✓";position:absolute;left:0;color:#34a853;font-weight:700}.tier-card .button{width:100%}.subscription-info ul{list-style:none;padding:0}.subscription-info li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#5f6368}.subscription-info li:before{content:"ℹ";position:absolute;left:0;color:#4285f4;font-weight:700}.admin-dashboard{max-width:1400px;margin:0 auto}.admin-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e8eaed}.tab-button{padding:1rem 2rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;color:#5f6368;cursor:pointer;transition:all .2s}.tab-button:hover{color:#202124}.tab-button.active{color:#4285f4;border-bottom-color:#4285f4}.users-table{overflow-x:auto}.users-table table{width:100%;border-collapse:collapse}.users-table th{text-align:left;padding:1rem;background-color:#f8f9fa;color:#5f6368;font-weight:600;border-bottom:2px solid #e8eaed}.users-table td{padding:1rem;border-bottom:1px solid #f1f3f4}.button-sm{padding:.5rem 1rem;font-size:.875rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:#4285f4;margin-bottom:.5rem}.stat-label{color:#5f6368;font-size:1rem}.revenue-breakdown,.cost-list{display:flex;flex-direction:column;gap:1rem}.revenue-item,.cost-item{display:flex;justify-content:space-between;padding:1rem;background-color:#f8f9fa;border-radius:4px}.revenue-tier,.cost-user{font-weight:600;color:#202124;text-transform:capitalize}.revenue-amount,.cost-amount{color:#34a853;font-weight:600}.total-cost{font-size:3rem;font-weight:700;color:#ea4335;text-align:center;padding:2rem}.cost-chart{display:flex;flex-direction:column;gap:1rem}.cost-bar-item{display:grid;grid-template-columns:120px 1fr 120px;align-items:center;gap:1rem}.cost-period{font-weight:500;color:#5f6368}.cost-bar-container{height:32px;background-color:#f1f3f4;border-radius:4px;overflow:hidden}.cost-bar{height:100%;background:linear-gradient(90deg,#ea4335,#fbbc04);transition:width .3s ease}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#202124}.queues-section{display:flex;flex-direction:column;gap:2rem}.queue-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.queue-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.queue-actions{display:flex;gap:1rem;align-items:center}.queue-selector{padding:.5rem 1rem;border:1px solid #dadce0;border-radius:4px;background:#fff;font-size:.875rem;color:#202124}.button-xs{padding:.25rem .5rem;font-size:.75rem}.button-danger{background-color:#ea4335;color:#fff;border:none}.button-danger:disabled{background-color:#f1f3f4;color:#9aa0a6;cursor:not-allowed}.queue-messages{display:flex;flex-direction:column;gap:1rem}.messages-header{padding:1rem;background-color:#f8f9fa;border-radius:4px;font-weight:500;color:#5f6368}.messages-list{display:flex;flex-direction:column;gap:1rem}.message-card{border:1px solid #dadce0;border-radius:8px;padding:1.5rem;background:#fff}.message-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.message-id{font-family:Courier New,monospace;font-size:.875rem;color:#5f6368}.message-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.message-time,.message-retries{font-size:.875rem;color:#5f6368;background-color:#f8f9fa;padding:.25rem .5rem;border-radius:4px}.message-user,.message-rendering{margin-bottom:1rem;padding:.75rem;background-color:#f8f9fa;border-radius:4px;font-size:.875rem;line-height:1.4}.message-body{margin-bottom:1rem}.message-body pre{background-color:#f8f9fa;padding:1rem;border-radius:4px;font-size:.75rem;overflow-x:auto;max-height:200px;overflow-y:auto;border:1px solid #e8eaed}.message-error{padding:.75rem;background-color:#fce8e6;border:1px solid #ea4335;border-radius:4px;color:#d93025;font-size:.875rem}.no-messages{text-align:center;padding:3rem;color:#5f6368}.no-messages p{font-size:1.125rem;margin:0}@media(max-width:768px){.queue-controls{flex-direction:column;align-items:stretch}.queue-actions{justify-content:center}.message-header{flex-direction:column;align-items:stretch}.message-actions{justify-content:space-between}}.prompts-section{display:flex;flex-direction:column;gap:2rem}.prompts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.prompts-table{overflow-x:auto}.prompts-table table{width:100%;border-collapse:collapse}.prompts-table th{text-align:left;padding:1rem;background-color:#f8f9fa;color:#5f6368;font-weight:600;border-bottom:2px solid #e8eaed}.prompts-table td{padding:1rem;border-bottom:1px solid #f1f3f4;vertical-align:top}.prompt-text-cell{max-width:400px;font-size:.875rem;color:#5f6368;line-height:1.4}.category-badge{display:inline-block;padding:.25rem .75rem;background-color:#e8f0fe;color:#1967d2;border-radius:12px;font-size:.875rem;font-weight:500}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status-badge.active{background-color:#e6f4ea;color:#137333}.status-badge.inactive{background-color:#f1f3f4;color:#5f6368}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 4px 16px #0003}.modal-content.modal-large{max-width:800px}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:#5f6368;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.modal-close:hover{background-color:#f1f3f4}.modal-content h2{margin-top:0;margin-bottom:1.5rem;color:#202124}.textarea-large{min-height:150px;font-family:inherit;resize:vertical}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}@media(max-width:768px){.prompts-header{flex-direction:column;align-items:stretch}.action-buttons{flex-direction:column}.modal-content{padding:1.5rem;max-height:95vh}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:1rem 0}.navbar-container{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:1.25rem;font-weight:600;color:#4285f4;text-decoration:none}.navbar-menu{display:flex;gap:2rem}.navbar-link{color:#5f6368;text-decoration:none;font-weight:500;transition:color .2s}.navbar-link:hover{color:#4285f4}.navbar-user{display:flex;align-items:center;gap:1rem}.user-name{color:#5f6368;font-weight:500}.main-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.5rem;color:#666}.container{max-width:1200px;margin:0 auto;padding:2rem}.card{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem}.button{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s}.button-primary{background-color:#4285f4;color:#fff}.button-primary:hover{background-color:#357ae8}.button-secondary{background-color:#f1f3f4;color:#202124}.button-secondary:hover{background-color:#e8eaed}.button-danger{background-color:#ea4335;color:#fff}.button-danger:hover{background-color:#d33b2c}.input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;margin-bottom:1rem}.input:focus{outline:none;border-color:#4285f4}.error{color:#ea4335;margin-top:.5rem;font-size:.875rem}.success{color:#34a853;margin-top:.5rem;font-size:.875rem}h1{font-size:2rem;margin-bottom:1.5rem;color:#202124}h2{font-size:1.5rem;margin-bottom:1rem;color:#202124}h3{font-size:1.25rem;margin-bottom:.75rem;color:#202124}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#202124;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}@media(max-width:768px){.navbar-container{flex-direction:column;gap:.5rem;padding:.75rem!important;align-items:stretch}.navbar-brand{font-size:.9rem!important;text-align:center;width:100%;padding:.5rem 0;margin-bottom:.25rem}.navbar-menu{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem!important;width:100%;padding:.25rem 0}.navbar-link{font-size:.8rem;padding:.4rem .6rem;white-space:nowrap;flex-shrink:0}.navbar-user{display:flex;flex-direction:column;gap:.5rem!important;width:100%;align-items:center;padding-top:.25rem}.user-name{font-size:.8rem;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-user .button{width:100%;max-width:200px;font-size:.85rem;padding:.5rem}}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{overflow-x:hidden;-webkit-overflow-scrolling:touch}button,.button,a,input[type=checkbox],input[type=radio]{min-height:44px;min-width:44px}input,textarea,select{font-size:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.container{padding:1rem;max-width:100%}@media(min-width:768px){.container{padding:2rem}}.card{padding:1rem;margin-bottom:1rem}@media(min-width:768px){.card{padding:2rem;margin-bottom:1.5rem}}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.125rem}@media(min-width:768px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}.button{padding:.625rem 1rem;font-size:.875rem;width:100%}@media(min-width:768px){.button{padding:.75rem 1.5rem;font-size:1rem;width:auto}}.modal-overlay{padding:0}.modal{margin:0;border-radius:0;max-height:100vh;width:100%;max-width:100%}@media(min-width:768px){.modal-overlay{padding:1rem}.modal{margin:auto;border-radius:8px;max-height:90vh;max-width:600px}}@media(max-width:767px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}thead{display:none}tbody,tr,td{display:block;width:100%}tr{margin-bottom:1rem;border:1px solid #ddd;border-radius:4px;padding:.5rem}td{text-align:right;padding:.5rem;position:relative;padding-left:50%}td:before{content:attr(data-label);position:absolute;left:.5rem;width:45%;padding-right:.5rem;text-align:left;font-weight:700}}@media(max-width:767px){.grid,[class*=grid-]{display:block!important}.grid>*,[class*=grid-]>*{width:100%!important;margin-bottom:1rem}}img{max-width:100%;height:auto}*{max-width:100%}@media(max-width:767px){.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}}.hide-mobile{display:none}@media(min-width:768px){.hide-mobile{display:block}}.show-mobile{display:block}@media(min-width:768px){.show-mobile{display:none}}nav{overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:767px){.form-row{flex-direction:column}.form-group{width:100%!important;margin-right:0!important}}input[type=file]{font-size:16px;padding:.5rem}select{font-size:16px;padding:.75rem 2.5rem .75rem .75rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px}input[type=checkbox],input[type=radio]{width:20px;height:20px;margin-right:.5rem}.loading{font-size:1rem;padding:1rem}@media(min-width:768px){.loading{font-size:1.5rem}}.error,.success{padding:.75rem;border-radius:4px;margin:.5rem 0}.error{background-color:#fef2f2;border:1px solid #fecaca}.success{background-color:#f0fdf4;border:1px solid #bbf7d0}@media(max-width:767px){.card-grid{grid-template-columns:1fr!important}}@media(max-width:767px){.action-buttons{display:flex;flex-direction:column;gap:.5rem}.action-buttons button,.action-buttons .button{width:100%}}@media(max-width:767px){header{padding:1rem}header h1{font-size:1.25rem}}@media(max-width:767px){footer{padding:1rem;text-align:center}}@media(max-width:767px){.sidebar{position:fixed;top:0;left:-100%;width:80%;max-width:300px;height:100vh;background:#fff;transition:left .3s ease;z-index:1000;box-shadow:2px 0 8px #0000001a}.sidebar.open{left:0}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999;display:none}.sidebar-overlay.open{display:block}}p,li,td,th{line-height:1.6}@media(max-width:767px){p,li,td,th{font-size:.9375rem}}ul,ol{padding-left:1.5rem}@media(max-width:767px){ul,ol{padding-left:1.25rem}}pre,code{overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:.875rem}@media(max-width:767px){pre,code{font-size:.8125rem}}
