@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a12;--surface:#ffffff0a;--surface-hover:#ffffff12;--border:#ffffff14;--border-focus:#a78bfa80;--text:#e2e8f0;--text-muted:#94a3b8;--text-dim:#64748b;--accent-purple:#a78bfa;--accent-blue:#60a5fa;--accent-gradient:linear-gradient(135deg, #a78bfa, #60a5fa);--error:#f87171;--error-bg:#f871711a;--success:#34d399;--radius:16px;--radius-sm:10px;--shadow:0 4px 24px #0006;--transition:.25s cubic-bezier(.4, 0, .2, 1)}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}#root{min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex;position:relative;overflow-x:hidden}.bg-gradient{z-index:0;pointer-events:none;background:radial-gradient(600px 400px at 20% 10%,#a78bfa1f,#0000),radial-gradient(500px 350px at 80% 80%,#60a5fa14,#0000),radial-gradient(300px 300px,#8b5cf60d,#0000);position:fixed;inset:0}.header{z-index:1;text-align:center;padding:2.5rem 1.5rem 1rem;position:relative}.logo{align-items:center;gap:.65rem;margin-bottom:.4rem;display:inline-flex}.logo h1{background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1.6rem;font-weight:700}.tagline{color:var(--text-muted);font-size:.9rem;font-weight:400}.main{z-index:1;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem 2rem;position:relative}.content-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.5rem;display:grid}.left-panel,.right-panel{min-height:350px}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;height:100%;min-height:350px;transition:all var(--transition);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2rem;display:flex}.upload-zone:hover{background:var(--surface-hover);border-color:#a78bfa59}.upload-zone.dragging{border-color:var(--accent-purple);background:#a78bfa14;transform:scale(1.01);box-shadow:0 0 30px #a78bfa26}.upload-zone.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.upload-icon{color:var(--accent-purple);opacity:.7;transition:all var(--transition)}.upload-zone:hover .upload-icon{opacity:1;transform:translateY(-3px)}.upload-title{color:var(--text);font-size:1.1rem;font-weight:600}.upload-subtitle{color:var(--text-muted);font-size:.88rem}.upload-hint{color:var(--text-dim);margin-top:.25rem;font-size:.78rem}.preview-card{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);flex-direction:column;height:100%;animation:.4s fadeSlideIn;display:flex;overflow:hidden}.preview-image-wrapper{background:#0003;flex:1;justify-content:center;align-items:center;min-height:200px;display:flex;overflow:hidden}.preview-image{object-fit:contain;max-width:100%;max-height:300px}.preview-info{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.file-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:65%;font-size:.85rem;font-weight:500;overflow:hidden}.file-size{color:var(--text-dim);font-size:.78rem}.reset-btn{border:none;border-top:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;justify-content:center;align-items:center;gap:.5rem;padding:.7rem;font-family:inherit;font-size:.85rem;display:flex}.reset-btn:hover{background:var(--surface-hover);color:var(--accent-purple)}.reset-btn:disabled{opacity:.4;cursor:not-allowed}.description-panel{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);flex-direction:column;height:100%;min-height:350px;display:flex;overflow:hidden}.description-panel.empty{justify-content:center;align-items:center;display:flex}.empty-state{color:var(--text-dim);flex-direction:column;align-items:center;gap:.75rem;padding:2rem;display:flex}.empty-state p{font-size:.88rem}.panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.panel-header h3{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;display:flex}.panel-header h3 svg{stroke:var(--accent-purple)}.copy-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:8px;align-items:center;gap:.35rem;padding:.35rem .7rem;font-family:inherit;font-size:.78rem;display:inline-flex}.copy-btn:hover{background:var(--surface-hover);color:var(--text);border-color:#a78bfa4d}.copy-btn.copied{border-color:var(--success);color:var(--success)}.error-message{border-radius:var(--radius-sm);background:var(--error-bg);border:1px solid #f8717133;align-items:flex-start;gap:.6rem;margin:1rem 1.25rem;padding:.9rem 1rem;animation:.3s fadeSlideIn;display:flex}.error-message svg{stroke:var(--error);flex-shrink:0;margin-top:1px}.error-message p{color:var(--error);font-size:.85rem;line-height:1.5}.loading-state{flex-direction:column;flex:1;gap:1rem;padding:1.25rem;display:flex}.loading-shimmer{flex-direction:column;gap:.65rem;display:flex}.shimmer-line{background:linear-gradient(90deg,#ffffff0a 0%,#a78bfa14 50%,#ffffff0a 100%) 0 0/200% 100%;border-radius:6px;height:14px;animation:1.5s ease-in-out infinite shimmer}.shimmer-line.long{width:100%}.shimmer-line.medium{width:75%}.shimmer-line.short{width:50%}.loading-text{color:var(--text-muted);align-items:center;gap:.5rem;margin-top:.5rem;font-size:.85rem;display:flex}.dot-pulse{background:var(--accent-purple);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite pulse;display:inline-block}.description-content{flex:1;padding:1.25rem;animation:.5s fadeSlideIn;overflow-y:auto}.description-content p{color:var(--text);margin-bottom:.85rem;font-size:.9rem;line-height:1.75}.description-content p:last-child{margin-bottom:0}.description-content::-webkit-scrollbar{width:5px}.description-content::-webkit-scrollbar-track{background:0 0}.description-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.api-key-section{margin-bottom:.5rem}.settings-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all var(--transition);align-items:center;gap:.45rem;padding:.5rem .85rem;font-family:inherit;font-size:.82rem;display:inline-flex}.settings-toggle:hover{background:var(--surface-hover);color:var(--text)}.settings-toggle .chevron{transition:transform var(--transition)}.settings-toggle.open .chevron{transform:rotate(180deg)}.settings-content{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);margin-top:.75rem;padding:1rem 1.25rem;animation:.3s fadeSlideIn}.settings-content label{color:var(--text-muted);margin-bottom:.5rem;font-size:.82rem;font-weight:500;display:block}.key-input-wrapper{gap:.5rem;display:flex}.key-input-wrapper input{border:1px solid var(--border);color:var(--text);transition:border-color var(--transition);background:#00000040;border-radius:8px;outline:none;flex:1;padding:.6rem .85rem;font-family:inherit;font-size:.85rem}.key-input-wrapper input:focus{border-color:var(--border-focus)}.key-input-wrapper input::placeholder{color:var(--text-dim)}.toggle-visibility{border:1px solid var(--border);width:38px;color:var(--text-dim);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:8px;justify-content:center;align-items:center;display:flex}.toggle-visibility:hover{background:var(--surface-hover);color:var(--text)}.key-hint{color:var(--text-dim);margin-top:.5rem;font-size:.78rem}.key-hint a{color:var(--accent-purple);transition:color var(--transition);font-weight:500;text-decoration:none}.key-hint a:hover{color:var(--accent-blue);text-decoration:underline}.footer{z-index:1;text-align:center;border-top:1px solid var(--border);padding:1.5rem;position:relative}.footer p{color:var(--text-dim);font-size:.78rem}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%,to{background-position:-200% 0}50%{background-position:200% 0}}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@media (width<=768px){.header{padding:2rem 1rem .75rem}.logo h1{font-size:1.35rem}.main{padding:0 1rem 2rem}.content-grid{grid-template-columns:1fr;gap:1rem}.left-panel,.right-panel,.upload-zone{min-height:280px}}
