@charset "UTF-8";@media (max-width: 767px){body,.app-page,.billing-page,.gallery-page,.portrait-creator-page{padding-bottom:70px}}.animate-spin{animation:spin 1s linear infinite}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--gray-800)}::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f172a;padding:2rem}.error-boundary__content{background:#1e293b;border-radius:.75rem;padding:3rem;text-align:center;max-width:500px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.error-boundary__title{color:#ef4444;font-size:1.5rem;font-weight:700;margin:0 0 1rem}.error-boundary__message{color:#cbd5e1;font-size:1rem;margin:0 0 2rem;line-height:1.6}.error-boundary__button{background:#6366f1;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:.3s ease-in-out}.error-boundary__button:hover{background:#5b62f3}.select-wrapper{display:flex;flex-direction:column;gap:.25rem}.select{appearance:none;background:#1e293b;border:1px solid #475569;border-radius:.5rem;color:#f8fafc;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:400;outline:none;padding:.5rem 2rem .5rem 1rem;transition:all .3s ease-in-out;width:100%}.select:hover:not(:disabled){border-color:#64748b}.select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.select:disabled{background:#334155;color:#94a3b8;cursor:not-allowed}.select--sm{font-size:.875rem;padding:.25rem 1.5rem .25rem .5rem}.select--md{font-size:1rem;padding:.5rem 2rem .5rem 1rem}.select--lg{font-size:1.125rem;padding:1rem 3rem 1rem 1.5rem}.select--default{background:#1e293b;border:1px solid #475569}.select--outline{background:transparent;border:2px solid #475569}.select--outline:focus{border-color:#6366f1;background:#1e293b}.select--filled{background:#334155;border:1px solid transparent}.select--filled:focus{background:#1e293b;border-color:#6366f1}.select--error{border-color:#ef4444}.select--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.select--full-width{width:100%}.select--loading{padding-right:4.5rem}.select--disabled{background:#334155;color:#94a3b8;cursor:not-allowed}.select__label{color:#f8fafc;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.select__required{color:#ef4444;margin-left:2px}.select__container{position:relative;display:inline-block;width:100%}.select__spinner{position:absolute;right:2rem;top:50%;transform:translateY(-50%);pointer-events:none;color:#6366f1;width:1rem;height:1rem}.select__spinner svg{width:100%;height:100%}.select__helper{font-size:.75rem;color:#cbd5e1;margin-top:.25rem}.select__helper--error{color:#ef4444}.select:focus-visible{outline:2px solid #6366f1;outline-offset:2px}@media (prefers-color-scheme: dark){.select::-webkit-scrollbar{width:8px}.select::-webkit-scrollbar-track{background:#0f172a}.select::-webkit-scrollbar-thumb{background:#475569;border-radius:.25rem}}.select__chevron svg{transition:transform .15s ease-in-out}.select:focus~.select__chevron svg{transform:rotate(180deg)}@media (max-width: 767px){.select--lg{font-size:1rem;padding:.5rem 2rem .5rem 1rem}}.generation-form{background:#1e293b;border-radius:.75rem;padding:1.5rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.generation-form__title{font-size:1.25rem;font-weight:600;color:#f8fafc;margin-bottom:1.5rem}.generation-form__form{display:flex;flex-direction:column;gap:1.5rem}.generation-form__field{display:flex;flex-direction:column}.generation-form__field label{display:block;font-size:.875rem;font-weight:500;color:#cbd5e1;margin-bottom:.5rem}.generation-form__field textarea{width:100%;padding:.75rem;background:#0f172a;border:1px solid #475569;border-radius:.5rem;color:#f8fafc;font-size:.875rem;resize:none;transition:.3s ease-in-out}.generation-form__field textarea::placeholder{color:#94a3b8}.generation-form__field textarea:focus{outline:none;box-shadow:0 0 0 2px #6366f1;border-color:transparent}.generation-form__field textarea:disabled{opacity:.6;cursor:not-allowed}.generation-form__field select{width:100%;padding:.75rem 2.5rem .75rem .75rem;background:#0f172a;border:1px solid #475569;border-radius:.5rem;color:#f8fafc;font-size:.875rem;transition:.3s ease-in-out;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem}.generation-form__field select:focus{outline:none;box-shadow:0 0 0 2px #6366f1;border-color:transparent}.generation-form__field select:disabled{opacity:.6;cursor:not-allowed}.generation-form__field select option{background:#0f172a;color:#f8fafc}.generation-form__field-description{font-size:.875rem;color:#94a3b8;margin-top:.25rem}.generation-form__field--error textarea,.generation-form__field--error input,.generation-form__field--error select{border-color:#ef4444;box-shadow:0 0 0 1px #ef4444}.generation-form__field-error{color:#ef4444;font-size:.75rem;margin-top:.25rem;display:flex;align-items:center;gap:.25rem}.generation-form__field-error:before{content:"⚠";font-size:.875rem}.generation-form__error{background:#ef444433;border:1px solid rgba(239,68,68,.5);color:#fca5a5;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem}.generation-form__submit{width:100%;background:#6366f1;color:#fff;font-weight:500;padding:.75rem 1rem;border-radius:.5rem;border:none;cursor:pointer;transition:.3s ease-in-out;font-size:.875rem}.generation-form__submit:hover:not(:disabled){background:#5b62f3}.generation-form__submit:disabled{background:#64748b;cursor:not-allowed}.generation-form__submit:focus{outline:none;box-shadow:0 0 0 2px #6366f1,0 0 0 4px #9333ea1a}.generation-form__templates{margin-top:2rem}.generation-form__templates-title{font-size:1rem;font-weight:500;color:#f8fafc;margin-bottom:.75rem}.generation-form__templates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}@media (max-width: 768px){.generation-form__templates-grid{grid-template-columns:1fr;gap:.375rem}}.generation-form__templates-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#0f172a;border:1px solid #475569;border-radius:.5rem;cursor:pointer;transition:all .15s ease-in-out;text-align:left;min-height:auto}.generation-form__templates-item:hover:not(:disabled){background:#334155;border-color:#6366f1;transform:translateY(-1px);box-shadow:0 2px 8px #9333ea1f}.generation-form__templates-item:active:not(:disabled){transform:translateY(0)}.generation-form__templates-item:disabled{opacity:.6;cursor:not-allowed}.generation-form__templates-item-icon{font-size:1.1rem;flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:transform .15s ease-in-out}.generation-form__templates-item:hover:not(:disabled) .generation-form__templates-item-icon{transform:scale(1.1)}.generation-form__templates-item-content{flex:1;min-width:0}.generation-form__templates-item-title{color:#6366f1;font-size:.8rem;font-weight:600;margin:0 0 .25rem;line-height:1.2}.generation-form__templates-item-prompt{color:#cbd5e1;font-size:.7rem;line-height:1.3;margin:0;opacity:.9}.generation-form__templates-item:hover:not(:disabled) .generation-form__templates-item-prompt{color:#f8fafc;opacity:1}.generation-form__model-info{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.generation-form__model-description{font-size:.75rem;color:#94a3b8}.generation-form__model-cost{font-size:.75rem;color:#6366f1;font-weight:600}.generation-form__model-cost--insufficient{color:#ef4444}.generation-form__tokens-remaining{color:#94a3b8;font-weight:400;margin-left:.5rem}.generation-form__required{color:#ef4444}.generation-form__char-count{font-size:.75rem;color:#94a3b8;margin-top:.25rem;text-align:right}.generation-form__format-warning{margin-top:.5rem;padding:.5rem;background:#f59e0b33;color:#f59e0b;border-radius:.5rem;font-size:.75rem;border:1px solid rgba(245,158,11,.3)}.generation-form__seed-input{display:flex;gap:.5rem;align-items:center}.generation-form__seed-input input[type=number]{flex:1;padding:.75rem;background:#0f172a;border:1px solid #475569;border-radius:.5rem;color:#f8fafc;font-size:.875rem;transition:.3s ease-in-out}.generation-form__seed-input input[type=number]::placeholder{color:#94a3b8}.generation-form__seed-input input[type=number]:focus{outline:none;box-shadow:0 0 0 2px #6366f1;border-color:transparent}.generation-form__seed-input input[type=number]:disabled{opacity:.5;cursor:not-allowed}.generation-form__use-seed-btn{padding:.5rem 1rem;background:#334155;color:#f8fafc;border:none;border-radius:.5rem;font-size:.75rem;cursor:pointer;transition:.3s ease-in-out;white-space:nowrap}.generation-form__use-seed-btn:hover:not(:disabled){background:#64748b}.generation-form__use-seed-btn:disabled{opacity:.5;cursor:not-allowed}.image-gallery{background:var(--gray-800);border-radius:var(--border-radius-lg);padding:1.5rem;box-shadow:var(--shadow-xl)}.image-gallery__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.image-gallery__header-title{font-size:1.25rem;font-weight:600;color:var(--white)}.image-gallery__header-actions{display:flex;align-items:center;gap:1rem}.image-gallery__show-more{display:flex;align-items:center;gap:.25rem;background:var(--primary-color);color:#fff;border:none;padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.image-gallery__show-more:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.image-gallery__show-more svg{width:1rem;height:1rem}.image-gallery__generating{margin-bottom:1.5rem;padding:1rem;background:var(--gray-700);border-radius:var(--border-radius-lg);border:2px solid rgba(147,51,234,.5)}.image-gallery__generating-content{display:flex;align-items:center;gap:.75rem}.image-gallery__generating-content .spinner{width:1.5rem;height:1.5rem;border:2px solid var(--primary-color);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.image-gallery__generating-content span{color:var(--white)}.image-gallery__empty{text-align:center;padding:3rem 0}.image-gallery__empty-title{color:var(--gray-500);font-size:1.125rem;margin-bottom:.5rem}.image-gallery__empty-subtitle{color:var(--gray-400);font-size:.875rem}.image-gallery__grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.image-gallery__grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.image-gallery__grid{grid-template-columns:repeat(3,1fr)}}.image-gallery__item{background:var(--gray-700);border-radius:var(--border-radius-lg);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}.image-gallery__item:hover{box-shadow:0 0 0 2px var(--primary-color)}.image-gallery__item-image{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;flex:1}.image-gallery__item-image img{width:100%;height:100%;object-fit:cover;cursor:pointer;transition:transform .2s ease-in-out}.image-gallery__item-image img:hover{transform:scale(1.05)}.image-gallery__item-overlay{position:absolute;inset:0;background:linear-gradient(45deg,#0009,#0000004d);display:flex;align-items:center;justify-content:center;gap:1rem;opacity:0;transition:opacity .3s ease}.image-gallery__item:hover .image-gallery__item-overlay{opacity:1}.image-gallery__item-view,.image-gallery__item-download{background:#fffffff2;color:var(--gray-700);border:none;padding:.75rem;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.image-gallery__item-view svg,.image-gallery__item-download svg{width:1.25rem;height:1.25rem}.image-gallery__item-view:hover,.image-gallery__item-download:hover{background:var(--white);transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.image-gallery__item-view:hover{color:var(--primary-color)}.image-gallery__item-download:hover{color:var(--success-color)}.image-gallery__item-content{padding:.75rem}.image-gallery__item-content-prompt{color:var(--gray-300);margin-bottom:.5rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.image-gallery__item-content-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--gray-400)}.image-gallery__item-content-meta:not(:last-child){margin-bottom:.25rem}.image-gallery__modal{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}@media (max-width: 767px){.image-gallery__modal{padding:.5rem}}.image-gallery__modal-content{width:100vw;max-width:1000px;max-height:85vh;background:var(--gray-800);border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px -12px #000c;display:flex;flex-direction:column}.image-gallery__modal-header{padding:1.5rem;border-bottom:1px solid var(--gray-700);display:flex;justify-content:space-between;align-items:center}@media (max-width: 767px){.image-gallery__modal-header{padding:.5rem 1.5rem}}.image-gallery__modal-header h3{color:var(--white);font-weight:600;font-size:1.25rem;margin:0}.image-gallery__modal-close{color:var(--gray-400);background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s ease}.image-gallery__modal-close:hover{color:var(--white);background:var(--gray-700)}.image-gallery__modal-close svg{width:1.5rem;height:1.5rem}.image-gallery__modal-body{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;padding:1.5rem;overflow-y:auto}@media (max-width: 768px){.image-gallery__modal-body{grid-template-columns:1fr}}.image-gallery__modal-image{display:flex;align-items:center;justify-content:center;background:var(--gray-900);border-radius:.5rem;overflow:hidden;min-height:400px;position:relative}@media (max-width: 767px){.image-gallery__modal-image{margin:0 -1rem}}.image-gallery__modal-image img{width:100%;height:auto;max-height:85vh;object-fit:contain;transition:opacity .3s ease}.image-gallery__modal-image img[data-loading=true]{opacity:0}.image-gallery__modal-image img[data-loading=false]{opacity:1}.image-gallery__modal-image:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shimmer 1.5s infinite;z-index:1}.image-gallery__modal-image[data-image-loaded=true]:before{display:none}.image-gallery__modal-details{display:flex;flex-direction:column;gap:1.5rem}.image-gallery__modal-prompt h4{color:var(--white);font-size:1rem;font-weight:600;margin:0 0 .5rem}.image-gallery__modal-prompt p{color:var(--gray-300);line-height:1.5;margin:0;padding:.75rem;background:var(--gray-700);border-radius:.5rem;border:1px solid var(--gray-600)}.image-gallery__modal-meta{display:flex;flex-direction:column;gap:.75rem}.image-gallery__modal-meta-item{display:flex;justify-content:space-between;align-items:center}.image-gallery__modal-meta-item .label{color:var(--gray-400);font-size:.875rem;font-weight:500}.image-gallery__modal-meta-item .value{color:var(--white);font-size:.875rem;font-weight:600}.image-gallery__modal-actions{display:flex;flex-direction:column;gap:.75rem}.image-gallery__modal-download,.image-gallery__modal-view-all{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.image-gallery__modal-download svg,.image-gallery__modal-view-all svg{width:1rem;height:1rem}.image-gallery__modal-download{background:var(--primary-color);color:var(--white)}.image-gallery__modal-download:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.image-gallery__modal-view-all{background:var(--gray-700);color:var(--gray-300);border:1px solid var(--gray-600)}.image-gallery__modal-view-all:hover{background:var(--gray-600);color:var(--white)}.image-card{background:#1e293b;border-radius:.75rem;border:1px solid #475569;overflow:hidden;transition:all .3s ease}.image-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.image-card__image{position:relative;aspect-ratio:1;overflow:hidden}.image-card__image img{width:100%;height:100%;object-fit:cover;cursor:pointer;transition:transform .3s ease}.image-card__image:hover img{transform:scale(1.05)}.image-card__overlay{position:absolute;inset:0;background:linear-gradient(45deg,#0009,#0000004d);display:flex;align-items:center;justify-content:center;gap:1rem;opacity:0;transition:opacity .3s ease}.image-card:hover .image-card__overlay{opacity:1}.image-card__action{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background:#1e293b;border:1px solid #475569;border-radius:50%;color:#f8fafc;cursor:pointer;transition:all .3s ease}.image-card__action svg{width:1.25rem;height:1.25rem}.image-card__action:hover{transform:scale(1.1);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.image-card__action--view:hover{background:#4f46e5;border-color:#4f46e5;color:#fff}.image-card__action--download:hover{background:#10b981;border-color:#10b981;color:#fff}.image-card__content{padding:1rem}.image-card__prompt{color:var(--gray-300);margin-bottom:.5rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.image-card__meta{display:flex;align-items:center;justify-content:space-between;color:#cbd5e1;font-size:.75rem}.image-card__meta span{background:#0f172a;padding:.25rem;border-radius:.25rem}.image-modal{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;backdrop-filter:blur(4px)}@media (max-width: 767px){.image-modal{padding:.5rem}}.image-modal__content{width:100vw;max-width:1000px;max-height:85vh;background:#1e293b;border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px -12px #000c;display:flex;flex-direction:column}.image-modal__header{padding:1.5rem;border-bottom:1px solid #475569;display:flex;justify-content:space-between;align-items:center}@media (max-width: 767px){.image-modal__header{padding:1rem 1.5rem}}.image-modal__header h3{color:#f8fafc;font-weight:600;font-size:1.125rem;margin:0}.image-modal__close{color:#cbd5e1;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s ease}.image-modal__close:hover{color:#f8fafc;background:#0f172a}.image-modal__close svg{width:1.5rem;height:1.5rem}.image-modal__body{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;padding:1.5rem;overflow-y:auto}@media (max-width: 768px){.image-modal__body{grid-template-columns:1fr;padding:1rem}}.image-modal__image{display:flex;align-items:center;justify-content:center;background:#0f172a;border-radius:.5rem;overflow:hidden;min-height:400px;position:relative}@media (max-width: 767px){.image-modal__image{margin:0 -1rem}}.image-modal__image img{width:100%;height:auto;max-height:70vh;object-fit:contain;transition:opacity .3s ease}.image-modal__image img[data-loading=true]{opacity:0}.image-modal__image img[data-loading=false]{opacity:1}.image-modal__image:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(79,70,229,.1),transparent);animation:shimmer 1.5s infinite;z-index:1}.image-modal__image[data-image-loaded=true]:before{display:none}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.image-modal__details{display:flex;flex-direction:column;gap:1.5rem}.image-modal__prompt h4{color:#f8fafc;font-size:1rem;font-weight:600;margin:0 0 .5rem}.image-modal__prompt p{color:#cbd5e1;line-height:1.5;margin:0 0 1rem;padding:.75rem;background:#0f172a;border-radius:.5rem;border:1px solid #475569}.image-modal__copy-prompt{padding:.25rem .5rem;background:#6366f1;color:#fff;border:none;border-radius:.25rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.image-modal__copy-prompt:hover{background:#5b62f3}.image-modal__meta{display:flex;flex-direction:column;gap:.75rem}.image-modal__meta-item{display:flex;justify-content:space-between;align-items:center}.image-modal__meta-item .label{color:#cbd5e1;font-size:.875rem;font-weight:500}.image-modal__meta-item .value{color:#f8fafc;font-size:.875rem;font-weight:600;text-transform:capitalize}.image-modal__actions{display:flex;flex-direction:column;gap:.75rem;margin-top:auto}.image-modal__download,.image-modal__view-all,.image-modal__regenerate{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.image-modal__download svg,.image-modal__view-all svg,.image-modal__regenerate svg{width:1rem;height:1rem}.image-modal__download{background:#6366f1;color:#fff}.image-modal__download:hover{background:#5b62f3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.image-modal__view-all{background:#0f172a;color:#cbd5e1;border:1px solid #475569}.image-modal__view-all:hover{background:#334155;color:#f8fafc;border-color:#64748b}.image-modal__regenerate{background:#10b981;color:#fff}.image-modal__regenerate:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.result-area{background:#1e293b;border-radius:.75rem;border:1px solid #475569;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;min-height:400px;display:flex;align-items:center;justify-content:center}.result-area__generating{align-items:center;justify-content:center;display:flex;flex-direction:column;gap:1.5rem;padding:2rem}.result-area__generating-content{align-items:center;justify-content:center;display:flex;flex-direction:column;gap:1rem}.result-area__generating-content .spinner{width:2.5rem;height:2.5rem;border:2px solid transparent;border-top:2px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.result-area__generating-content h3{color:#f8fafc;font-size:1.25rem;font-weight:600;margin:0}.result-area__generating-content p{color:#cbd5e1;font-size:1rem;margin:0}.result-area__content{position:relative;width:100%;height:100%;min-height:400px}.result-area__image{position:relative;width:100%;height:100%;min-height:400px;overflow:hidden;border-radius:.75rem}.result-area__image img{width:100%;height:100%;object-fit:cover;transition:all .3s ease;cursor:pointer}.result-area__image img:hover{transform:scale(1.05)}.result-area__overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.6) 50%,transparent 100%);padding:2rem;color:#fff;transition:all .3s ease}.result-area__overlay:hover{background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 60%,transparent 100%)}.result-area__details h3{color:#fff;font-size:1.25rem;font-weight:600;margin:0 0 .5rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.result-area__prompt{color:#fffffff2;font-size:.875rem;line-height:1.4;margin:0 0 .5rem;padding:.25rem .5rem;background:#ffffff1a;border-radius:.25rem;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);text-shadow:0 1px 2px rgba(0,0,0,.5);cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;max-height:calc(4.2em + .5rem);overflow:hidden}.result-area__prompt:after{content:"...";position:absolute;bottom:.25rem;right:17px;padding-left:1em;transition:opacity .4s cubic-bezier(.4,0,.2,1)}.result-area__prompt:hover{background:#ffffff26;border-color:#fff6;max-height:20em}.result-area__prompt:hover:after{opacity:0}.result-area__meta{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem}.result-area__meta span{background:#ffffff26;color:#ffffffe6;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);text-shadow:0 1px 2px rgba(0,0,0,.5)}.result-area__actions{margin-top:.5rem;display:flex;gap:6px}.result-area__download{display:flex;align-items:center;justify-content:center;gap:.25rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.25rem .5rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;backdrop-filter:blur(10px);text-shadow:0 1px 2px rgba(0,0,0,.5)}.result-area__download:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.result-area__download svg{width:1rem;height:1rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.result-area__empty{align-items:center;justify-content:center;display:flex;flex-direction:column;gap:1rem;padding:2rem}.result-area__empty-content{text-align:center}.result-area__empty-content h3{color:#f8fafc;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.result-area__empty-content p{color:#cbd5e1;font-size:1rem;margin:0}.result-area__metadata{margin:1rem 0;padding:.5rem 0;border-top:1px solid #475569}.result-area__meta-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.result-area__meta-row:last-child{margin-bottom:0}.result-area__meta-label{color:#cbd5e1;font-size:.875rem;font-weight:500;min-width:60px}.result-area__meta-value{color:#f8fafc;font-size:.875rem;flex:1;text-align:right}.result-area__meta-value--clickable{cursor:pointer;color:#6366f1;transition:.3s ease-in-out}.result-area__meta-value--clickable:hover{color:#5b62f3;text-decoration:underline}.result-area__status-success{color:#10b981!important;font-weight:600}.result-area__status-error{color:#ef4444!important;font-weight:600}.result-area__status-content_filtered{color:#f59e0b!important;font-weight:600}.result-area__copy-prompt{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;font-weight:500;transition:all .15s ease-in-out;cursor:pointer;border:none;text-decoration:none;background:#0f172a;color:#f8fafc;border:1px solid #475569;padding:.5rem 1rem;font-size:.875rem;gap:.25rem;transition:.3s ease-in-out}.result-area__copy-prompt:disabled{opacity:.6;cursor:not-allowed}.result-area__copy-prompt:hover:not(:disabled){background:#334155;border-color:#6366f1}.result-area__copy-prompt svg{width:1rem;height:1rem}.result-area__model-info{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #475569}.result-area__model-info h4{color:#f8fafc;font-size:1rem;font-weight:600;margin:0 0 .5rem}.result-area__model-info ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;flex-direction:column;gap:.25rem;width:100%}.result-area__model-info ul li{color:#cbd5e1;font-size:.875rem;margin-bottom:0;padding:.5rem;background:#0f172a;border-radius:.5rem;display:flex;flex-direction:column;word-break:break-word;line-height:1.4;box-shadow:0 1px 4px #0000000a;border:1px solid #475569}.result-area__model-info .result-area__model-name{font-weight:600;font-size:1.05em;color:#6366f1;margin-bottom:2px}.result-area__model-info .result-area__model-cost{color:#94a3b8;font-size:.95em;margin-bottom:2px}.result-area__model-info .result-area__model-desc{font-size:.97em}.creative-loader__overlay{position:fixed;z-index:1000;inset:0;background:#1e1b4bd9;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}.creative-loader__center{display:flex;flex-direction:column;align-items:center;gap:2.5rem}.creative-loader__spinner{animation:loader-spin 1.5s linear infinite;filter:drop-shadow(0 0 16px #a78bfa)}@keyframes loader-spin{0%{transform:rotate(-10deg)}to{transform:rotate(350deg)}}.creative-loader__progress{width:220px;margin-top:.5rem}.creative-loader__bar{width:100%;height:8px;background:#312e81;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px #7c3aed33}.creative-loader__bar-inner{height:100%;background:linear-gradient(90deg,#a78bfa,#fbbf24,#34d399,#f472b6,#a78bfa);border-radius:6px;transition:width .5s cubic-bezier(.4,0,.2,1);min-width:8px;max-width:100%}.creative-loader__quote{color:#fff;font-size:1.15rem;font-weight:500;text-align:center;margin-top:1.5rem;text-shadow:0 2px 8px #312e81;letter-spacing:.01em;min-height:2.5em}.creative-loader__sparkles circle{filter:drop-shadow(0 0 8px rgba(255,255,255,.4666666667))}.language-switcher{position:relative}.language-switcher__select{appearance:none;background:#1e293b;border:1px solid #475569;border-radius:6px;color:#f8fafc;font-size:.875rem;font-weight:500;padding:.5rem 2rem .5rem .75rem;min-width:120px;cursor:pointer;transition:all .2s ease;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23cbd5e1' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1rem}.language-switcher__select:hover{border-color:#64748b;background-color:#334155}.language-switcher__select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.language-switcher__select option{background:#1e293b;color:#f8fafc;padding:.5rem}@media (max-width: 767px){.language-switcher__select{min-width:100px;font-size:.8rem;padding:.4rem 1.75rem .4rem .6rem}}.modern-header{position:sticky;top:0;z-index:1000;background:#1e293bf2;backdrop-filter:blur(20px);border-bottom:1px solid rgba(71,85,105,.5);box-shadow:0 4px 20px #00000014}.modern-header__container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:70px}@media (max-width: 767px){.modern-header__container{padding:0 1rem;height:60px}}.modern-header__brand{flex-shrink:0}.modern-header__logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}.modern-header__logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#6366f1,#5b62f3);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 12px #6366f14d}@media (max-width: 767px){.modern-header__logo-icon{width:32px;height:32px;font-size:16px}}.modern-header__logo-text{font-size:1.25rem;font-weight:700;margin:0;background:linear-gradient(135deg,#6366f1,#5b62f3);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}@media (max-width: 767px){.modern-header__logo-text{font-size:1.125rem}}.modern-header__nav{display:flex;align-items:center;gap:1.5rem}@media (max-width: 767px){.modern-header__nav{display:none}}.modern-header__nav-item{display:flex;align-items:center}.modern-header__user-info{display:flex;align-items:center;gap:1rem;padding:.25rem .5rem;background:#1e293b80;border-radius:50px;border:1px solid rgba(71,85,105,.3)}.modern-header__tokens{display:flex;align-items:center;gap:.25rem;background:#6366f11a;padding:4px 8px;border-radius:20px;font-size:.875rem;font-weight:500;color:#6366f1}.modern-header__tokens-icon{font-size:14px}.modern-header__user-avatar{width:32px;height:32px;border-radius:50%;background:#6366f1;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;overflow:hidden}.modern-header__user-avatar img{width:100%;height:100%;object-fit:cover}.modern-header__logout-btn{background:none;border:none;color:#cbd5e1;cursor:pointer;padding:6px;border-radius:6px;transition:all .2s ease}.modern-header__logout-btn:hover{background:#ef44441a;color:#ef4444}.modern-header__mobile-toggle{display:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;background:none;border:none;cursor:pointer;padding:0;z-index:1001}@media (max-width: 767px){.modern-header__mobile-toggle{display:flex}}.modern-header__mobile-toggle span{display:block;height:2px;width:100%;background:#f8fafc;border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center}.modern-header__mobile-toggle--open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.modern-header__mobile-toggle--open span:nth-child(2){opacity:0;transform:scale(0)}.modern-header__mobile-toggle--open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.modern-header__mobile-menu{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#1e293b;box-shadow:-4px 0 20px #00000026;transition:right .3s cubic-bezier(.4,0,.2,1);z-index:999;overflow-y:auto}@media (max-width: 767px){.modern-header__mobile-menu{width:min(280px,80vw)}}.modern-header__mobile-menu--open{right:0}.modern-header__mobile-content{padding:80px 1.5rem 1.5rem;height:100%;display:flex;flex-direction:column}.modern-header__mobile-user{display:flex;align-items:center;gap:1rem;padding:1rem;background:#6366f10d;border-radius:16px;margin-bottom:1.5rem;border:1px solid rgba(99,102,241,.1)}.modern-header__mobile-avatar{width:48px;height:48px;border-radius:50%;background:#6366f1;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.125rem;overflow:hidden;flex-shrink:0}.modern-header__mobile-avatar img{width:100%;height:100%;object-fit:cover}.modern-header__mobile-user-info{flex:1;min-width:0}.modern-header__mobile-user-name{font-weight:500;color:#f8fafc;margin-bottom:4px;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modern-header__mobile-tokens{display:flex;align-items:center;gap:.25rem;color:#cbd5e1;font-size:.75rem}.modern-header__mobile-tokens-icon{color:#6366f1}.modern-header__mobile-items{flex:1}.modern-header__mobile-item{padding:1rem 0;border-bottom:1px solid rgba(71,85,105,.3)}.modern-header__mobile-item-label{font-size:.875rem;font-weight:500;color:#cbd5e1;margin-bottom:.5rem}.modern-header__mobile-logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:#ef4444;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:auto}.modern-header__mobile-logout:hover{background:#ef444426;transform:translateY(-1px)}.modern-header__backdrop{position:fixed;inset:0;background:#0006;z-index:998;backdrop-filter:blur(4px);opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{to{opacity:1}}.feature-navigation{background:#1e293b;border-bottom:1px solid #475569;padding:0}.feature-navigation__container{max-width:1400px;margin:0 auto;display:flex;gap:0}.feature-navigation__tab{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;text-decoration:none;color:#cbd5e1;background:transparent;border-bottom:3px solid transparent;transition:all .15s ease-in-out;position:relative;font-weight:500;font-size:.875rem}.feature-navigation__tab:hover:not(.feature-navigation__tab--active){color:#f8fafc;background:#6366f10d}.feature-navigation__tab--active{color:#6366f1;background:#6366f11a;border-bottom-color:#6366f1}.feature-navigation__icon{font-size:1.125rem}.feature-navigation__label{white-space:nowrap}@media (max-width: 767px){.feature-navigation{position:fixed;bottom:0;left:0;right:0;z-index:100;border-bottom:none;border-top:1px solid #475569;background:#1e293b;box-shadow:0 -2px 10px #0000001a}.feature-navigation__container{padding:0;max-width:100%;justify-content:space-around}.feature-navigation__tab{flex-direction:column;padding:.25rem .5rem;gap:2px;min-width:0;flex:1;border-bottom:none;border-top:3px solid transparent;min-height:60px}.feature-navigation__tab:hover:not(.feature-navigation__tab--active){background:#6366f10d}.feature-navigation__tab--active{background:#6366f11a;border-top-color:#6366f1;border-bottom-color:transparent}.feature-navigation__icon{font-size:20px;margin-bottom:2px}.feature-navigation__label{font-size:10px;font-weight:500;text-align:center;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}}@media (max-width: 400px){.feature-navigation__label{display:none}.feature-navigation__tab{min-height:50px;padding:.25rem}.feature-navigation__icon{font-size:24px}}@media (min-width: 768px) and (max-width: 1023px){.feature-navigation__container{padding:0 1.5rem}.feature-navigation__tab{padding:.5rem 1.5rem}}.app-page{min-height:100vh;background:#0f172a;display:flex;flex-direction:column}.app-page__main{flex:1;max-width:1400px;margin:0 auto;width:100%;padding:2rem}@media (max-width: 767px){.app-page__main{padding:.5rem}}.app-page__grid{display:grid;grid-template-columns:400px 1fr;gap:2rem;height:100%;align-items:start}@media (max-width: 767px){.app-page__grid{grid-template-columns:1fr;gap:1.5rem}}@media (min-width: 768px) and (max-width: 1023px){.app-page__grid{grid-template-columns:350px 1fr;gap:1.5rem}}.app-page__sidebar{position:sticky;top:6rem;height:fit-content}@media (max-width: 767px){.app-page__sidebar{position:static}}.app-page__content{min-height:500px;display:flex;flex-direction:column;gap:2rem}.app-page__gallery .image-gallery__header-title{font-size:1.125rem;font-weight:600}.app-page__gallery .image-gallery__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}@media (max-width: 767px){.app-page__gallery .image-gallery__grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}}.app-page__gallery .image-gallery__item-image img{height:150px;object-fit:cover}@media (max-width: 767px){.app-page__gallery .image-gallery__item-image img{height:120px}}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;border:1px solid transparent;border-radius:.5rem;font-weight:500;text-decoration:none;cursor:pointer;transition:.3s ease-in-out;white-space:nowrap;user-select:none}.btn:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:#6366f1;color:#fff;border-color:#6366f1}.btn--primary:hover:not(:disabled){background:#5b62f3;border-color:#5b62f3}.btn--secondary{background:#475569;color:#f8fafc;border-color:#475569}.btn--secondary:hover:not(:disabled){background:#64748b;border-color:#64748b}.btn--outline{background:transparent;color:#6366f1;border-color:#6366f1}.btn--outline:hover:not(:disabled){background:#6366f1;color:#fff}.btn--ghost{background:transparent;color:#f8fafc;border-color:transparent}.btn--ghost:hover:not(:disabled){background:#334155}.btn--danger{background:#ef4444;color:#fff;border-color:#ef4444}.btn--danger:hover:not(:disabled){background:#eb1515;border-color:#eb1515}.btn--sm{padding:.25rem .5rem;font-size:.875rem;min-height:2rem}.btn--md{padding:.5rem 1rem;font-size:1rem;min-height:2.5rem}.btn--lg{padding:1rem 1.5rem;font-size:1.125rem;min-height:3rem}.btn--full-width{width:100%}.btn--loading .btn__content{opacity:.7}.btn__icon{display:flex;align-items:center}.btn__icon svg{width:1em;height:1em}.btn__icon--left{margin-right:-.25rem}.btn__icon--right{margin-left:-.25rem}.btn__spinner{position:absolute;display:flex;align-items:center;justify-content:center}.btn__spinner svg{width:1em;height:1em}.btn__content{transition:opacity .2s ease}.token-usage-overview{display:flex;flex-direction:column;gap:1.5rem;position:relative}.token-usage-overview__loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fffc;border-radius:12px;z-index:1;font-weight:500;color:var(--text-secondary)}.token-usage-overview__cards{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (max-width: 768px){.token-usage-overview__cards{grid-template-columns:1fr;gap:1rem}}.token-card{background:var(--surface-primary);border:1px solid var(--border-light);border-radius:12px;padding:1.5rem;transition:all .2s ease;display:flex;flex-direction:column;min-height:280px}.token-card--primary{border-left:4px solid #6366f1}.token-card--secondary{border-left:4px solid #64748b}.token-card--active{box-shadow:0 4px 12px #0000001a;border-color:#6366f1;background:linear-gradient(135deg,var(--surface-primary) 0%,rgba(99,102,241,.02) 100%)}.token-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-shrink:0}.token-card__plan{display:flex;flex-direction:column;gap:.5rem}.token-card__plan-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);line-height:1.3}.token-card__plan-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;background:var(--surface-secondary);color:var(--text-secondary);border-radius:16px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;width:fit-content}.token-card__priority{display:flex;align-items:center;flex-shrink:0}.token-card__priority-badge{padding:.375rem .875rem;background:linear-gradient(135deg,#10b981,#22c55e);color:#fff;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #10b9814d}.token-card__content{display:flex;flex-direction:column;gap:1.25rem;flex:1}.token-card__main-content{flex:1;display:flex;flex-direction:column;justify-content:center}.token-card__actions{display:flex;gap:.75rem;margin-top:auto;padding-top:1rem}.token-card__notice{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:8px;font-size:.875rem;margin-top:auto}.token-card__notice-icon{font-size:1rem}.token-card__notice-text{color:#3b82f6;font-weight:500}.token-usage{display:flex;flex-direction:column;gap:1.25rem;text-align:center}.token-usage__numbers{display:flex;flex-direction:column;align-items:center;gap:.5rem}.token-usage__remaining{font-size:3rem;font-weight:700;color:var(--text-primary);line-height:1}.token-usage__total{font-size:1rem;color:var(--text-secondary);font-weight:500}.token-progress{display:flex;flex-direction:column;gap:.5rem}.token-progress__bar{width:100%;height:8px;background:var(--surface-secondary);border-radius:4px;overflow:hidden}.token-progress__fill{height:100%;background:linear-gradient(90deg,#6366f1,#5b62f3);border-radius:4px;transition:width .3s ease}.token-progress__text{font-size:.875rem;color:var(--text-secondary);font-weight:500}.token-balance{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.token-balance--compact{gap:.75rem}.token-balance__amount{display:flex;flex-direction:column;align-items:center;gap:.5rem}.token-balance__number{font-size:3rem;font-weight:700;color:var(--text-primary);line-height:1}.token-balance__label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.token-balance__rate{display:flex;justify-content:center}.token-balance__price{padding:.5rem 1rem;background:var(--surface-secondary);color:var(--text-secondary);border-radius:8px;font-size:.875rem;font-weight:600}.token-stats{display:flex;flex-direction:column;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-light)}.token-stats__compact{gap:.5rem;padding-top:.75rem}.token-stat{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.token-stat__label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.token-stat__value{font-size:.875rem;color:var(--text-primary);font-weight:600}.token-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:8px;font-size:.875rem}.token-warning__icon{font-size:1rem}.token-warning__text{color:#f59e0b;font-weight:500}@media (max-width: 768px){.token-usage-overview{gap:1rem}.token-usage-overview__cards{grid-template-columns:1fr}.token-card{padding:1.25rem;min-height:auto}.token-card__header{flex-direction:column;gap:.75rem;align-items:flex-start}.token-card__priority{align-self:flex-end}.token-usage__remaining,.token-balance__number{font-size:2.5rem}}@media (max-width: 480px){.token-card{padding:1rem}.token-usage__remaining,.token-balance__number{font-size:2rem}}.billing-section{margin-bottom:4rem}.billing-section__title{font-size:1.25rem;font-weight:600;color:#f8fafc;margin-bottom:2rem;text-align:center}.billing-history{background:#1e293b;border:1px solid #475569;border-radius:.75rem;overflow:hidden}.billing-history__loading,.billing-history__empty{padding:3rem;text-align:center;color:#cbd5e1;font-size:.875rem}.billing-history__header{display:grid;grid-template-columns:1fr 2fr 1fr 1fr;gap:1rem;padding:1.5rem;background:#334155;font-weight:600;color:#f8fafc;font-size:.875rem}.billing-history__row{display:grid;grid-template-columns:1fr 2fr 1fr 1fr;gap:1rem;padding:1.5rem;border-top:1px solid #475569;transition:background-color .15s ease-in-out}.billing-history__row:hover{background:#6366f105}.billing-history__date{color:#cbd5e1;font-size:.875rem}.billing-history__description{color:#f8fafc;font-size:.875rem}.billing-history__amount{color:#f8fafc;font-weight:500;font-size:.875rem}.billing-history__status{font-size:.875rem;font-weight:500;padding:.25rem .5rem;border-radius:.25rem;text-align:center}.billing-history__status--completed{background:#10b9811a;color:#10b981}.billing-history__status--pending{background:#f59e0b1a;color:#f59e0b}.billing-history__status--failed{background:#ef44441a;color:#ef4444}@media (max-width: 767px){.billing-history__header,.billing-history__row{grid-template-columns:1fr;gap:.25rem;text-align:left}.billing-history__header{display:none}.billing-history__row{padding:1rem}.billing-history__date:before{content:"Date: ";font-weight:600;color:#cbd5e1}.billing-history__description:before{content:"Description: ";font-weight:600;color:#cbd5e1}.billing-history__amount:before{content:"Amount: ";font-weight:600;color:#cbd5e1}.billing-history__status:before{content:"Status: ";font-weight:600;color:#cbd5e1}}.token-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem}.token-modal{background:#1e293b;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative}.token-modal__header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid #475569}.token-modal__title{font-size:1.25rem;font-weight:600;color:#f8fafc;margin:0}.token-modal__close{background:none;border:none;font-size:1.5rem;color:#cbd5e1;cursor:pointer;padding:.25rem;border-radius:.5rem;transition:all .15s ease-in-out;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.token-modal__close:hover{background:#334155;color:#f8fafc}.token-modal__content{padding:2rem}.token-modal__footer{display:flex;gap:1rem;padding:2rem;border-top:1px solid #475569;justify-content:flex-end}.token-presets{margin-bottom:2rem}.token-presets__title{font-size:1.125rem;font-weight:500;color:#f8fafc;margin-bottom:1rem}.token-presets__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.token-preset{background:#0f172a;border:2px solid #475569;border-radius:.75rem;padding:1rem;cursor:pointer;transition:all .15s ease-in-out;text-align:center;display:flex;flex-direction:column;justify-content:space-between;min-height:80px}.token-preset:hover{border-color:#6366f1;background:#6366f14d!important}.token-preset--active{border-color:#6366f1;background-color:#6366f11a}.token-preset__content{margin-bottom:.5rem}.token-preset__amount{display:block;font-size:1.125rem;font-weight:700;color:#f8fafc;line-height:1.2;margin-bottom:2px}.token-preset__label{display:block;font-size:.75rem;color:#cbd5e1;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.token-preset__price{display:block;font-size:.875rem;color:#6366f1;font-weight:600;padding:.25rem;background:#6366f11a;border-radius:.25rem;margin-top:auto}.token-custom{margin-bottom:2rem}.token-custom__title{font-size:1.125rem;font-weight:500;color:#f8fafc;margin-bottom:1.5rem}.token-input-group{margin-bottom:1.5rem}.token-input-group .token-input-label{display:block;font-size:.875rem;font-weight:500;color:#f8fafc;margin-bottom:.5rem}.token-input-group .token-input{width:100%;padding:1rem;border:2px solid #475569;border-radius:.5rem;font-size:1rem;color:#f8fafc;background:#1e293b;transition:border-color .15s ease-in-out}.token-input-group .token-input:focus{outline:none;border-color:#6366f1}.token-input-group .token-input::placeholder{color:#cbd5e1}.token-slider-group{margin-bottom:1.5rem}.token-slider-group .token-slider{width:100%;height:6px;border-radius:1rem;background:#475569;outline:none;cursor:pointer}.token-slider-group .token-slider::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:#6366f1;cursor:pointer;border:2px solid #ffffff;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;transition:all .15s ease-in-out}.token-slider-group .token-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.token-slider-group .token-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#6366f1;cursor:pointer;border:2px solid #ffffff;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.token-slider-group .token-slider-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#cbd5e1}.token-summary{background:#0f172a;border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.token-summary__row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem}.token-summary__row:last-child{margin-bottom:0}.token-summary__row--total{margin-top:1rem;padding-top:1rem;border-top:1px solid #475569;font-size:1rem;font-weight:600}.token-summary__value{font-weight:500;color:#f8fafc}.token-summary__total{font-size:1.125rem;font-weight:700;color:#6366f1}.token-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem;font-size:.875rem;color:#ef4444;text-align:center}.token-info{background:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:.5rem;padding:1rem;font-size:.875rem;color:#6366f1;text-align:center}@media (max-width: 767px){.token-modal{margin:1rem;max-height:calc(100vh - 2rem)}.token-modal__header,.token-modal__content,.token-modal__footer{padding:1.5rem}.token-presets__grid{grid-template-columns:repeat(2,1fr)}.token-modal__footer{flex-direction:column}.token-modal__footer button{width:100%}}.billing-skeleton{min-height:100vh;padding:3rem 1.5rem;max-width:1400px;margin:0 auto}.skeleton-section{margin-bottom:4rem}.skeleton-title{height:32px;background:linear-gradient(90deg,#475569 25%,#334155,#475569 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.5rem;width:200px;margin-bottom:2rem}.skeleton-card{background:#1e293b;border:1px solid #475569;border-radius:.75rem;padding:2rem;margin-bottom:3rem}.skeleton-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.skeleton-card__content{margin-top:1.5rem}.skeleton-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.skeleton-stat{display:flex;flex-direction:column;gap:.5rem}.skeleton-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.skeleton-pricing-card{background:#1e293b;border:1px solid #475569;border-radius:.75rem;padding:2rem;display:flex;flex-direction:column;gap:1rem}.skeleton-features{display:flex;flex-direction:column;gap:.5rem;flex:1}.skeleton-history{background:#1e293b;border:1px solid #475569;border-radius:.75rem;overflow:hidden}.skeleton-history-row{display:grid;grid-template-columns:1fr 2fr 1fr 1fr;gap:1rem;padding:1.5rem;border-bottom:1px solid #475569}.skeleton-history-row:last-child{border-bottom:none}.skeleton-text{background:linear-gradient(90deg,#475569 25%,#334155,#475569 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.25rem}.skeleton-text--small{height:16px;width:80px}.skeleton-text--medium{height:20px;width:120px}.skeleton-text--large{height:24px;width:80px}.skeleton-text--xlarge{height:32px;width:100px}.skeleton-button{height:40px;width:120px;background:linear-gradient(90deg,#475569 25%,#334155,#475569 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.5rem}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width: 767px){.billing-skeleton{padding:1.5rem 1rem}.skeleton-pricing-grid{grid-template-columns:1fr}.skeleton-history-row{grid-template-columns:1fr;gap:.25rem}.skeleton-stats{grid-template-columns:repeat(2,1fr)}}.billing-page{min-height:100vh;background:#0f172a}.billing-page__header{background:#1e293b;border-bottom:1px solid #475569;padding:2rem 0;text-align:center}.billing-page__title{font-size:1.5rem;font-weight:700;color:#f8fafc;margin-bottom:.5rem}.billing-page__subtitle{font-size:1rem;color:#cbd5e1;margin:0}.billing-page__container{max-width:1400px;margin:0 auto;padding:3rem 1.5rem}@media (max-width: 767px){.billing-page__container{padding:1.5rem 1rem}}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:2rem 0;flex-wrap:wrap}.pagination__button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid #374151;background:#1f2937;color:#e5e7eb;border-radius:.5rem;font-size:.875rem;font-weight:500;transition:all .2s;cursor:pointer}.pagination__button svg{width:1rem;height:1rem}.pagination__button:hover:not(:disabled){background:#374151;border-color:#4f46e5;color:#a5b4fc}.pagination__button:disabled{opacity:.5;cursor:not-allowed}.pagination__button--prev svg{order:-1}.pagination__button--next svg{order:1}.pagination__pages{display:flex;align-items:center;gap:.25rem}.pagination__page{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border:1px solid #374151;background:#1f2937;color:#e5e7eb;border-radius:.5rem;font-size:.875rem;font-weight:500;transition:all .2s;cursor:pointer}.pagination__page:hover:not(:disabled):not(.pagination__page--active){background:#374151;border-color:#4f46e5;color:#a5b4fc}.pagination__page--active{background:#4f46e5;border-color:#4f46e5;color:#fff;box-shadow:0 0 0 2px #4f46e533}.pagination__page:disabled{opacity:.5;cursor:not-allowed}.pagination__ellipsis{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;color:#6b7280;font-weight:500}@media (max-width: 640px){.pagination__button{padding:.5rem;font-size:0}.pagination__button svg{margin:0}.pagination__page{width:2.25rem;height:2.25rem;font-size:.75rem}.pagination__ellipsis{width:2.25rem;height:2.25rem}}.input-wrapper{display:flex;flex-direction:column;gap:.25rem}.input{background:#1e293b;border:1px solid #475569;border-radius:.5rem;color:#f8fafc;font-family:inherit;font-size:1rem;font-weight:400;outline:none;padding:.5rem 1rem;transition:all .3s ease-in-out;width:100%}.input::placeholder{color:#94a3b8}.input:hover:not(:disabled){border-color:#64748b}.input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.input:disabled{background:#334155;color:#94a3b8;cursor:not-allowed}.input--sm{font-size:.875rem;padding:.25rem .5rem}.input--md{font-size:1rem;padding:.5rem 1rem}.input--lg{font-size:1.125rem;padding:1rem 1.5rem}.input--default{background:#1e293b;border:1px solid #475569}.input--outline{background:transparent;border:2px solid #475569}.input--outline:focus{border-color:#6366f1;background:#1e293b}.input--filled{background:#334155;border:1px solid transparent}.input--filled:focus{background:#1e293b;border-color:#6366f1}.input--error{border-color:#ef4444}.input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.input--full-width{width:100%}.input--with-left-icon{padding-left:2.75rem}.input--with-right-icon,.input--loading{padding-right:2.75rem}.input--disabled{background:#334155;color:#94a3b8;cursor:not-allowed}.input__label{color:#f8fafc;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.input__required{color:#ef4444;margin-left:2px}.input__container{position:relative;display:inline-block;width:100%}.input__icon{position:absolute;top:50%;transform:translateY(-50%);color:#cbd5e1;width:1.25rem;height:1.25rem;pointer-events:none}.input__icon--left{left:.5rem}.input__icon--right{right:.5rem}.input:focus~.input__icon{color:#6366f1}.input--error~.input__icon{color:#ef4444}.input:disabled~.input__icon{color:#94a3b8}.input__icon svg{width:100%;height:100%}.input__spinner{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);pointer-events:none;color:#6366f1;width:1rem;height:1rem}.input__spinner svg{width:100%;height:100%}.input__helper{font-size:.75rem;color:#cbd5e1;margin-top:.25rem}.input__helper--error{color:#ef4444}.input:focus-visible{outline:2px solid #6366f1;outline-offset:2px}@media (max-width: 767px){.input--lg{font-size:1rem;padding:.5rem 1rem}}.page-size-selector{position:relative}.page-size-selector .select{background:#1f2937;border:1px solid #374151;color:#e5e7eb;cursor:pointer;transition:all .2s ease;min-width:120px}.page-size-selector .select:hover:not(:disabled){background:#374151;border-color:#4f46e5;color:#a5b4fc}.page-size-selector .select:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e533}.page-size-selector .select:after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;pointer-events:none}.page-size-selector .select__options{background:#1f2937;border:1px solid #374151;border-radius:.5rem;box-shadow:0 10px 25px -5px #0006,0 10px 10px -5px #0003}.page-size-selector .select__options .select__option{color:#e5e7eb;padding:.75rem 1rem;transition:all .2s ease}.page-size-selector .select__options .select__option:hover{background:#374151;color:#a5b4fc}.page-size-selector .select__options .select__option--selected{background:#4f46e5;color:#fff}.gallery-header{background:#1f2937;border:1px solid #374151;border-radius:.75rem;padding:1.5rem;margin-bottom:3rem}.gallery-header__row{display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.gallery-header__row:not(:last-child){margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #374151}@media (max-width: 767px){.gallery-header__row{flex-direction:column;align-items:stretch;gap:1rem}}.gallery-header__stats{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.gallery-header__stat{display:flex;align-items:center;justify-content:center;gap:.25rem}.gallery-header__stat-label{color:#9ca3af;font-size:.875rem;font-weight:500}.gallery-header__stat-value{color:#e5e7eb;font-size:.875rem;font-weight:600;background:#374151;padding:.25rem .5rem;border-radius:.25rem}.gallery-header__search{flex:1;max-width:400px}.gallery-header__page-size{display:flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap}.gallery-header__page-size-label{color:#9ca3af;font-size:.875rem;font-weight:500}.gallery-header__actions{display:flex;align-items:center;justify-content:center;gap:.5rem}.gallery-header__refresh{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.5rem 1rem;background:#4f46e5;border:1px solid #4f46e5;border-radius:.5rem;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.gallery-header__refresh svg{width:1rem;height:1rem;transition:transform .2s ease}.gallery-header__refresh:hover:not(:disabled){background:#4338ca;border-color:#4338ca;transform:translateY(-1px)}.gallery-header__refresh:hover:not(:disabled) svg{transform:rotate(180deg)}.gallery-header__refresh:disabled{opacity:.5;cursor:not-allowed;transform:none}.gallery-header__refresh:disabled svg{animation:spin 1s linear infinite}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem}@media (max-width: 767px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}}.gallery-grid__loading{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;padding:3rem;color:#9ca3af;background:#1f2937;border:1px solid #374151;border-radius:.75rem;margin-bottom:2rem}.gallery-grid__loading .spinner{width:2rem;height:2rem;border:2px solid #374151;border-top:2px solid #4f46e5;border-radius:50%;animation:spin 1s linear infinite}.gallery-grid__loading span{font-weight:500}.gallery-grid__empty{text-align:center;padding:3rem 0;color:#cbd5e1;background:#1f2937;border:1px solid #374151;border-radius:.75rem;grid-column:1/-1}.gallery-grid__empty h3{color:#e5e7eb;font-size:1.125rem;margin-bottom:.5rem}.gallery-grid__empty p{color:#9ca3af;font-size:.875rem}.gallery-page{min-height:100vh;background:#0f172a;display:flex;flex-direction:column}.gallery-page__main{flex:1;max-width:1400px;margin:0 auto;width:100%;padding:2rem}.gallery-page__loading{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;height:100vh;color:#cbd5e1}.gallery-page__loading .spinner{width:2rem;height:2rem;border:2px solid #475569;border-top:2px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.gallery-page__loading-text{font-weight:500}@media (max-width: 767px){.gallery-page__main{padding:1rem}}.login-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e0f2fe,#e0e7ff);position:relative}.login-page__language-switcher{position:absolute;top:1rem;right:1rem;z-index:10}.login-page__language-switcher .language-switcher__select{background:#ffffffe6;border:1px solid rgba(0,0,0,.1);color:#1e293b;backdrop-filter:blur(10px)}.login-page__language-switcher .language-switcher__select:hover{background:#fffffff2;border-color:#0003}.login-page__language-switcher .language-switcher__select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.login-page__language-switcher .language-switcher__select option{background:#fff;color:#1e293b}.login-page__background{position:absolute;inset:0}.login-page__background--blur{background:#fff6;backdrop-filter:blur(60px)}.login-page__background--gradient{background:linear-gradient(135deg,#9333ea1a,#3b82f61a,#6366f11a)}.login-page__content{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-page__container{width:100%;max-width:28rem}.login-page__brand{text-align:center;margin-bottom:2rem}.login-page__brand-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:var(--border-radius-2xl);margin-bottom:1rem;box-shadow:var(--shadow-lg)}.login-page__brand-icon-inner{width:2rem;height:2rem;background:var(--white);border-radius:var(--border-radius-lg);opacity:.9}.login-page__brand-title{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.login-page__brand-subtitle{color:var(--gray-600);font-size:.875rem}.login-page__card{background:var(--white);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--gray-100);padding:2rem;backdrop-filter:blur(4px)}.login-page__card-header{margin-bottom:1.5rem}.login-page__card-header h2{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.login-page__card-header p{color:var(--gray-600);font-size:.875rem}.login-page__google-login{margin-bottom:1.5rem}.login-page__google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;background:var(--white);border:1px solid #dadce0;border-radius:var(--border-radius-xl);font-size:.875rem;font-weight:500;color:#3c4043;cursor:pointer;transition:var(--transition);box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.login-page__google-button:hover:not(:disabled){background:#f8f9fa;border-color:#c1c7cd;box-shadow:0 1px 3px #3c40434d,0 4px 8px 3px #3c404326}.login-page__google-button:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px #4285f44d}.login-page__google-button:active:not(:disabled){background:#f1f3f4;box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.login-page__google-button:disabled{opacity:.6;cursor:not-allowed;background:#f8f9fa}.login-page__google-button span{font-family:Google Sans,Roboto,Arial,sans-serif;color:#3c4043}.login-page__google-icon{flex-shrink:0}.login-page__signup{margin-top:1.5rem;text-align:center}.login-page__signup p{color:var(--gray-600);font-size:.875rem}.login-page__features{margin-top:2rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}.login-page__features-item{padding:.75rem}.login-page__features-item-icon{width:2rem;height:2rem;border-radius:var(--border-radius-lg);margin:0 auto .5rem;display:flex;align-items:center;justify-content:center}.login-page__features-item-icon--ai{background:linear-gradient(135deg,#a855f7,#3b82f6)}.login-page__features-item-icon--styles{background:linear-gradient(135deg,#3b82f6,#6366f1)}.login-page__features-item-icon--quality{background:linear-gradient(135deg,#6366f1,#a855f7)}.login-page__features-item-icon .icon-inner{width:1rem;height:1rem;background:var(--white);border-radius:.125rem}.login-page__features-item-label{font-size:.75rem;color:var(--gray-600);font-weight:500}.payment-status{min-height:100vh;background:#0f172a;display:flex;align-items:center;justify-content:center;padding:1.5rem}.payment-status__container{max-width:600px;width:100%}.payment-status__content{background:#1e293b;border-radius:1rem;padding:4rem;text-align:center;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.payment-status__content--success{border-top:4px solid #10b981}.payment-status__content--failed{border-top:4px solid #ef4444}.payment-status__loader{text-align:center;background:#1e293b;border-radius:1rem;padding:4rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.payment-status__loader h2{margin:1.5rem 0 1rem;color:#f8fafc;font-size:1.25rem}.payment-status__loader p{margin:0;color:#cbd5e1;font-size:1rem}.payment-status__icon{font-size:4rem;margin-bottom:1.5rem;line-height:1}.payment-status__title{font-size:1.5rem;font-weight:700;color:#f8fafc;margin-bottom:1.5rem}.payment-status__message{font-size:1.125rem;color:#cbd5e1;margin-bottom:3rem;line-height:1.5}.payment-status__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.payment-status__actions .button{min-width:150px}.spinner{width:40px;height:40px;border:4px solid #475569;border-top:4px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@media (max-width: 767px){.payment-status{padding:1rem}.payment-status__content,.payment-status__loader{padding:2rem}.payment-status__title{font-size:1.25rem}.payment-status__message{font-size:1rem}.payment-status__actions{flex-direction:column}.payment-status__actions .button{width:100%}}.file-upload{width:100%}.file-upload__zone{border:2px dashed #475569;border-radius:.75rem;background:#334155;position:relative;cursor:pointer;transition:all .15s ease-in-out;overflow:hidden}.file-upload__zone:hover:not(.file-upload__zone--disabled){border-color:#6366f1;background:#6366f10d}.file-upload__zone--dragging{border-color:#6366f1;background:#6366f11a;transform:scale(1.02)}.file-upload__zone--disabled{opacity:.5;cursor:not-allowed;background:#334155}.file-upload__zone--has-file{border-style:solid;border-color:#10b981}.file-upload__input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.file-upload__placeholder{padding:2rem;text-align:center;min-height:200px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem}.file-upload__icon{font-size:2.25rem;opacity:.6}.file-upload__text{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.25rem}.file-upload__text strong{font-size:1.125rem;font-weight:600;color:#f8fafc}.file-upload__text span{font-size:.875rem;color:#cbd5e1}.file-upload__formats{font-size:.75rem;color:#94a3b8;padding:.25rem .5rem;background:#1e293b;border-radius:.5rem}.file-upload__loading{padding:2rem;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;min-height:200px}.file-upload__loading span{color:#cbd5e1;font-size:.875rem}.file-upload__spinner{width:32px;height:32px;border:3px solid #475569;border-top:3px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.file-upload__preview{position:relative;min-height:200px}.file-upload__preview:hover .file-upload__preview-overlay{opacity:1}.file-upload__preview-image{width:100%;height:200px;object-fit:cover;border-radius:.75rem}.file-upload__preview-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease-in-out;border-radius:.75rem}.file-upload__preview-overlay span{color:#fff;font-size:.875rem;font-weight:500}.file-upload__file-info{position:absolute;bottom:.5rem;left:.5rem;right:.5rem;background:#000c;padding:.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:space-between}.file-upload__file-info span{color:#fff;font-size:.75rem}.file-upload__file-name{font-weight:500;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-upload__file-size{opacity:.8}.portrait-creator-page{min-height:100vh;background:#0f172a;display:flex;flex-direction:column}.portrait-creator-page__loading{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;height:100vh;background:#0f172a}.portrait-creator-page__loading .spinner{width:32px;height:32px;border:3px solid #475569;border-top:3px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.portrait-creator-page__loading-text{color:#cbd5e1;font-size:.875rem}.portrait-creator-page__main{flex:1;padding:2rem}.portrait-creator-page__container{max-width:1400px;margin:0 auto;width:100%}.portrait-creator-page__grid{display:grid;grid-template-columns:400px 1fr;gap:2rem;align-items:start}@media (max-width: 767px){.portrait-creator-page__grid{grid-template-columns:1fr;gap:1.5rem}}.portrait-creator-page__sidebar{display:flex;flex-direction:column;gap:1.5rem}.portrait-creator-page__content{min-height:600px;display:flex;flex-direction:column;gap:1.5rem}.portrait-creator-page__section{background:#1e293b;border-radius:.75rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.portrait-creator-page__section-title{font-size:1.125rem;font-weight:600;color:#f8fafc;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #475569}.portrait-creator-page__file-upload,.portrait-creator-page__form-group{margin-bottom:1rem}.portrait-creator-page__label{display:block;font-size:.875rem;font-weight:500;color:#f8fafc;margin-bottom:.5rem}.portrait-creator-page__textarea{width:100%;min-height:100px;padding:.5rem 1rem;border:1px solid #475569;border-radius:.5rem;background:#334155;color:#f8fafc;font-size:.875rem;line-height:1.5;resize:vertical;transition:border-color .15s ease-in-out}.portrait-creator-page__textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.portrait-creator-page__textarea:disabled{opacity:.5;cursor:not-allowed;background:#334155}.portrait-creator-page__textarea::placeholder{color:#94a3b8}.portrait-creator-page__gender-tabs{display:flex;gap:.25rem;margin-bottom:1rem}.portrait-creator-page__gender-tab{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.5rem 1rem;border:1px solid #475569;border-radius:.5rem;background:#334155;color:#cbd5e1;cursor:pointer;transition:all .15s ease-in-out;font-size:.875rem;font-weight:500}.portrait-creator-page__gender-tab:hover:not(.portrait-creator-page__gender-tab--active){border-color:#6366f1;color:#f8fafc}.portrait-creator-page__gender-tab--active{border-color:#6366f1;background:#6366f11a;color:#6366f1}.portrait-creator-page__templates{margin-bottom:1rem}.portrait-creator-page__template-grid{display:grid;grid-template-columns:1fr 1fr;gap:.25rem}.portrait-creator-page__template-button{padding:.5rem;border:1px solid #475569;border-radius:.5rem;background:#334155;color:#cbd5e1;cursor:pointer;transition:all .15s ease-in-out;font-size:.75rem;text-align:left}.portrait-creator-page__template-button:hover:not(:disabled){border-color:#6366f1;background:#6366f10d;color:#f8fafc}.portrait-creator-page__template-button:disabled{opacity:.5;cursor:not-allowed}.portrait-creator-page__error{background:#ef44441a;color:#ef4444;padding:.5rem 1rem;border-radius:.5rem;border:1px solid rgba(239,68,68,.3);font-size:.875rem;margin-bottom:1rem}.portrait-creator-page__generate{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #475569}.portrait-creator-page__cost{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;font-size:.875rem}.portrait-creator-page__cost span:first-child{color:#cbd5e1}.portrait-creator-page__cost span:last-child{color:#6366f1;font-weight:600}.portrait-creator-page__result{background:#1e293b;border-radius:.75rem;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;min-height:400px;display:flex;align-items:center;justify-content:center}.portrait-creator-page__generating{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;text-align:center}.portrait-creator-page__generating h3{color:#f8fafc;font-size:1.25rem;margin:0}.portrait-creator-page__generating p{color:#cbd5e1;font-size:.875rem;margin:0}.portrait-creator-page__spinner{width:48px;height:48px;border:4px solid #475569;border-top:4px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.portrait-creator-page__success{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;width:100%}.portrait-creator-page__result-image{max-width:100%;max-height:400px;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.portrait-creator-page__result-actions{display:flex;align-items:center;justify-content:center;gap:1rem}.portrait-creator-page__placeholder{display:flex;flex-direction:column;gap:1rem;height:100%;min-height:400px}.portrait-creator-page__preview-showcase{display:flex;flex-direction:column;height:100%;gap:1rem}.portrait-creator-page__showcase-header{text-align:center;margin-bottom:.5rem}.portrait-creator-page__showcase-header h3{color:#f8fafc;font-size:1.125rem;font-weight:600;margin:0;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.portrait-creator-page__large-previews{display:flex;gap:1rem;flex:1;min-height:0}.portrait-creator-page__large-preview{position:relative;flex:1;border-radius:.75rem;overflow:hidden;box-shadow:0 4px 20px #00000026;transition:all .3s ease;border:2px solid transparent;background:#1e293b}.portrait-creator-page__large-preview:hover{transform:translateY(-2px);box-shadow:0 8px 30px #6366f140;border-color:#6366f14d}.portrait-creator-page__large-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.portrait-creator-page__large-preview:hover .portrait-creator-page__large-image{transform:scale(1.02)}.portrait-creator-page__original-pip{position:absolute;top:.5rem;left:.5rem;width:130px;height:130px;border-radius:.5rem;overflow:hidden;border:3px solid rgba(255,255,255,.9);box-shadow:0 2px 12px #0006;transition:all .3s ease;background:#ffffff1a;backdrop-filter:blur(4px)}.portrait-creator-page__original-pip:before{content:"Original";position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.75rem;color:#fff;background:#000c;padding:2px 6px;border-radius:.25rem;white-space:nowrap;opacity:0;transition:opacity .3s ease;pointer-events:none;font-weight:500}.portrait-creator-page__original-pip:hover:before{opacity:1}.portrait-creator-page__pip-image{width:100%;height:100%;object-fit:cover}.portrait-creator-page__mini-cta{text-align:center;padding:.5rem}.portrait-creator-page__mini-cta span{color:#cbd5e1;font-size:.875rem;font-weight:500;opacity:.8}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@media (max-width: 767px){.portrait-creator-page__placeholder{padding:1rem;min-height:300px}.portrait-creator-page__large-previews{flex-direction:column;gap:.5rem}.portrait-creator-page__large-preview{height:200px}.portrait-creator-page__original-pip{width:50px;height:50px;top:.25rem;left:.25rem;border-width:2px}.portrait-creator-page__original-pip:before{bottom:-18px;font-size:10px}}.portrait-creator-page__steps{display:flex;flex-direction:column;gap:1rem;align-items:center}.portrait-creator-page__step{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;color:#cbd5e1}.portrait-creator-page__step-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#6366f1;color:#fff;border-radius:50%;font-size:.75rem;font-weight:700}.conversations-list{display:flex;flex-direction:column;height:100%;overflow:hidden}.conversations-list__header{padding:1rem;border-bottom:1px solid var(--gray-700);background:var(--gray-800);display:flex;justify-content:space-between;align-items:center;gap:.5rem}.conversations-list__title{font-size:1.125rem;font-weight:600;color:var(--white);margin:0;flex:1}.conversations-list__new-button{flex-shrink:0}.conversations-list__content{flex:1;overflow:hidden;display:flex;flex-direction:column}.conversations-list__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:.75rem;color:var(--gray-400)}.conversations-list__loading .spinner{width:1.5rem;height:1.5rem;border:2px solid var(--gray-700);border-top:2px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}.conversations-list__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--gray-400);gap:1rem}.conversations-list__empty-icon{font-size:3rem;opacity:.5}.conversations-list__empty-title{font-size:1.125rem;font-weight:600;color:var(--gray-300)}.conversations-list__empty-subtitle{font-size:.875rem;margin-bottom:.5rem}.conversations-list__empty-button{margin-top:.5rem}.conversations-list__items{flex:1;overflow-y:auto;overflow-x:hidden}.conversations-list__items::-webkit-scrollbar{width:4px}.conversations-list__items::-webkit-scrollbar-track{background:var(--gray-800)}.conversations-list__items::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:2px}.conversations-list__items::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.conversations-list__item{display:flex;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--gray-700);cursor:pointer;transition:all .2s ease;background:var(--gray-800)}.conversations-list__item:hover{background:var(--gray-750)}.conversations-list__item--active{border-left:4px solid var(--primary-hover)}.conversations-list__item--active .conversations-list__item-title{color:var(--primary-100);font-weight:600}.conversations-list__item--active .conversations-list__item-date{color:var(--primary-200)}.conversations-list__item--active:hover{border-left-color:var(--primary-400)}.conversations-list__item-content{flex:1;min-width:0}.conversations-list__item-title{font-size:.875rem;font-weight:500;color:var(--gray-200);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversations-list__item-date{font-size:.75rem;color:var(--gray-400)}.conversations-list__item-delete{background:none;border:none;color:var(--gray-500);cursor:pointer;padding:.25rem;border-radius:.25rem;font-size:.875rem;opacity:0;transition:all .2s ease}.conversations-list__item-delete:hover{background:var(--red-900);color:var(--red-400)}.conversations-list__item:hover .conversations-list__item-delete{opacity:1}.conversations-list__error{background:var(--red-900);color:var(--red-100);padding:.75rem 1rem;margin:.5rem;border-radius:.5rem;font-size:.875rem;display:flex;justify-content:space-between;align-items:center}.conversations-list__error-close{background:none;border:none;color:var(--red-300);cursor:pointer;padding:.25rem;border-radius:.25rem}.conversations-list__error-close:hover{background:var(--red-800)}@media (max-width: 768px){.conversations-list__header{padding:.75rem}.conversations-list__items{max-height:150px}.conversations-list__item{padding:.5rem .75rem}.conversations-list__item-title{font-size:.8rem}.conversations-list__item-date{font-size:.7rem}}.message-bubble{margin-bottom:1rem;width:100%;display:block;position:relative}.message-bubble:hover .message-bubble__actions,.message-bubble:hover .message-bubble__meta{opacity:1;visibility:visible}.message-bubble--user{display:flex;justify-content:flex-end}.message-bubble--user .message-bubble__wrapper{max-width:100%}.message-bubble--user .message-bubble__content{background:#334155;color:#f8fafc;border-radius:.75rem;padding:.5rem 1rem;font-size:1rem;line-height:1.5;margin-left:auto;border:1px solid transparent;transition:all .15s ease-in-out}.message-bubble--user .message-bubble__actions{justify-content:flex-end;margin-right:0}.message-bubble--assistant{margin-right:20%}.message-bubble--assistant .message-bubble__wrapper{max-width:100%}.message-bubble--assistant .message-bubble__content{background:transparent;color:#f8fafc;border-radius:.75rem;padding:.5rem 1rem;font-size:1rem;line-height:1.5;border:1px solid transparent;transition:all .15s ease-in-out}.message-bubble--streaming .message-bubble__content{background:#6366f10d;border-color:#6366f133}.message-bubble__wrapper{position:relative}.message-bubble__content{word-wrap:break-word;overflow-wrap:break-word;position:relative}.message-bubble__text{margin:0}.message-bubble__cursor{display:inline-block;background:currentColor;width:2px;height:1.2em;margin-left:2px;animation:blink 1s infinite;vertical-align:baseline;position:relative;top:.1em}.message-bubble__actions{position:absolute;top:50%;right:-60px;transform:translateY(-50%);opacity:0;visibility:hidden;transition:all .15s ease-in-out;display:flex;align-items:center;gap:2px;background:#1e293b;border:1px solid #475569;border-radius:.75rem;padding:4px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;z-index:10}.message-bubble--user .message-bubble__actions{right:auto;left:-60px}.message-bubble__meta{position:absolute;bottom:-20px;left:16px;opacity:0;visibility:hidden;transition:all .15s ease-in-out;font-size:.75rem;color:#94a3b8;white-space:nowrap;box-shadow:0 1px 2px #0000000d;z-index:5}.message-bubble--user .message-bubble__meta{right:auto;left:0}.message-bubble__tokens{display:inline-flex;align-items:center;gap:4px}.message-bubble__tokens-icon{width:12px;height:12px;opacity:.7}.message-bubble .markdown-paragraph{margin:0 0 .5rem}.message-bubble .markdown-paragraph:last-child{margin-bottom:0}.message-bubble .markdown-list{margin:.5rem 0;padding-left:1.5rem}.message-bubble .markdown-list--ordered{list-style-type:decimal}.message-bubble .markdown-list:not(.message-bubble .markdown-list--ordered){list-style-type:disc}.message-bubble .markdown-list-item{margin:.25rem 0;line-height:1.5}.message-bubble .markdown-heading{font-weight:600;margin:1rem 0 .5rem;line-height:1.4}.message-bubble .markdown-heading--1{font-size:1.25rem;border-bottom:1px solid #475569;padding-bottom:.25rem}.message-bubble .markdown-heading--2{font-size:1.125rem}.message-bubble .markdown-heading--3{font-size:1rem;font-weight:600}.message-bubble .markdown-heading:first-child{margin-top:0}.message-bubble .markdown-blockquote{border-left:3px solid #64748b;margin:.5rem 0;padding:.25rem 0 .25rem .5rem;background:#3341554d;border-radius:0 .25rem .25rem 0;font-style:italic;color:#cbd5e1}.message-bubble .markdown-strong{font-weight:600}.message-bubble .markdown-em{font-style:italic}.message-bubble .markdown-link{color:#6366f1;text-decoration:none;transition:all .15s ease-in-out}.message-bubble .markdown-link:hover{color:#5b62f3;text-decoration:underline}.message-bubble .inline-code{background:#64748b1a;color:#f8fafc;padding:2px 4px;border-radius:.25rem;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.9em;border:1px solid rgba(100,116,139,.15)}.message-bubble pre{margin:.5rem 0!important;border-radius:.5rem!important;overflow:hidden!important;font-size:.875rem!important}.message-bubble pre:first-child{margin-top:0!important}.message-bubble pre:last-child{margin-bottom:0!important}@media (max-width: 768px){.message-bubble--user,.message-bubble--assistant{margin-left:0;margin-right:0}.message-bubble__actions{position:static;opacity:1;visibility:visible;margin-top:.25rem;justify-content:flex-start;transform:none;background:transparent;border:none;box-shadow:none;padding:0}.message-bubble__meta{position:static;opacity:1;visibility:visible;margin-top:.25rem;background:transparent;border:none;box-shadow:none;padding:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@media print{.message-bubble__actions{display:none!important}.message-bubble__content{box-shadow:none!important;border:1px solid #ccc!important}.message-bubble--user .message-bubble__content{background:#f5f5f5!important;color:#000!important}}.streaming-indicator{padding:.5rem 0;margin-left:1rem}.streaming-indicator__content{display:flex;align-items:center;gap:.5rem}.streaming-indicator__dots{display:flex;gap:.2rem}.streaming-indicator__dot{width:.4rem;height:.4rem;background:var(--primary-500);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.streaming-indicator__dot:nth-child(1){animation-delay:-.32s}.streaming-indicator__dot:nth-child(2){animation-delay:-.16s}.streaming-indicator__dot:nth-child(3){animation-delay:0s}.streaming-indicator__text{font-size:.75rem;color:var(--gray-400);font-style:italic}@keyframes bounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}@media (max-width: 768px){.streaming-indicator{margin-left:.5rem}.streaming-indicator__text{font-size:.7rem}.streaming-indicator__dot{width:.35rem;height:.35rem}}.message-list{height:100%;overflow:hidden;display:flex;flex-direction:column;padding:0 calc((100% - 840px)/2);overflow-y:auto;overflow-x:hidden}.message-list--empty{justify-content:center;align-items:center}.message-list__content{flex:1;padding:1rem 1.5rem}.message-list__content::-webkit-scrollbar{width:6px}.message-list__content::-webkit-scrollbar-track{background:#334155}.message-list__content::-webkit-scrollbar-thumb{background:#64748b;border-radius:3px}.message-list__content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.message-list__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;height:100%}.message-list__empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.3}.message-list__empty-title{font-size:1.25rem;font-weight:600;color:var(--gray-400);margin-bottom:.5rem}.message-list__empty-subtitle{font-size:1rem;color:var(--gray-500)}.message-list__streaming{position:relative}@media (max-width: 768px){.message-list__content{padding:.5rem 1rem}.message-list__empty{padding:1.5rem}.message-list__empty-icon{font-size:3rem}.message-list__empty-title{font-size:1.125rem}.message-list__empty-subtitle{font-size:.875rem}}.chat-settings-modal{position:fixed;inset:0;z-index:1050;display:flex;align-items:center;justify-content:center;padding:1.5rem}.chat-settings-modal__backdrop{position:absolute;inset:0;background:#00000080;backdrop-filter:blur(4px)}.chat-settings-modal__content{position:relative;background:#1e293b;border:1px solid #475569;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;max-width:500px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.chat-settings-modal__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #475569;background:#0f172a}.chat-settings-modal__title{font-size:1.25rem;font-weight:600;color:#f8fafc;margin:0}.chat-settings-modal__close{background:none;border:none;color:#cbd5e1;cursor:pointer;padding:.25rem;border-radius:.25rem;font-size:1.125rem;line-height:1;transition:.15s ease-in-out}.chat-settings-modal__close:hover{background:#334155;color:#f8fafc}.chat-settings-modal__body{flex:1;padding:1.5rem;overflow-y:auto}.chat-settings-modal__body::-webkit-scrollbar{width:4px}.chat-settings-modal__body::-webkit-scrollbar-track{background:#0f172a}.chat-settings-modal__body::-webkit-scrollbar-thumb{background:#64748b;border-radius:2px}.chat-settings-modal__body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.chat-settings-modal__section{margin-bottom:2rem}.chat-settings-modal__section:last-child{margin-bottom:0}.chat-settings-modal__label{display:block;font-size:.875rem;font-weight:600;color:#f8fafc;margin-bottom:.5rem}.chat-settings-modal__select,.chat-settings-modal__input{width:100%;margin-bottom:.5rem}.chat-settings-modal__description{font-size:.75rem;color:#cbd5e1;line-height:1.4}.chat-settings-modal__footer{padding:1.5rem;border-top:1px solid #475569;background:#0f172a;display:flex;justify-content:flex-end}.chat-settings-modal__save{min-width:100px}@media (max-width: 768px){.chat-settings-modal{padding:1rem}.chat-settings-modal__content{max-height:90vh}.chat-settings-modal__header{padding:1rem}.chat-settings-modal__title{font-size:1.125rem}.chat-settings-modal__body{padding:1rem}.chat-settings-modal__section{margin-bottom:1.5rem}.chat-settings-modal__footer{padding:1rem}}@media (max-width: 480px){.chat-settings-modal{padding:.5rem}.chat-settings-modal__content{max-height:95vh}}.chat-input-area{background:#1e293b;border-top:1px solid #475569;padding:.5rem 1.5rem 1.5rem}.chat-input-area__config-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:0 .25rem}.chat-input-area__model-info{display:flex;align-items:center;gap:1.5rem}.chat-input-area__info-item{display:flex;align-items:center;gap:.25rem;cursor:pointer}.chat-input-area__info-label{color:#cbd5e1;font-size:.75rem;font-weight:500}.chat-input-area__info-value{color:#f8fafc;font-size:.875rem;font-weight:600}.chat-input-area__settings-btn{background:none;border:none;color:#94a3b8;cursor:pointer;padding:.25rem;border-radius:.25rem;font-size:.875rem;line-height:1;transition:.15s ease-in-out;opacity:.6}.chat-input-area__settings-btn:hover{background:#0f172a;color:#cbd5e1;opacity:1;transform:rotate(90deg)}.chat-input-area__container{background:#0f172a;border:1px solid #475569;border-radius:1rem;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;transition:.15s ease-in-out}.chat-input-area__container:focus-within{border-color:#475569;box-shadow:none}.chat-input-area__input-wrapper{flex:1;min-width:0}.chat-input-area__textarea{width:100%;background:transparent;border:none;outline:none;color:#f8fafc;font-size:1rem;line-height:1.5;resize:none;overflow-y:auto;min-height:1.5rem;max-height:120px;font-family:inherit}.chat-input-area__textarea::placeholder{color:#94a3b8}.chat-input-area__textarea:disabled{opacity:.6;cursor:not-allowed}.chat-input-area__textarea::-webkit-scrollbar{width:3px}.chat-input-area__textarea::-webkit-scrollbar-track{background:transparent}.chat-input-area__textarea::-webkit-scrollbar-thumb{background:#64748b;border-radius:2px}.chat-input-area__send-button{background:#475569;border:none;color:#fff;cursor:pointer;width:2rem;height:2rem;border-radius:50%;font-size:1rem;font-weight:700;line-height:1;transition:.15s ease-in-out;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-input-area__send-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.chat-input-area__send-button--ready{background:#6366f1}.chat-input-area__send-button--ready:hover:not(:disabled){background:#3438ed;transform:scale(1.05);box-shadow:0 2px 8px #6366f14d}.chat-input-area__footer{margin-top:.25rem;padding:0 .25rem;display:flex;justify-content:center}.chat-input-area__hint{font-size:.75rem;color:#94a3b8;opacity:.8}@media (max-width: 768px){.chat-input-area{padding:.5rem 1rem}.chat-input-area__config-bar{margin-bottom:.25rem}.chat-input-area__model-info{gap:1rem}.chat-input-area__info-item{gap:4px;cursor:pointer}.chat-input-area__info-label{font-size:10px}.chat-input-area__info-value{font-size:.75rem}.chat-input-area__container{padding:.5rem;border-radius:.75rem}.chat-input-area__textarea{font-size:.875rem}.chat-input-area__send-button{width:1.75rem;height:1.75rem;font-size:.875rem}.chat-input-area__footer{margin-top:2px}.chat-input-area__hint{font-size:10px}}@media (max-width: 480px){.chat-input-area{padding:.5rem}.chat-input-area__model-info{flex-direction:column;align-items:flex-start;gap:.25rem}.chat-input-area__info-item{gap:.25rem;cursor:pointer}}.chat-area{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--gray-900)}.chat-area__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-700);background:var(--gray-850);min-height:60px}.chat-area__title{font-size:1.125rem;font-weight:600;color:var(--white);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;margin-right:1rem}.chat-area__messages{flex:1;overflow:hidden;position:relative}.chat-area__input{padding:1rem 1.5rem;border-top:1px solid #475569;background:#1e293b;display:flex;flex-direction:column;gap:.5rem}.chat-area__config-info{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}.chat-area__config-labels{display:flex;align-items:center;gap:1rem}.chat-area__config-badge{display:flex;align-items:center;gap:.25rem;background:#0f172a;border:1px solid #475569;border-radius:.5rem;padding:.25rem .5rem;font-size:.75rem}.chat-area__config-badge-label{color:#cbd5e1;font-weight:500}.chat-area__config-badge-value{color:#f8fafc;font-weight:600;background:#6366f1;color:#fff;padding:2px .25rem;border-radius:.25rem;font-size:.75rem}.chat-area__settings-button{background:#0f172a;border:1px solid #475569;border-radius:.5rem;padding:.25rem;cursor:pointer;font-size:1rem;transition:.15s ease-in-out;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.chat-area__settings-button:hover{background:#334155;border-color:#64748b;transform:rotate(90deg)}.chat-area__context-info{padding:.5rem 1.5rem;background:var(--gray-800);border-top:1px solid var(--gray-700);font-size:.75rem;color:var(--gray-400);text-align:center}.chat-area__error-banner{background:var(--red-900);color:var(--red-100);padding:.75rem 1.5rem;font-size:.875rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--red-700)}.chat-area__error-banner-close{background:none;border:none;color:var(--red-300);cursor:pointer;padding:.25rem;border-radius:.25rem}.chat-area__error-banner-close:hover{background:var(--red-800)}.chat-area__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:var(--gray-400)}.chat-area__loading .spinner{width:2rem;height:2rem;border:2px solid var(--gray-700);border-top:2px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}.chat-area__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:2rem}.chat-area__empty-content{text-align:center;max-width:400px}.chat-area__empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.chat-area__empty-title{font-size:1.5rem;font-weight:600;color:var(--gray-300);margin-bottom:.5rem}.chat-area__empty-subtitle{font-size:1rem;color:var(--gray-400);margin-bottom:2rem}.chat-area__error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:2rem}.chat-area__error-content{text-align:center;max-width:400px}.chat-area__error-icon{font-size:4rem;margin-bottom:1rem;opacity:.7}.chat-area__error-title{font-size:1.25rem;font-weight:600;color:var(--red-400)}@media (max-width: 768px){.chat-area__header{padding:.75rem 1rem;min-height:50px}.chat-area__title{font-size:1rem}.chat-area__input{padding:.5rem 1rem}.chat-area__config-info{padding:.25rem 0}.chat-area__config-labels{gap:.5rem}.chat-area__config-badge{padding:2px .25rem;font-size:10px}.chat-area__config-badge-value{padding:1px 4px;font-size:10px}.chat-area__settings-button{width:1.75rem;height:1.75rem;font-size:.875rem}.chat-area__context-info{padding:.5rem 1rem;font-size:.7rem}.chat-area__error-banner{padding:.5rem 1rem;font-size:.8rem}}.chat-page{min-height:100vh;background:#0f172a;display:flex;flex-direction:column}.chat-page__loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:#0f172a;color:#fff;gap:1rem}.chat-page__loading .spinner{width:2rem;height:2rem;border:2px solid #475569;border-top:2px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.chat-page__loading-text{font-size:1.125rem;color:#64748b}.chat-page__main{flex:1;padding:0;overflow:hidden}.chat-page__grid{display:grid;grid-template-columns:250px 1fr;height:calc(100vh - 120px);overflow:hidden}@media (max-width: 768px){.chat-page__grid{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:calc(100vh - 140px)}}.chat-page__sidebar{background:var(--gray-800);border-right:1px solid var(--gray-700);overflow:hidden;display:flex;flex-direction:column}@media (max-width: 768px){.chat-page__sidebar{max-height:200px;border-right:none;border-bottom:1px solid var(--gray-700)}}.chat-page__content{background:var(--gray-900);overflow:hidden;display:flex;flex-direction:column;position:relative}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{to{transform:rotate(360deg)}}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}* :focus-visible{outline:none;outline-offset:0}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{margin:0;font-weight:inherit;font-size:inherit}p{margin:0}button{background:none;border:none;padding:0;margin:0;cursor:pointer;font-family:inherit;font-size:inherit;line-height:inherit}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;background:transparent;border:none;outline:none;margin:0;padding:0}a{color:inherit;text-decoration:none}table{border-collapse:collapse;border-spacing:0}fieldset{border:none;margin:0;padding:0}legend{padding:0}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}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;margin:0;padding:0;background-color:#0f172a;color:#f8fafc;line-height:1.5;overflow-x:hidden;text-rendering:optimizeLegibility;-webkit-font-feature-settings:"kern" 1;font-feature-settings:"kern" 1;font-kerning:normal}.spinner{width:1rem;height:1rem;border:2px solid transparent;border-top:2px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-column{display:flex;flex-direction:column}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hidden{display:none!important}.invisible{visibility:hidden}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.grid{display:grid}.w-full{width:100%}.w-auto{width:auto}.h-full{height:100%}.h-auto{height:auto}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#1e293b;border-radius:4px}::-webkit-scrollbar-thumb{background:#475569;border-radius:4px;transition:background-color .2s ease}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}::-webkit-scrollbar-corner{background:#1e293b}*{scrollbar-width:thin;scrollbar-color:#475569 #1e293b}::selection{background-color:#6366f133;color:inherit}::-moz-selection{background-color:#6366f133;color:inherit}input,textarea,select{width:100%;padding:.5rem 1rem;border:1px solid #475569;border-radius:.5rem;font-size:.875rem;transition:border-color .15s ease-in-out}input:focus,textarea:focus,select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}input:disabled,textarea:disabled,select:disabled{background-color:#0f172a;color:#94a3b8;cursor:not-allowed}input::placeholder,textarea::placeholder,select::placeholder{color:#64748b}button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;transition:all .15s ease-in-out;cursor:pointer;border:none;text-decoration:none;background-color:#6366f1;color:#fff}button:disabled{opacity:.6;cursor:not-allowed}button:hover:not(:disabled){background-color:#5b62f3}button:active:not(:disabled){background-color:#4f46e5}button.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;transition:all .15s ease-in-out;cursor:pointer;border:none;text-decoration:none;background-color:#1e293b;color:#e2e8f0}button.btn-secondary:disabled{opacity:.6;cursor:not-allowed}button.btn-secondary:hover:not(:disabled){background-color:#334155}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{outline:none}button:focus:not(:focus-visible),input:focus:not(:focus-visible),textarea:focus:not(:focus-visible),select:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){*{text-shadow:none!important;box-shadow:none!important}}.card{background-color:#fff;border:1px solid #475569;border-radius:.75rem;box-shadow:0 1px 2px #0000000d;padding:1.5rem}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}:root{--primary-color: #9333ea;--primary-hover: #7c3aed;--secondary-color: #3b82f6;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--info-color: #06b6d4;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--white: #ffffff;--black: #000000;--border-radius: .5rem;--border-radius-lg: .75rem;--border-radius-xl: 1rem;--border-radius-2xl: 1.5rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition: all .2s ease-in-out}
