*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color:#4a90a4;--success-color:#7d9c65;--error-color:#d32f2f;--text-size:18px;--text-size-large:22px;--border-radius:12px;--max-width:720px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8f9fa;color:#333;line-height:1.5}.container{max-width:var(--max-width);margin:0 auto;padding:2rem;font-size:var(--text-size)}.hero{text-align:center;margin-bottom:1.5rem}.hero h1{font-size:2rem;margin-bottom:.5rem;color:#2a2a2a}.hero-lead{font-size:1.15rem;color:#4f4f4f;margin:0}.limit-banner{text-align:center;margin-bottom:1.5rem}.limit-banner__compact{font-size:.95rem;color:#4f4f4f;margin:0;padding:.5rem 1rem;background:#f8f9fb;border-radius:8px;display:inline-block}.limit-banner__compact strong{color:var(--primary-color);font-size:1.1rem}.limit-banner__compact--error{background:#fff5f5;color:#c62828}.link-button{background:none;border:none;padding:0;font:inherit;color:var(--primary-color);text-decoration:underline;cursor:pointer}.link-button:hover{color:#3a7a8a}@media (min-width:768px){.upload-actions{flex-direction:row}.upload-btn{flex:1 1}.upload-tips{flex-direction:row;flex-wrap:wrap;gap:.75rem 1.25rem}.upload-tips li{flex:1 1 45%}}.limit-display{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:.75rem 1rem;text-align:center;margin-bottom:1.5rem;font-size:16px;color:#666}.limit-display .unlimited-mode,.limit-display span[style*=\1F389]{background:linear-gradient(135deg,#f0f8f0,#e8f5e8);border:1px solid #c8e6c9;border-radius:20px;padding:8px 16px;color:#2e7d32;font-weight:600;display:inline-block}.reset-time{margin-top:.5rem;font-size:14px;color:#888;font-style:italic}.quality-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:.75rem 1rem;text-align:center;margin-bottom:1.5rem;font-size:14px;color:#856404;line-height:1.4}.upload-area{border:3px dashed #ccc;border-radius:var(--border-radius);padding:3rem 2rem;margin:2rem 0;text-align:center;background:#fafafa;transition:all .3s ease;cursor:pointer}.upload-area:hover{border-color:var(--primary-color);background:#f0f8ff}.upload-icon{font-size:3rem;margin-bottom:1rem;opacity:.7;display:block}.upload-text{font-size:var(--text-size-large);color:#333;line-height:1.6;display:block}.upload-hint{margin-top:1rem;font-size:16px;color:#888;line-height:1.4}.upload-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.upload-btn{border-radius:12px;padding:1rem 2rem;font-size:18px;font-weight:600;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:transform .2s ease,box-shadow .2s ease;min-height:48px}.upload-btn--camera{background:var(--primary-color);color:#fff;box-shadow:0 10px 20px rgba(74,144,164,.25)}.upload-btn--camera:hover{transform:translateY(-2px);box-shadow:0 15px 24px rgba(74,144,164,.35)}.upload-btn--library{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color)}.upload-btn--library:hover{background:#f0f8ff}.upload-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.upload-tips{list-style:none;margin:1.25rem 0 0;padding:0;display:flex;flex-direction:column;gap:.65rem;color:#5a6b79;font-size:.95rem}.upload-tips li{display:flex;gap:.6rem;align-items:flex-start}.upload-tip__icon{font-size:1.1rem;line-height:1.4}.upload-area.drag-over{border-color:var(--primary-color);background:#e6f3ff;transform:scale(1.02)}.error-message{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;padding:1rem;margin-bottom:1.5rem;color:var(--error-color);text-align:center;font-size:16px}.image-preview{text-align:center;margin:2rem 0}.uploaded-image{max-width:100%;max-height:500px;border-radius:var(--border-radius);box-shadow:0 4px 12px rgba(0,0,0,.15);margin-bottom:2rem;cursor:pointer;transition:transform .2s ease}.uploaded-image:hover{transform:scale(1.02)}.processing-message{background:linear-gradient(135deg,var(--primary-color),#6ba5b7);color:#fff;padding:1rem 1.5rem;border-radius:var(--border-radius);margin:1rem auto 1.5rem;max-width:400px;font-size:var(--text-size);font-weight:500;box-shadow:0 2px 8px rgba(74,144,164,.2);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.action-buttons{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:0 auto}.btn-primary{background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);padding:1rem 2rem;font-size:var(--text-size);font-weight:600;cursor:pointer;transition:all .3s ease;min-height:48px}.btn-primary:hover:not(:disabled){background:#3a7a8a;transform:translateY(-2px);box-shadow:0 4px 12px rgba(74,144,164,.3)}.btn-primary:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:var(--border-radius);padding:1rem 2rem;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:48px}.btn-secondary:hover{background:var(--primary-color);color:#fff;transform:translateY(-1px)}.btn-primary:focus,.btn-secondary:focus,.upload-area:focus{outline:2px solid var(--primary-color);outline-offset:2px}.result-display{margin:2rem 0}.result-comparison{margin-bottom:2rem}.simple-before-after{display:flex;flex-direction:column;gap:1.25rem}.simple-before-after__hint{text-align:center;font-size:.95rem;color:#5a6b79;margin:0 0 .5rem;font-weight:500}.simple-before-after__image-wrapper{position:relative;width:100%;max-height:500px;border-radius:var(--border-radius);overflow:hidden;background:#10141a;box-shadow:0 8px 24px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center}.simple-before-after__image{width:100%;height:100%;max-height:500px;object-fit:contain;display:block;cursor:pointer;transition:opacity .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.simple-before-after__image:hover{opacity:.95}.simple-before-after__image:focus{outline:3px solid var(--primary-color);outline-offset:2px}@media (max-width:768px){.simple-before-after__image{cursor:default}}.simple-before-after__label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(0,0,0,.75),transparent);color:#fff;padding:1.5rem 1rem 1rem;font-size:1rem;font-weight:500;text-align:center;pointer-events:none}.simple-before-after__toggle{background:#fff;border:2px solid var(--primary-color);color:var(--primary-color);font-size:18px;font-weight:600;padding:1rem 2rem;border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;text-align:center;font-family:inherit;min-height:48px;max-width:400px;margin:0 auto}.simple-before-after__toggle:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(74,144,164,.3)}.simple-before-after__toggle:active{transform:translateY(0)}.simple-before-after__toggle:focus{outline:3px solid var(--primary-color);outline-offset:2px}.result-actions{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:0 auto}.result-actions .btn-primary{text-decoration:none;display:flex;align-items:center;justify-content:center;gap:.5rem}.result-actions-item{max-width:400px;margin:0 auto;width:100%}.loading{text-align:center;padding:2.5rem 2rem;background:#fff;border-radius:var(--border-radius);margin:2rem 0;box-shadow:0 2px 12px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04)}.loading-content{max-width:500px;margin:0 auto}.modern-spinner{width:64px;height:64px;margin:0 auto 2rem;position:relative}.spinner-ring{position:absolute;width:100%;height:100%;border-radius:50%;border-left:3px solid transparent;border-bottom:3px solid transparent;border-top:3px solid transparent;border-top-color:var(--primary-color);border-right:3px solid transparent;border-right-color:var(--primary-color);animation:spin 1.2s cubic-bezier(.68,-.55,.27,1.55) infinite}.spinner-ring-inner{position:absolute;top:6px;left:6px;right:6px;bottom:6px;border-radius:50%;border-color:#66b3c7 transparent transparent #66b3c7;border-style:solid;border-width:3px;animation:spin 1.8s cubic-bezier(.68,-.55,.27,1.55) infinite reverse;opacity:.6}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.processing-stages{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;padding:0 1rem}.stage-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;transition:all .3s ease;background:#f8f9fa}.stage-item.stage-pending{opacity:.4}.stage-item.stage-active{background:linear-gradient(90deg,rgba(74,144,164,.08),rgba(102,179,199,.08));border:1px solid rgba(74,144,164,.2);animation:stagePulse 2s ease-in-out infinite}.stage-item.stage-completed{background:linear-gradient(90deg,hsla(94,22%,50%,.08),hsla(94,22%,50%,.08));border:1px solid hsla(94,22%,50%,.2)}@keyframes stagePulse{0%,to{transform:scale(1);box-shadow:0 0 0 rgba(74,144,164,0)}50%{transform:scale(1.01);box-shadow:0 2px 8px rgba(74,144,164,.15)}}.stage-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:600;transition:all .3s ease}.stage-pending .stage-icon{background:#e0e0e0;color:#999}.stage-active .stage-icon{background:var(--primary-color);color:#fff;animation:iconPulse 1.5s ease-in-out infinite}.stage-completed .stage-icon{background:var(--success-color);color:#fff}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.stage-icon .checkmark{width:18px;height:18px;animation:checkmarkAppear .4s ease-out}@keyframes checkmarkAppear{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}.stage-label{font-size:15px;color:#333;font-weight:500;flex:1 1;text-align:left}.stage-pending .stage-label{color:#999}.stage-active .stage-label{color:var(--primary-color)}.stage-completed .stage-label{color:#666}.progress-container{margin:1.5rem 0;width:100%}.progress-bar-modern{width:100%;height:10px;background:#e8eef1;margin-bottom:.75rem}.progress-bar-modern,.progress-fill-modern{border-radius:5px;overflow:hidden;position:relative}.progress-fill-modern{height:100%;background:linear-gradient(90deg,var(--primary-color),#5ba4bb,var(--primary-color));background-size:200% 100%;transition:width .4s cubic-bezier(.4,0,.2,1);animation:gradientShift 2s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.progress-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.4),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.progress-info{display:flex;justify-content:space-between;align-items:center;font-size:14px}.progress-percent{color:var(--primary-color);font-weight:600;font-size:15px}.progress-time{color:#888;font-size:13px}.loading-hint{font-size:15px;color:#888;margin-top:1rem;line-height:1.4}@media (max-width:768px){.container{padding:1rem}.upload-area{padding:2rem 1rem}.action-buttons{max-width:100%}.btn-primary,.btn-secondary{min-height:60px;font-size:var(--text-size)}.uploaded-image{max-height:400px}.loading{padding:2rem 1rem}.modern-spinner{width:56px;height:56px;margin-bottom:1.5rem}.processing-stages{padding:0 .5rem;gap:.6rem}.stage-item{padding:.6rem .75rem}.stage-icon{width:24px;height:24px;font-size:12px}.stage-label{font-size:14px}.progress-bar-modern{height:8px}.result-slider__legend{flex-direction:column;align-items:flex-start;gap:.35rem}.before-after__handle{font-size:.7rem;padding:.2rem .45rem}.result-actions{max-width:100%}}.footer{text-align:center;padding:1rem 2rem;margin-top:2rem;color:#666;font-size:14px;border-top:1px solid #e5e5e5;background:#f8f9fa}.footer p{margin:0}.footer .version{font-size:12px;color:#999;margin-top:.25rem;opacity:.7}.language-switcher{display:flex;justify-content:center;align-items:center;gap:0;margin-bottom:1rem;transition:gap .3s cubic-bezier(.4,0,.2,1)}.language-switcher.expanded{gap:.5rem}.lang-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#fff;border:2px solid rgba(0,0,0,.1);border-radius:50%;cursor:pointer;font-size:20px;line-height:1;box-shadow:0 2px 4px rgba(0,0,0,.1);transition:all .3s cubic-bezier(.4,0,.2,1)}.lang-btn.hidden{width:0;height:40px;opacity:0;transform:scale(0);pointer-events:none}.language-switcher.expanded .lang-btn.hidden{width:40px;opacity:1;transform:scale(1);pointer-events:auto}.lang-btn:hover{transform:scale(1.1);border-color:var(--color-primary);box-shadow:0 3px 8px rgba(0,0,0,.15)}.lang-btn.active{background:var(--color-primary)!important;border-color:var(--color-primary)!important;box-shadow:0 3px 10px rgba(74,144,164,.4)!important}.lang-btn.active:hover{transform:scale(1.15)}@media (max-width:768px){.lang-btn{width:44px;height:44px;font-size:22px}.lang-btn.hidden{width:0;height:44px}.language-switcher.expanded .lang-btn.hidden{width:44px}}.custom-prompt-collapsed{width:100%;margin:0}.custom-prompt-collapsed .btn-secondary{width:100%}.btn-with-hint{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.65rem 2rem!important;line-height:1.2}.btn-main-text{font-size:18px;font-weight:600;display:block;line-height:1.2}.btn-hint-text{font-size:12px;font-weight:400;opacity:.75;display:block;line-height:1.2}.custom-prompt-expanded{background:#fff;border:none;border-radius:var(--border-radius);padding:1.5rem;margin:1rem 0;box-shadow:0 4px 12px rgba(0,0,0,.1);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.custom-prompt-title{font-size:18px;font-weight:600;color:#333;margin:0 0 1rem;text-align:center}.custom-prompt-input{width:100%;min-height:90px;padding:1rem;border:2px solid #ddd;border-radius:var(--border-radius);font-family:inherit;font-size:18px;line-height:1.5;resize:vertical;transition:all .2s ease}.custom-prompt-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px rgba(74,144,164,.1)}.char-counter{font-size:14px;color:#999;margin:.5rem 0 1.25rem;text-align:left}.custom-prompt-examples{margin-bottom:1.5rem}.examples-label{font-size:16px;color:#666;display:block;margin-bottom:.75rem}.example-tags-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:.5rem;gap:.5rem}.example-tag{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:var(--border-radius);padding:.4rem .85rem;font-size:14px;font-family:inherit;cursor:pointer;transition:all .2s ease;min-height:36px;display:inline-flex;align-items:center;justify-content:center}.example-tag:hover:not(:disabled){background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 2px 8px rgba(74,144,164,.3)}.example-tag:disabled{opacity:.5;cursor:not-allowed}.custom-prompt-actions{display:flex;flex-direction:column;gap:.75rem}.custom-prompt-actions .btn-primary{width:100%;margin:0}.btn-cancel{width:100%;background:transparent;color:#666;border:2px solid #ddd;border-radius:var(--border-radius);padding:1rem 2rem;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:48px}.btn-cancel:hover:not(:disabled){background:#f5f5f5;border-color:#999;color:#333;transform:translateY(-1px)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.custom-prompt-expanded{padding:1.25rem}.custom-prompt-input,.custom-prompt-title{font-size:18px}.example-tag{font-size:14px;padding:.4rem .85rem;min-height:40px}.btn-cancel,.btn-primary,.btn-secondary,.simple-before-after__toggle,.upload-btn{min-height:60px;font-size:18px}.btn-with-hint{padding:.75rem 2rem!important}.btn-hint-text{font-size:13px}}.help-banner{background:#fff5f5;border:1px solid #f7c8c8;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.help-banner__block{margin:0}.help-banner__block h3{margin-top:0;margin-bottom:.5rem;font-size:1.05rem;color:#c62828}.help-banner__block p{color:#4f5b66;font-size:.95rem;line-height:1.5;margin:0}