:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e5e7eb;background:#0f172a}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 30%),radial-gradient(circle at bottom right,rgba(45,212,191,.12),transparent 28%),#0f172a}button,textarea,input,select{font:inherit}button{cursor:pointer}.app{display:grid;grid-template-columns:320px 1fr;height:100vh;overflow:hidden}.mobile-menu-btn,.sidebar-backdrop,.close-sidebar-btn,.sidebar-mobile-header{display:none}.sidebar{display:flex;flex-direction:column;gap:16px;padding:18px;background:#0f172ae0;border-right:1px solid rgba(148,163,184,.18);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);overflow-y:auto}.brand{display:flex;gap:12px;align-items:center}.brand-icon{display:grid;width:44px;height:44px;place-items:center;border-radius:16px;background:#2dd4bf26;font-size:24px;flex:0 0 auto}.brand h1{margin:0;font-size:22px}.brand p{margin:2px 0 0;color:#94a3b8;font-size:13px}.user-id{margin:4px 0 0;color:#64748b;font-size:11px}.new-chat-btn,.composer button,.topup-form button,.primary-btn{border:none;border-radius:14px;background:linear-gradient(135deg,#38bdf8,#2dd4bf);color:#04111f;font-weight:700;padding:12px 14px}.new-chat-btn:hover,.composer button:hover,.topup-form button:hover,.primary-btn:hover{filter:brightness(1.05)}.chat-list{display:flex;flex-direction:column;gap:8px}.chat-item{display:flex;gap:8px;align-items:center;padding:6px;border-radius:14px;background:#1e293bb3;border:1px solid transparent}.chat-item.active{border-color:#2dd4bf80;background:#14b8a624}.chat-title{flex:1;min-width:0;border:none;background:transparent;color:#e5e7eb;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:8px}.rename-chat,.delete-chat{width:28px;height:28px;border:none;border-radius:10px;flex:0 0 auto}.rename-chat{background:#38bdf824;color:#bae6fd}.delete-chat{background:#ef444424;color:#fecaca}.empty-chats{padding:14px;border:1px dashed rgba(148,163,184,.3);border-radius:16px;color:#94a3b8}.balance-panel{margin-top:auto;padding:14px;border-radius:20px;background:#1e293bb8;border:1px solid rgba(148,163,184,.16)}.balance-panel h3{margin:0 0 12px}.balance-grid{display:grid;grid-template-columns:1fr auto;gap:8px;color:#cbd5e1;font-size:14px}.balance-grid strong{color:#e5e7eb}.balance-grid .danger{color:#fca5a5}.topup-form{display:grid;gap:8px;margin-top:14px}.topup-form input,.mode-select,.composer textarea{border:1px solid rgba(148,163,184,.18);background:#0f172ab8;color:#e5e7eb;border-radius:14px;outline:none}.topup-form input{padding:10px 12px}.main{min-width:0;display:flex;flex-direction:column}.chat-window{display:grid;grid-template-rows:auto 1fr auto auto;height:100vh}.chat-header{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:18px 22px;border-bottom:1px solid rgba(148,163,184,.16);background:#0f172a8c;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.chat-header h2{margin:0;font-size:20px}.chat-header p{margin:3px 0 0;color:#94a3b8;font-size:13px}.mode-select{padding:10px 12px}.messages{overflow-y:auto;padding:24px}.message-row{display:flex;margin-bottom:16px}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message-bubble{max-width:min(820px,86%);padding:14px 16px;border-radius:20px;line-height:1.55;box-shadow:0 18px 45px #0000002e}.message-row.user .message-bubble{background:linear-gradient(135deg,#2563eb,#0891b2);color:#fff;border-bottom-right-radius:6px}.message-row.assistant .message-bubble{background:#1e293beb;border:1px solid rgba(148,163,184,.16);border-bottom-left-radius:6px}.message-content p{margin:0 0 10px}.message-content p:last-child{margin-bottom:0}.message-content table{width:100%;border-collapse:collapse;margin:12px 0;overflow:hidden;border-radius:12px;display:block;max-width:100%;overflow-x:auto}.message-content th,.message-content td{border:1px solid rgba(148,163,184,.25);padding:8px 10px;text-align:left;vertical-align:top}.message-content th{background:#0f172ad9}.message-content code{background:#0f172ae6;padding:2px 5px;border-radius:6px}.message-content pre{overflow-x:auto;background:#0f172ae6;padding:12px;border-radius:14px}.message-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0;max-width:680px}.message-image-button{display:block;width:100%;padding:0;border:none;border-radius:16px;background:#0f172a8c;overflow:hidden;cursor:zoom-in}.message-content>.message-image-button{max-width:min(100%,680px);margin:12px 0}.message-image{display:block;width:100%;max-width:100%;max-height:520px;height:auto;object-fit:contain;border-radius:16px;border:1px solid rgba(148,163,184,.22);transition:filter .15s ease,transform .15s ease}.message-gallery .message-image{aspect-ratio:4 / 3;height:220px;max-height:none;object-fit:cover}.message-image-button:hover .message-image{filter:brightness(1.08);transform:scale(1.005)}.image-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;display:grid;place-items:center;padding:18px;background:#020617e0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.image-viewer{position:relative;display:grid;grid-template-rows:auto 1fr auto;width:min(1080px,100%);height:min(860px,94vh);border-radius:24px;background:#0f172af0;border:1px solid rgba(148,163,184,.22);box-shadow:0 32px 90px #0000006b;overflow:hidden}.image-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(148,163,184,.16);color:#cbd5e1;font-weight:700}.image-viewer-close{display:grid;place-items:center;width:38px;height:38px;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:#1e293bd9;color:#e5e7eb;font-size:26px}.image-viewer-body{position:relative;display:grid;place-items:center;min-height:0;padding:14px}.image-viewer-img{display:block;max-width:100%;max-height:100%;border-radius:16px;object-fit:contain}.image-viewer-nav{position:absolute;top:50%;z-index:2;display:grid;place-items:center;width:46px;height:70px;border:1px solid rgba(148,163,184,.22);border-radius:18px;background:#0f172ab8;color:#e5e7eb;font-size:44px;transform:translateY(-50%)}.image-viewer-prev{left:14px}.image-viewer-next{right:14px}.image-viewer-footer{display:flex;justify-content:center;padding:14px 16px 16px;border-top:1px solid rgba(148,163,184,.16)}.image-viewer-link{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;border-radius:14px;background:linear-gradient(135deg,#38bdf8,#2dd4bf);color:#04111f;font-weight:800;text-decoration:none}.typing{color:#94a3b8}.welcome-message,.no-chat-card{max-width:520px;margin:48px auto;padding:24px;border-radius:24px;background:#1e293bb8;border:1px solid rgba(148,163,184,.16);text-align:center}.welcome-message h3,.no-chat-card h2{margin-top:0}.welcome-message p,.no-chat-card p{color:#94a3b8}.no-chat{display:grid;place-items:center;height:100vh}.big-icon{font-size:44px}.error-box{margin:0 24px 12px;padding:12px 14px;border-radius:14px;background:#ef444424;border:1px solid rgba(248,113,113,.25);color:#fecaca}.composer{display:grid;grid-template-columns:1fr;gap:10px;padding:18px 22px;border-top:1px solid rgba(148,163,184,.16);background:#0f172ab8}.composer-main{display:grid;grid-template-columns:auto 1fr auto;gap:12px}.composer textarea{resize:none;min-height:58px;max-height:180px;padding:12px 14px}.composer button{align-self:end;min-width:120px}.attach-btn{align-self:end;display:grid;place-items:center;min-width:48px!important;width:48px;height:48px;padding:0!important;border-radius:16px!important;font-size:26px;line-height:1}.hidden-file-input{display:none}.attachment-preview-panel{display:flex;gap:10px;overflow-x:auto;padding:2px 0 4px}.attachment-preview{position:relative;flex:0 0 auto;width:82px;height:82px;border-radius:16px;overflow:hidden;background:#0f172ab8;border:1px solid rgba(148,163,184,.22)}.attachment-preview-image-btn{display:block;width:100%;height:100%;min-width:0!important;padding:0!important;border:none;border-radius:16px;background:transparent!important;cursor:zoom-in;overflow:hidden}.attachment-preview-image-btn img{width:100%;height:100%;object-fit:cover}.attachment-preview-remove{position:absolute;top:5px;right:5px;z-index:2;display:grid;place-items:center;width:24px;height:24px;min-width:0!important;padding:0!important;border:none;border-radius:999px;background:#0f172ae0!important;color:#e5e7eb!important;font-size:18px}.attachment-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:180;display:grid;place-items:center;padding:18px;background:#020617e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.attachment-viewer{position:relative;display:grid;grid-template-rows:auto 1fr auto;width:min(1080px,100%);height:min(860px,94vh);border-radius:24px;background:#0f172af5;border:1px solid rgba(148,163,184,.22);box-shadow:0 32px 90px #0000006b;overflow:hidden}.attachment-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(148,163,184,.16);color:#cbd5e1;font-weight:700}.attachment-viewer-close{display:grid;place-items:center;width:38px;height:38px;min-width:0!important;padding:0!important;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:#1e293bd9!important;color:#e5e7eb!important;font-size:26px}.attachment-viewer-body{position:relative;display:grid;place-items:center;min-height:0;padding:14px}.attachment-viewer-img{display:block;max-width:100%;max-height:100%;border-radius:16px;object-fit:contain}.attachment-viewer-nav{position:absolute;top:50%;z-index:2;display:grid;place-items:center;width:46px;height:70px;min-width:0!important;padding:0!important;border:1px solid rgba(148,163,184,.22);border-radius:18px;background:#0f172ab8!important;color:#e5e7eb!important;font-size:44px;transform:translateY(-50%)}.attachment-viewer-prev{left:14px}.attachment-viewer-next{right:14px}.attachment-viewer-footer{display:flex;justify-content:center;gap:10px;padding:14px 16px 16px;border-top:1px solid rgba(148,163,184,.16)}.composer button:disabled,.secondary-btn:disabled,.primary-btn:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#020617b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100}.modal{width:min(520px,100%);border-radius:24px;padding:22px;background:#111827;border:1px solid rgba(148,163,184,.2);box-shadow:0 30px 80px #00000059}.modal h2{margin-top:0}.estimate-box{display:grid;gap:10px;margin:16px 0;padding:14px;border-radius:18px;background:#0f172ab3}.estimate-box div{display:flex;justify-content:space-between;gap:16px}.estimate-box span,.modal-note{color:#94a3b8}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.secondary-btn{border:1px solid rgba(148,163,184,.25);color:#e5e7eb;background:#1e293bcc;padding:12px 14px;border-radius:14px}@media (max-width: 860px){.app{display:block;height:100vh;overflow:hidden}.mobile-menu-btn{position:fixed;top:12px;left:14px;z-index:60;display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(148,163,184,.25);border-radius:14px;background:#0f172ae6;color:#e5e7eb;font-size:22px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:block;border:none;background:#0206179e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar{position:fixed;inset:0 auto 0 0;z-index:80;width:min(86vw,360px);height:100vh;transform:translate(-105%);transition:transform .22s ease;border-right:1px solid rgba(148,163,184,.22);border-bottom:none;padding:16px}.sidebar.open{transform:translate(0)}.desktop-brand{display:none}.sidebar-mobile-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.close-sidebar-btn{display:grid;place-items:center;width:38px;height:38px;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:#1e293bcc;color:#e5e7eb;font-size:24px}.brand h1{font-size:20px}.brand p{font-size:12px}.new-chat-btn{padding:13px 14px}.chat-list{max-height:32vh;overflow-y:auto;padding-right:2px}.balance-panel{margin-top:0}.main{height:100vh}.chat-window{height:100vh;grid-template-rows:auto 1fr auto auto}.chat-header{min-height:66px;padding:12px 14px 12px 66px;position:sticky;top:0;z-index:20}.chat-header h2{max-width:48vw;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header p{font-size:12px}.mode-select{max-width:132px;padding:9px 10px;border-radius:12px;font-size:14px}.messages{padding:14px 14px 18px}.message-bubble{max-width:96%;padding:12px 13px;border-radius:18px;font-size:15px;line-height:1.5}.message-content table{font-size:13px}.message-content th,.message-content td{padding:7px 8px}.message-gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-width:100%}.message-gallery .message-image{height:132px;border-radius:14px}.message-content>.message-image-button{max-width:100%}.message-content>.message-image-button .message-image{max-height:320px;border-radius:14px}.image-viewer-backdrop{padding:8px}.image-viewer{width:100%;height:92vh;border-radius:20px}.image-viewer-header{padding:10px 12px}.image-viewer-body{padding:8px}.image-viewer-nav{width:40px;height:58px;border-radius:15px;font-size:38px}.image-viewer-prev{left:8px}.image-viewer-next{right:8px}.image-viewer-footer{padding:10px 12px 12px}.image-viewer-link{width:100%}.welcome-message,.no-chat-card{width:calc(100% - 28px);margin:24px auto;padding:20px}.no-chat{height:100vh;padding-top:60px}.error-box{margin:0 14px 10px;font-size:14px}.composer{grid-template-columns:1fr;gap:10px;padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom))}.composer-main{grid-template-columns:auto 1fr}.composer-main textarea{grid-column:2}.composer-main>button[type=submit]{grid-column:1 / -1;width:100%;min-width:0;padding:13px 14px}.attach-btn{grid-row:1;align-self:stretch;height:auto;min-height:74px}.composer textarea{min-height:74px;max-height:160px;font-size:15px}.attachment-preview{width:72px;height:72px}.attachment-viewer-backdrop{padding:8px}.attachment-viewer{width:100%;height:92vh;border-radius:20px}.attachment-viewer-header{padding:10px 12px}.attachment-viewer-body{padding:8px}.attachment-viewer-nav{width:40px;height:58px;border-radius:15px;font-size:38px}.attachment-viewer-prev{left:8px}.attachment-viewer-next{right:8px}.attachment-viewer-footer{padding:10px 12px 12px;flex-direction:column}.attachment-viewer-footer button{width:100%}.modal{max-height:88vh;overflow-y:auto}.estimate-box div{flex-direction:column;gap:4px}}
