:root{--bg: #0a0b10;--bg-surface: #12141c;--bg-elevated: #1a1d28;--bg-glass: rgba(26, 29, 40, .82);--bg-glass-light: rgba(40, 44, 60, .65);--border: rgba(255, 255, 255, .06);--border-bright: rgba(255, 255, 255, .12);--text: #e8e9ee;--text-dim: #9195a4;--text-muted: #5c6070;--accent: #6366f1;--accent-hover: #818cf8;--accent-glow: rgba(99, 102, 241, .2);--accent-glow-strong: rgba(99, 102, 241, .35);--green: #22c55e;--green-dim: rgba(34, 197, 94, .12);--red: #ef4444;--red-dim: rgba(239, 68, 68, .1);--amber: #f59e0b;--amber-dim: rgba(245, 158, 11, .1);--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow: 0 8px 32px rgba(0, 0, 0, .45);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .6);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.55;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100dvh;overflow:hidden}#app{min-height:100dvh;display:flex;flex-direction:column}.screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}.passcode-screen{background:radial-gradient(ellipse at 50% 30%,rgba(99,102,241,.1) 0%,var(--bg) 70%)}.landing-screen{position:relative;overflow:hidden;justify-content:center;align-items:stretch;padding:0}.landing-overlay{position:absolute;inset:0;background:linear-gradient(115deg,#080a108a 14%,#080a1024 42%,#080a1057),radial-gradient(circle at 18% 24%,rgba(99,102,241,.28),transparent 32%),radial-gradient(circle at 84% 20%,rgba(251,191,36,.18),transparent 26%);z-index:1}.landing-grid{position:absolute;inset:0;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.15fr;grid-template-rows:1.1fr .95fr 1fr;gap:14px;padding:18px;z-index:0;transform:scale(1.02)}.landing-tile{position:relative;min-height:0;perspective:1600px}.landing-tile.hero{grid-column:span 2;grid-row:span 2}.landing-tile.tall{grid-row:span 2}.landing-tile.wide{grid-column:span 2}.landing-tile.square{grid-column:span 1;grid-row:span 1}.landing-tile-shell{position:relative;width:100%;height:100%;border-radius:28px;overflow:hidden;transition:transform .9s cubic-bezier(.22,1,.36,1),box-shadow .3s ease;box-shadow:0 18px 48px #00000052}.landing-tile.is-flipped .landing-tile-shell{transform:rotateY(8deg) scale(1.01)}.landing-tile-face{position:absolute;inset:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform-style:preserve-3d;transition:opacity .75s ease,transform .9s cubic-bezier(.22,1,.36,1)}.landing-tile-face.front{opacity:1;transform:rotateY(0) scale(1)}.landing-tile-face.back{opacity:0;transform:rotateY(-92deg) scale(.98)}.landing-tile.is-flipped .landing-tile-face.front{opacity:0;transform:rotateY(92deg) scale(.98)}.landing-tile.is-flipped .landing-tile-face.back{opacity:1;transform:rotateY(0) scale(1)}.landing-tile-face:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#090b1147,#090b1103 45%)}.landing-tile-face img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1.08) saturate(1.08) contrast(1.02)}.landing-tile-label{position:absolute;left:14px;bottom:14px;z-index:2;padding:.3rem .65rem;border-radius:999px;background:#080a1094;border:1px solid rgba(255,255,255,.16);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:#fffffff0;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.landing-panel{position:relative;z-index:2;width:min(520px,calc(100% - 2rem));margin:auto 0 auto 6vw;padding:2rem 1.85rem 1.4rem;border-radius:28px;background:#0d10185c;border:1px solid rgba(255,255,255,.18);box-shadow:0 24px 90px #0000003d;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.landing-kicker{color:#b6b8ff;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.75rem}.landing-logo{font-size:clamp(2.35rem,4vw,3.35rem);margin-bottom:.75rem}.landing-headline{font-size:clamp(2rem,3.2vw,3.1rem);line-height:1.02;letter-spacing:-.045em;margin:0 0 .95rem;max-width:11ch}.landing-copy{color:var(--text-dim);font-size:.98rem;line-height:1.7;max-width:48ch}.landing-style-pills{display:flex;gap:.55rem;flex-wrap:wrap;margin:1.2rem 0 1.4rem}.landing-style-pills span{padding:.32rem .72rem;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#ffffffe0;font-size:.77rem}.landing-login-buttons{align-items:flex-start;margin-top:0}.landing-error{margin-top:.9rem;text-align:left}.passcode-screen .logo{font-size:2rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.35rem}.passcode-screen .tagline{color:var(--text-dim);font-size:.8rem;margin-bottom:2rem;letter-spacing:.04em;text-transform:uppercase}.passcode-screen form{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:320px;background:var(--bg-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:1.75rem}.passcode-screen input{padding:.7rem 1rem;background:var(--bg);border:1px solid var(--border-bright);border-radius:var(--radius-sm);color:var(--text);font-size:.9375rem;outline:none;transition:border-color .2s}.passcode-screen input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.passcode-screen button[type=submit]{padding:.7rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.passcode-screen button[type=submit]:hover{background:var(--accent-hover)}.passcode-screen button[type=submit]:active{transform:scale(.98)}.passcode-screen .error{color:var(--red);font-size:.8rem;text-align:center}.legal-links{display:flex;gap:1rem;margin-top:.8rem;justify-content:center;flex-wrap:wrap}.legal-links a,.profile-link{color:var(--text-dim);text-decoration:none;font-size:.8rem}.legal-links a:hover,.profile-link:hover{color:var(--accent);text-decoration:underline}.logo{font-size:1rem;font-weight:700;letter-spacing:-.02em}.logo span{color:var(--accent)}.icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);font-size:1rem;cursor:pointer;transition:all .15s}.icon-btn:hover{background:var(--bg-glass);color:var(--text)}.mode-toggle{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:20px;color:var(--text-dim);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.02em}.mode-toggle:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.mode-icon{font-size:.85rem}.error-banner{width:100%;max-width:560px;padding:.6rem .85rem;background:var(--red-dim);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);color:#fca5a5;font-size:.8125rem;display:flex;align-items:center;gap:.5rem;animation:toastIn .3s ease-out;margin-bottom:.75rem;overflow:hidden;position:relative}.error-banner:after{content:"";position:absolute;bottom:0;left:0;height:2px;background:#ef444480;animation:toastCountdown 8s linear forwards}.error-banner.floating{position:absolute;top:1rem;left:50%;transform:translate(-50%);z-index:50;max-width:400px}.error-banner button{background:none;border:none;color:#fca5a5;cursor:pointer;font-size:1.1rem;padding:0 .2rem;line-height:1;margin-left:auto}.generating-overlay{position:absolute;inset:0;background:#0a0b10cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;z-index:5}.gen-spinner{width:40px;height:40px;border:3px solid var(--border-bright);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.gen-label{color:var(--text);font-size:.9rem;font-weight:500}.placeholder{color:var(--text-muted);font-size:.85rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.placeholder-icon{font-size:2.5rem;opacity:.3}.mini-spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.options-grid{display:flex;flex-direction:column;gap:.5rem}.options-grid.inline{margin-top:.5rem}.option-card{padding:.75rem .85rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);position:relative;transition:all .2s}.option-card:hover{border-color:var(--border-bright);background:#1a1d28f2}.option-card.recommended{border-color:var(--accent-glow-strong);background:#6366f10f}.option-card.recommended:hover{border-color:var(--accent)}.badge{position:absolute;top:.5rem;right:.5rem;font-size:.6rem;font-weight:700;background:var(--accent);color:#fff;padding:.15rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.option-card h4{margin:0 0 .2rem;font-size:.85rem;font-weight:600;color:var(--text);padding-right:3.5rem}.option-card .why{margin:0 0 .45rem;font-size:.75rem;color:var(--text-dim);line-height:1.4}.option-card .tool-tag{display:inline-block;font-size:.625rem;color:var(--text-muted);background:var(--bg);padding:.12rem .35rem;border-radius:4px;margin-bottom:.45rem}.gen-btn{width:100%;padding:.4rem 0;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.gen-btn:hover{background:var(--accent-hover)}.gen-btn:active{transform:scale(.98)}.gen-btn:disabled{opacity:.4;cursor:not-allowed}.recheck-card{width:100%;max-width:560px;margin-top:.75rem;padding:.65rem .85rem;border-radius:var(--radius);animation:fadeSlide .3s ease-out;display:flex;align-items:flex-start;gap:.6rem}.recheck-card.pass{background:var(--green-dim);border:1px solid rgba(34,197,94,.18)}.recheck-card.warn{background:var(--amber-dim);border:1px solid rgba(245,158,11,.18)}.recheck-card.fail{background:var(--red-dim);border:1px solid rgba(239,68,68,.18)}.recheck-card.loading{background:var(--bg-elevated);border:1px solid var(--border)}.recheck-icon{font-size:1.15rem;flex-shrink:0;margin-top:.05rem}.recheck-body{flex:1;min-width:0}.recheck-title{font-size:.8rem;font-weight:600;margin-bottom:.1rem}.recheck-card.pass .recheck-title{color:var(--green)}.recheck-card.warn .recheck-title{color:var(--amber)}.recheck-card.fail .recheck-title{color:var(--red)}.recheck-card.loading .recheck-title{color:var(--text-dim)}.recheck-feedback{font-size:.725rem;color:var(--text-dim);line-height:1.4}.recheck-score{font-size:.675rem;color:var(--text-muted);margin-top:.2rem}.recheck-retry-btn{margin-top:.45rem;padding:.3rem .75rem;font-size:.72rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;transition:opacity .2s,transform .15s}.recheck-retry-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.recheck-retry-btn:disabled{opacity:.5;cursor:not-allowed}.recheck-card.fail .recheck-retry-btn{background:linear-gradient(135deg,#ef4444,#dc2626)}.recheck-card.warn .recheck-retry-btn{background:linear-gradient(135deg,#f59e0b,#d97706)}.voice-screen{padding:0;align-items:stretch;justify-content:flex-start;overflow:hidden;background:var(--bg);display:flex;flex-direction:column;height:100dvh;max-height:100dvh;min-height:0}.voice-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;height:48px;flex-shrink:0;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:30}.voice-header .header-actions{display:flex;gap:.5rem;align-items:center}.voice-canvas{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:.75rem;background:radial-gradient(ellipse at 50% 40%,rgba(99,102,241,.04) 0%,var(--bg) 70%)}.voice-image-wrap{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.voice-image-wrap img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius)}.voice-placeholder{color:var(--text-muted);font-size:1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;animation:fadeSlide .5s ease-out}.voice-placeholder .placeholder-icon{font-size:4rem;opacity:.25}.voice-controls{flex-shrink:0;z-index:30;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.4rem 1rem .5rem;background:var(--bg-surface);border-top:1px solid var(--border);transition:all .3s;max-height:180px;overflow:hidden}.voice-transcript{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;border:1px solid var(--border-bright);color:var(--text);font-size:.85rem;animation:fadeSlide .2s ease-out;max-width:400px;text-align:center}.voice-wave{color:var(--red);animation:pulse 1s infinite;font-size:.7rem}.voice-refinements{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center}.voice-refinements button{padding:.35rem .7rem;background:var(--bg-glass);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-bright);border-radius:20px;font-size:.75rem;color:var(--text-dim);cursor:pointer;transition:all .15s}.voice-refinements button:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.voice-bottom-row{display:flex;align-items:center;gap:.75rem;width:100%;max-width:720px}.voice-input-row{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.voice-recheck-inline{flex-shrink:0;max-width:280px}.voice-recheck-inline .recheck-card{padding:.4rem .6rem;font-size:.7rem}.voice-recheck-inline .recheck-feedback{max-height:2.5em;overflow:hidden;text-overflow:ellipsis}.voice-recheck-inline .recheck-score{display:none}.voice-recheck-inline .recheck-retry-btn{font-size:.65rem;padding:.2rem .55rem}.voice-text-input{flex:1;min-width:0;padding:.65rem 1rem;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:24px;color:var(--text);font-size:.875rem;outline:none;transition:border-color .2s}.voice-text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.voice-text-input::placeholder{color:var(--text-muted)}.mic-btn{width:52px;height:52px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 20px var(--accent-glow-strong);flex-shrink:0}.mic-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.mic-btn:active{transform:scale(.95)}.mic-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.mic-btn.listening{background:var(--red);box-shadow:0 0 30px #ef444466;animation:micPulse 1.5s infinite}.mic-waves{display:flex;gap:3px;align-items:center;height:20px}.mic-waves span{width:3px;background:#fff;border-radius:2px;animation:wave .8s ease-in-out infinite}.mic-waves span:nth-child(1){height:8px;animation-delay:0s}.mic-waves span:nth-child(2){height:16px;animation-delay:.15s}.mic-waves span:nth-child(3){height:8px;animation-delay:.3s}.voice-send{width:40px;height:40px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.voice-send:hover{background:var(--accent-hover)}.voice-send:disabled{opacity:.4}.voice-status{color:var(--text-muted);font-size:.8rem;display:flex;align-items:center;gap:.4rem}.chat-screen{padding:0;align-items:stretch;overflow:hidden;height:100dvh;max-height:100dvh;min-height:0}.chat-screen .header{display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;height:52px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;z-index:20}.chat-screen .header-actions{display:flex;gap:.5rem;align-items:center}.chat-layout{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.chat-thread{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.chat-messages{flex:1;overflow-y:auto;padding:1rem 1rem .5rem;scrollbar-width:thin;scrollbar-color:var(--border-bright) transparent}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.85rem;gap:.5rem}.chat-msg{display:flex;gap:.6rem;margin-bottom:.75rem;animation:fadeSlide .25s ease-out;max-width:720px}.chat-msg.user,.chat-msg.assistant{flex-direction:row}.chat-avatar{width:30px;height:30px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;margin-top:.15rem}.chat-bubble-wrap{flex:1;min-width:0}.chat-bubble{display:inline-block;padding:.55rem .85rem;border-radius:14px;font-size:.8125rem;line-height:1.5;max-width:100%}.chat-msg.user .chat-bubble{background:var(--accent);color:#fff;border-bottom-left-radius:4px}.chat-msg.assistant .chat-bubble{background:var(--bg-elevated);color:var(--text-dim);border-bottom-left-radius:4px}.chat-bubble.typing{display:inline-flex;gap:4px;padding:.65rem .85rem}.chat-bubble.typing .dot{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:dotBounce 1.2s infinite}.chat-bubble.typing .dot:nth-child(2){animation-delay:.15s}.chat-bubble.typing .dot:nth-child(3){animation-delay:.3s}.chat-inline-image{margin-top:.5rem;width:220px;max-width:100%;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.chat-inline-image img{width:100%;height:auto;display:block}.chat-bubble-wrap .options-grid.inline .option-card{background:var(--bg-surface);border-color:var(--border-bright)}.chat-refinements{padding:.5rem 1rem;display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;border-top:1px solid var(--border)}.chat-refinements .label{color:var(--text-muted);font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;margin-right:.3rem}.chat-refinements button{padding:.3rem .6rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:18px;font-size:.75rem;color:var(--text-dim);cursor:pointer;transition:all .15s}.chat-refinements button:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.chat-input{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:var(--bg-surface);border-top:1px solid var(--border)}.chat-attach,.chat-mic{width:38px;height:38px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-dim);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.chat-attach:hover{background:#60a5fa1a;color:#60a5fa;border-color:#60a5fa4d}.chat-attach:disabled{opacity:.5;cursor:not-allowed}.chat-mic:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.chat-mic.listening{background:var(--red-dim);color:var(--red);border-color:#ef44444d;animation:pulse 1.2s infinite}.chat-mic:disabled{opacity:.5;cursor:not-allowed}.chat-input input{flex:1;min-width:0;padding:.6rem .85rem;background:var(--bg);border:1px solid var(--border-bright);border-radius:20px;color:var(--text);font-size:.875rem;outline:none;transition:border-color .2s}.chat-input input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.chat-input input::placeholder{color:var(--text-muted)}.chat-send{width:38px;height:38px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.chat-send:hover{background:var(--accent-hover)}.chat-send:disabled{opacity:.35;cursor:not-allowed}.chat-image-panel{display:none;flex-direction:column;align-items:center;justify-content:center;padding:1rem;overflow-y:auto;position:relative;background:var(--bg-surface);border-left:1px solid var(--border);min-width:0}.chat-image-wrap{position:relative;width:100%;max-width:90%;flex:1;min-height:0;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}.chat-image-wrap img{max-width:100%;max-height:100%;object-fit:contain}.image-actions{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap;justify-content:center}.commit-btn{padding:.5rem 1.1rem;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.commit-btn:hover{background:#16a34a}.commit-btn:active{transform:scale(.97)}.commit-btn:disabled{opacity:.4;cursor:not-allowed}.action-bar{display:flex;gap:.35rem;align-items:center}.action-bar.compact .action-btn{padding:.3rem .5rem;font-size:.7rem}.action-btn{display:flex;align-items:center;gap:.25rem;padding:.35rem .65rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:18px;color:var(--text-dim);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.action-btn:hover{background:var(--bg-glass-light);color:var(--text);border-color:var(--border-bright)}.action-btn:disabled{opacity:.4;cursor:not-allowed}.action-icon{font-size:.85rem}.action-btn.undo-btn:hover{color:var(--amber);border-color:#f59e0b4d}.action-btn.save-btn:hover{color:var(--green);border-color:#22c55e4d}.action-btn.upload-btn:hover{color:#60a5fa;border-color:#60a5fa4d}.action-btn.clear-btn:hover{color:var(--accent);border-color:var(--accent-glow-strong)}.image-actions .action-btn{border-radius:var(--radius-sm)}.hidden-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.mobile-only{display:none!important}.drop-overlay{position:absolute;inset:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#8b5cf626;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px dashed var(--accent);border-radius:var(--radius);color:var(--accent);font-size:1.1rem;font-weight:500;animation:fadeSlide .2s ease}.drop-icon{font-size:2.5rem}.voice-canvas.drag-over,.chat-image-panel.drag-over{outline:2px dashed var(--accent);outline-offset:-4px}.drop-target{cursor:pointer;transition:all .2s;border:2px dashed transparent}.drop-target:hover{border-color:var(--border-bright);background:var(--bg-glass-light)}.drop-hint{display:block;margin-top:.5rem;font-size:.8rem;color:var(--text-dim);opacity:.7}.login-buttons{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem;align-items:center}.google-btn{display:flex;align-items:center;gap:.75rem;padding:.85rem 2rem;border-radius:var(--radius);border:1px solid var(--border-bright);background:var(--bg-elevated);color:var(--text);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.google-btn:hover{background:var(--bg-glass-light);border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.google-btn svg{flex-shrink:0}.login-note{margin-top:1.5rem;font-size:.82rem;color:var(--text-dim);opacity:.7}@media(max-width:1080px){.landing-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(4,minmax(120px,1fr));opacity:.45}.landing-tile.hero,.landing-tile.wide,.landing-tile.tall,.landing-tile.square{grid-column:span 1;grid-row:span 1}.landing-panel{width:min(620px,calc(100% - 2rem));margin:auto}}@media(max-width:720px){.landing-grid{grid-template-columns:1fr;grid-template-rows:repeat(5,minmax(90px,1fr));gap:10px;padding:14px;opacity:.28}.landing-panel{padding:1.4rem 1.1rem 1.1rem;border-radius:22px}.landing-headline{max-width:none;font-size:1.85rem}.landing-copy{font-size:.92rem}}.token-counter{background:var(--bg-glass);border:1px solid var(--border-bright);border-radius:var(--radius-sm);color:var(--accent);font-size:.8rem;font-weight:600;padding:.3rem .65rem;cursor:pointer;transition:all .2s;white-space:nowrap}.token-counter:hover{background:var(--accent-glow);border-color:var(--accent)}.user-avatar{padding:0;width:28px;height:28px;border-radius:50%;overflow:hidden;border:1px solid var(--border-bright)}.user-avatar img{width:100%;height:100%;object-fit:cover}.low-balance-nudge{position:relative;flex-shrink:0;width:100%;text-align:center;padding:.5rem 1rem .65rem;background:linear-gradient(90deg,var(--amber-dim),rgba(245,158,11,.15));border-top:1px solid rgba(245,158,11,.3);color:var(--amber);font-size:.82rem;cursor:pointer;transition:background .2s}.low-balance-nudge:hover{background:#f59e0b33}.low-balance-nudge strong{text-decoration:underline}.modal-overlay{position:fixed;inset:0;z-index:200;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;animation:fadeSlide .2s ease}.modal-card{background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:2rem;width:90%;max-width:400px;box-shadow:var(--shadow-lg);position:relative}.modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-dim);font-size:1.4rem;cursor:pointer;padding:.25rem}.modal-close:hover{color:var(--text)}.modal-card h3{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.modal-balance{color:var(--text-dim);font-size:.9rem;margin-bottom:1.25rem}.modal-balance strong{color:var(--accent)}.modal-packages{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.package-btn{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-radius:var(--radius);border:1px solid var(--border-bright);background:var(--bg-glass);color:var(--text);cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.package-btn:hover{border-color:var(--accent);background:var(--accent-glow)}.package-btn.best{border-color:var(--accent)}.pkg-badge{position:absolute;top:0;right:0;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .6rem;border-radius:0 var(--radius) 0 var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.pkg-amount{font-size:1.05rem;font-weight:600}.pkg-price{font-size:1.1rem;font-weight:700;color:var(--accent)}.modal-note{font-size:.78rem;color:var(--text-muted);text-align:center}.profile-panel{max-width:340px;text-align:center}.profile-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;text-align:left}.profile-avatar-lg{width:56px;height:56px;border-radius:50%;overflow:hidden;background:var(--bg-glass-light);display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0;border:2px solid var(--border-bright)}.profile-avatar-lg img{width:100%;height:100%;object-fit:cover}.profile-info{min-width:0}.profile-info h3{font-size:1.1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-email{font-size:.82rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-stats{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;margin-bottom:1.25rem;background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius)}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-value{font-size:1.8rem;font-weight:700;color:var(--accent);line-height:1}.stat-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.profile-buy-btn{padding:.55rem 1.25rem;border-radius:var(--radius-sm);border:1px solid var(--accent);background:transparent;color:var(--accent);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.profile-buy-btn:hover{background:var(--accent-glow)}.profile-actions{border-top:1px solid var(--border);padding-top:1rem}.profile-actions{display:flex;flex-direction:column;gap:.7rem}.profile-action{width:100%;padding:.65rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:.85rem;cursor:pointer;transition:all .2s}.profile-action:hover{color:var(--red);border-color:#ef44444d;background:var(--red-dim)}@media(min-width:768px){.chat-layout{flex-direction:row}.chat-thread{width:340px;min-width:300px;max-width:340px;border-right:1px solid var(--border)}.chat-image-panel{display:flex;flex:1}.voice-options-overlay .options-grid{flex-direction:row}}@media(min-width:1200px){.chat-thread{width:380px;min-width:340px;max-width:400px}.chat-msg{max-width:100%}}@media(max-width:900px){body{overflow:auto}.voice-screen,.chat-screen{height:100dvh;max-height:none}.voice-header,.chat-screen .header{height:auto;min-height:52px;padding:.55rem .75rem;align-items:flex-start;flex-wrap:wrap;gap:.55rem}.voice-header .header-actions,.chat-screen .header-actions{width:100%;flex-wrap:wrap;justify-content:flex-end;gap:.4rem}.project-name-header{order:3;width:100%;max-width:100%}.action-bar{flex-wrap:wrap;max-width:100%}.action-bar.compact .action-btn,.assets-btn,.token-counter,.mode-toggle{font-size:.72rem;padding:.32rem .55rem}.chat-layout{overflow-y:auto}.chat-image-panel{display:flex;order:-1;min-height:38dvh;border-left:none;border-bottom:1px solid var(--border);padding:.75rem}.chat-image-wrap{width:100%;max-width:100%;min-height:220px}.chat-messages{padding:.8rem .8rem .5rem}.chat-empty,.placeholder{text-align:center;padding:1rem}.chat-input{gap:.4rem;padding:.55rem .65rem calc(.55rem + env(safe-area-inset-bottom))}.voice-canvas{padding:.55rem}.voice-controls{max-height:none;padding:.55rem .75rem calc(.65rem + env(safe-area-inset-bottom))}.voice-bottom-row{flex-direction:column;align-items:stretch;gap:.5rem}.voice-input-row,.voice-recheck-inline{width:100%;max-width:none}.ref-shelf{padding:.45rem .6rem}.modal-card{width:calc(100% - 1rem);max-width:none;padding:1.15rem}.assets-modal,.profile-panel,.context-panel{max-height:88dvh;overflow-y:auto}.mobile-only{display:inline-flex!important}}@media(max-width:720px){.voice-header .logo,.chat-screen .logo{font-size:1rem}.voice-header .header-actions,.chat-screen .header-actions{justify-content:flex-start}.chat-thread{min-height:40dvh}.chat-image-panel{min-height:34dvh}.chat-inline-image{width:180px}.voice-placeholder .placeholder-icon,.placeholder-icon{font-size:2.8rem}.ref-add-btns{width:100%;justify-content:flex-start;flex-wrap:wrap}.asset-upload-area{flex-wrap:wrap}}.context-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .7rem;border-radius:999px;background:var(--bg-glass);border:1px solid var(--border-dim);color:var(--text-muted);font-size:.72rem;cursor:pointer;transition:all .2s;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.4rem}.context-pill:hover{border-color:var(--border-bright);color:var(--text-primary);background:var(--bg-glass-light)}.context-pill.has-context{border-color:#8b5cf659;color:var(--text-secondary);background:#8b5cf614}.context-pill-icon{font-size:.85rem;flex-shrink:0}.context-pill-text{overflow:hidden;text-overflow:ellipsis}.context-panel{max-width:440px;text-align:left}.context-title{margin:0 0 .25rem;font-size:1rem;font-weight:600}.context-subtitle{margin:0 0 1rem;font-size:.75rem;color:var(--text-muted)}.context-label{display:block;font-size:.72rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:.75rem 0 .3rem}.context-input{width:100%;padding:.45rem .6rem;border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-dim);color:var(--text-primary);font-size:.8rem;outline:none}.context-input:focus{border-color:var(--border-bright)}.context-chips{display:flex;flex-wrap:wrap;gap:.3rem;padding:.35rem;border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-dim);min-height:36px;align-items:center}.context-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:999px;font-size:.72rem;background:#8b5cf626;color:#c4b5fd;border:1px solid rgba(139,92,246,.25)}.context-chip.chip-keep{background:#22c55e1f;color:#86efac;border-color:#22c55e40}.context-chip.chip-avoid{background:#ef44441f;color:#fca5a5;border-color:#ef444440}.context-chip button{background:none;border:none;color:inherit;cursor:pointer;font-size:.85rem;line-height:1;padding:0;margin-left:.1rem;opacity:.6}.context-chip button:hover{opacity:1}.context-chip-input{flex:1;min-width:80px;border:none;background:transparent;color:var(--text-primary);font-size:.75rem;outline:none;padding:.15rem .3rem}.context-actions{display:flex;gap:.5rem;margin-top:1rem}.context-save-btn{flex:1;padding:.5rem;border-radius:var(--radius-sm);background:var(--accent);color:#fff;border:none;font-size:.8rem;font-weight:500;cursor:pointer}.context-save-btn:hover{filter:brightness(1.1)}.context-clear-btn{padding:.5rem .75rem;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);border:1px solid var(--border-dim);font-size:.8rem;cursor:pointer}.context-clear-btn:hover{border-color:#ef444466;color:#fca5a5}.context-revert-btn{padding:.5rem .75rem;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);border:1px solid var(--border-dim);font-size:.8rem;cursor:pointer}.context-revert-btn:hover{border-color:#fbbf2466;color:#fde68a}.context-revision{text-align:center;font-size:.65rem;color:var(--text-muted);margin-top:.5rem;opacity:.6}.project-name-header{background:#6366f126;color:var(--accent);border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm);padding:.25rem .75rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.project-name-header:hover{background:#6366f140;border-color:#6366f180}.projects-home-screen{display:flex;flex-direction:column;height:100vh}.projects-home{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;align-items:center;max-width:900px;margin:0 auto;width:100%}.projects-home-title{font-size:1.5rem;font-weight:700;color:var(--text-main);margin-bottom:.25rem}.projects-home-subtitle{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem}.project-create-form{display:flex;gap:.5rem;width:100%;max-width:600px;margin-bottom:2rem;flex-wrap:wrap}.project-name-input,.project-desc-input{flex:1;min-width:160px;padding:.6rem .75rem;background:var(--surface-1);border:1px solid var(--border-dim);border-radius:var(--radius-sm);color:var(--text-main);font-size:.85rem}.project-name-input:focus,.project-desc-input:focus{border-color:var(--accent);outline:none}.project-create-btn{padding:.6rem 1.2rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;cursor:pointer;transition:background .2s;white-space:nowrap}.project-create-btn:hover:not(:disabled){background:var(--accent-hover)}.project-create-btn:disabled{opacity:.5;cursor:default}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;width:100%}.project-card{background:var(--surface-1);border:1px solid var(--border-dim);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color .2s,transform .15s;position:relative}.project-card:hover{border-color:var(--accent);transform:translateY(-2px)}.project-card-thumb{width:100%;height:140px;background:var(--bg-main);overflow:hidden;display:flex;align-items:center;justify-content:center}.project-card-thumb img{width:100%;height:100%;object-fit:cover}.project-card-placeholder{font-size:2.5rem;opacity:.3}.project-card-info{padding:.75rem;display:flex;flex-direction:column;gap:.15rem}.project-card-info strong{font-size:.9rem;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-desc{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-date{font-size:.65rem;color:var(--text-muted);opacity:.6}.project-card-delete{position:absolute;top:.4rem;right:.4rem;background:#0009;color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.85rem;line-height:1;cursor:pointer;opacity:0;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{background:#ef4444cc}.project-switch-modal{max-width:460px;width:90vw}.project-list-compact{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.project-list-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-radius:var(--radius-sm);transition:background .15s}.project-list-item:hover{background:var(--surface-2, rgba(255,255,255,.04))}.project-list-item.active{background:#6366f11a}.project-list-info{display:flex;flex-direction:column;gap:.1rem;overflow:hidden}.project-list-info strong{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-list-desc{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-list-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.project-open-btn{padding:.3rem .7rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer}.project-open-btn:hover{background:var(--accent-hover)}.project-secondary-btn{padding:.3rem .7rem;background:#ffffff0f;color:var(--text-main);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer}.project-secondary-btn:hover{background:#ffffff1f}.project-active-badge{font-size:.7rem;color:var(--accent);font-weight:600;padding:.2rem .5rem;border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm)}.project-create-inline{display:flex;gap:.4rem;margin-bottom:.75rem}.project-create-inline input{flex:1;padding:.5rem .6rem;background:var(--surface-1);border:1px solid var(--border-dim);border-radius:var(--radius-sm);color:var(--text-main);font-size:.8rem}.project-create-inline input:focus{border-color:var(--accent);outline:none}.project-create-inline button{padding:.5rem .8rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer}.project-create-inline button:disabled{opacity:.5}.project-close-btn{width:100%;padding:.6rem;background:transparent;color:var(--text-muted);border:1px solid var(--border-dim);border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:background .2s,color .2s}.project-close-btn:hover{background:#ef44441a;color:#fca5a5;border-color:#ef44444d}.project-gallery-modal{width:min(980px,96vw);max-height:84vh;display:flex;flex-direction:column}.project-gallery-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.project-gallery-header h3{margin:0;font-size:1.05rem;color:#fff}.project-gallery-subtitle{margin-top:4px;color:var(--text-muted);font-size:.82rem}.project-gallery-select{min-width:220px;background:#ffffff14;border:1px solid rgba(255,255,255,.16);color:#fff;padding:8px 10px;border-radius:8px;font-size:.85rem}.project-gallery-empty{padding:40px 0;text-align:center;color:#ffffff80;font-size:.92rem}.project-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;overflow-y:auto;padding:4px}.project-gallery-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.project-gallery-thumb{width:100%;aspect-ratio:1 / 1;border:none;padding:0;background:#00000059;cursor:pointer}.project-gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.project-gallery-meta{padding:10px 12px 6px;display:flex;flex-direction:column;gap:4px}.project-gallery-date{color:var(--text-muted);font-size:.72rem}.project-gallery-name{color:var(--text-main);font-size:.78rem;line-height:1.3;word-break:break-word}.project-gallery-actions{display:flex;gap:8px;padding:0 12px 12px}.project-gallery-actions button{flex:1}.project-versions-modal{width:min(760px,94vw);max-height:84vh;display:flex;flex-direction:column}.project-versions-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.project-versions-header h3{margin:0;font-size:1.05rem;color:#fff}.project-versions-create{display:grid;gap:10px;margin-bottom:14px;padding:14px;border-radius:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1)}.project-versions-create label{font-size:.84rem;font-weight:600;color:var(--text-main)}.project-versions-help,.project-version-meta{color:var(--text-muted);font-size:.78rem}.project-version-note-input{width:100%;background:#ffffff14;border:1px solid rgba(255,255,255,.16);color:#fff;padding:10px 12px;border-radius:10px;font:inherit;resize:vertical}.project-versions-list{display:grid;gap:10px;overflow-y:auto;padding-right:2px}.project-version-card{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.project-version-copy{display:grid;gap:6px;min-width:0}.project-version-row{display:flex;justify-content:space-between;gap:10px;align-items:center}@keyframes fadeSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastCountdown{0%{width:100%}to{width:0%}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes micPulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 14px #ef444400}}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1.3)}}@keyframes dotBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}}.image-settings-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.size-selector{display:flex;align-items:center;gap:1px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:18px;padding:2px}.size-option{padding:.2rem .45rem;border:none;border-radius:16px;background:transparent;color:var(--text-muted);font-size:.65rem;font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.02em;white-space:nowrap}.size-option:hover{color:var(--text-dim)}.size-option.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.assets-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;padding:4px 10px;border-radius:8px;font-size:.82rem;cursor:pointer;transition:background .2s}.assets-btn:hover{background:#ffffff38}.assets-modal{width:540px;max-width:96vw;max-height:80vh;display:flex;flex-direction:column}.assets-modal h3{margin:0 0 12px;font-size:1.1rem;color:#fff}.asset-upload-area{display:flex;gap:8px;margin-bottom:12px;align-items:center}.asset-upload-error{margin:-4px 0 12px;color:var(--red);font-size:.8rem}.asset-type-select{background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#fff;padding:6px 10px;border-radius:8px;font-size:.85rem}.asset-upload-btn{background:#6366f1;color:#fff;border:none;padding:6px 16px;border-radius:8px;cursor:pointer;font-size:.85rem;transition:background .2s}.asset-upload-btn:hover:not(:disabled){background:#818cf8}.asset-upload-btn:disabled{opacity:.5;cursor:wait}.asset-tabs{display:flex;gap:4px;margin-bottom:12px;overflow-x:auto}.asset-tab{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#fff9;padding:4px 12px;border-radius:16px;font-size:.8rem;cursor:pointer;transition:all .2s;white-space:nowrap}.asset-tab.active{background:#6366f140;border-color:#6366f1;color:#fff}.asset-tab:hover:not(.active){background:#ffffff1a;color:#fff}.asset-empty{text-align:center;color:#ffffff73;padding:32px 0;font-size:.9rem}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;overflow-y:auto;max-height:50vh;padding:4px}.asset-card{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s}.asset-card:hover{border-color:#ffffff40}.asset-thumb{width:100%;aspect-ratio:1;overflow:hidden;background:#0000004d;display:flex;align-items:center;justify-content:center}.asset-thumb img{width:100%;height:100%;object-fit:cover}.asset-card-info{padding:6px 8px;display:flex;flex-direction:column;gap:3px}.asset-card-name{font-size:.75rem;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-type-badge{font-size:.65rem;padding:1px 6px;border-radius:8px;text-transform:uppercase;font-weight:600;letter-spacing:.03em;width:fit-content}.badge-logo{background:#eab30833;color:#eab308}.badge-product{background:#6366f133;color:#818cf8}.badge-reference{background:#22c55e33;color:#22c55e}.badge-other{background:#ffffff1a;color:#ffffff8c}.asset-card-actions{display:flex;gap:4px;padding:4px 8px 6px;justify-content:flex-end}.asset-overlay-btn{background:#6366f133;color:#818cf8;border:1px solid rgba(99,102,241,.3);padding:2px 8px;border-radius:6px;font-size:.72rem;cursor:pointer;transition:background .2s}.asset-overlay-btn:hover{background:#6366f159}.asset-delete-btn{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.2);padding:2px 8px;border-radius:6px;font-size:.82rem;cursor:pointer;transition:background .2s}.asset-delete-btn:hover{background:#ef44444d}.ref-shelf{display:flex;align-items:center;gap:8px;padding:6px 16px;background:#0f0f1999;border-bottom:1px solid rgba(255,255,255,.06);min-height:56px;flex-shrink:0;transition:background .2s,border-color .2s}.ref-shelf.ref-drag-over{background:#6366f11f;border-bottom-color:#6366f166;outline:2px dashed rgba(99,102,241,.5);outline-offset:-2px}.ref-shelf-mini{min-height:32px;padding:4px 16px;justify-content:center}.ref-shelf-collapsed{background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.25);padding:4px 14px;border-radius:12px;font-size:.75rem;cursor:pointer;transition:background .2s}.ref-shelf-collapsed:hover{background:#6366f140}.ref-drop-hint{display:flex;align-items:center;gap:8px;flex:1;padding:4px 8px;border:1.5px dashed rgba(255,255,255,.12);border-radius:8px;min-height:40px;justify-content:center;transition:border-color .2s}.ref-drag-over .ref-drop-hint{border-color:#6366f199}.ref-drop-icon{font-size:1.1rem;opacity:.6}.ref-drop-text{font-size:.72rem;color:#ffffff59;white-space:nowrap}.ref-drag-over .ref-drop-text{color:#a5b4fc}.ref-clear-btn{color:#ef4444b3!important;border-color:#ef444433!important}.ref-clear-btn:hover{background:#ef444426!important;color:#ef4444!important}.ref-thumbs{display:flex;gap:6px;overflow-x:auto;flex:1;min-width:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.ref-thumb{position:relative;width:44px;height:44px;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.12);flex-shrink:0;cursor:default}.ref-thumb img{width:100%;height:100%;object-fit:cover}.ref-thumb-pdf{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e1e3a,#2a2a4a);color:#e74c3c;font-size:.65rem;font-weight:700;gap:1px}.ref-thumb-pdf-name{font-size:.45rem;color:#fff6;font-weight:400;max-width:38px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ref-thumb-remove{position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:50%;background:#ef4444d9;color:#fff;border:none;font-size:10px;line-height:16px;text-align:center;cursor:pointer;opacity:0;transition:opacity .15s;padding:0}.ref-thumb:hover .ref-thumb-remove{opacity:1}.ref-add-btns{display:flex;gap:4px;flex-shrink:0}.ref-add-btn{background:#ffffff0f;color:#fff9;border:1px solid rgba(255,255,255,.1);padding:4px 10px;border-radius:8px;font-size:.7rem;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}.ref-add-btn:hover{background:#6366f133;color:#a5b4fc}.ref-collapse-btn{font-size:.85rem;padding:2px 8px}.ref-source-picker{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center}.ref-source-list{background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;max-width:460px;width:90%;max-height:400px;overflow-y:auto}.ref-source-list h4{margin:0 0 10px;font-size:.9rem;color:#ffffffd9;display:flex;justify-content:space-between;align-items:center}.ref-source-close{background:none;border:none;color:#ffffff80;font-size:1.2rem;cursor:pointer}.ref-source-empty{color:#ffffff59;text-align:center;padding:24px 0;font-size:.85rem}.ref-source-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}.ref-source-item{border-radius:8px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .15s;background:#ffffff0a}.ref-source-item:hover{border-color:#6366f180;transform:scale(1.03)}.ref-source-item.selected{border-color:#818cf8;opacity:.5;pointer-events:none}.ref-source-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.ref-source-item span{display:block;font-size:.65rem;color:#ffffff80;padding:2px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
