:root{--gg-primary: #1f6f5f;--gg-secondary: #2fa084;--gg-highlight: #6fcf97;--gg-light-bg: #eeeeee;--bg: #0f2a24;--bg-elevated: #15322c;--surface: #1a3a32;--surface-soft: #20483e;--surface-strong: #25584b;--text: #edf7f2;--text-muted: #bad0c7;--text-soft: #d9ebe4;--border: rgba(111, 207, 151, .2);--border-strong: rgba(111, 207, 151, .36);--shadow: 0 24px 80px rgba(3, 19, 16, .44);--shadow-soft: 0 14px 34px rgba(3, 19, 16, .22);--focus-ring: 0 0 0 3px rgba(111, 207, 151, .42);--selection-bg: rgba(111, 207, 151, .34);--selection-text: #edf7f2;--code-bg: #0b211c;--danger-surface: rgba(111, 207, 151, .1);--danger-text: #edf7f2}@media (prefers-color-scheme: light){:root{--bg: #eeeeee;--bg-elevated: #f7f8f6;--surface: #f7f8f6;--surface-soft: #e1ebe6;--surface-strong: #d2e3dc;--text: #13342e;--text-muted: #49685f;--text-soft: #244a42;--border: rgba(31, 111, 95, .16);--border-strong: rgba(31, 111, 95, .32);--shadow: 0 24px 70px rgba(31, 111, 95, .16);--shadow-soft: 0 12px 30px rgba(31, 111, 95, .11);--focus-ring: 0 0 0 3px rgba(47, 160, 132, .32);--selection-bg: rgba(47, 160, 132, .28);--selection-text: #0f2a24;--code-bg: #12352e;--danger-surface: rgba(31, 111, 95, .09);--danger-text: #13342e}}:root[data-theme=light]{--bg: #eeeeee;--bg-elevated: #f7f8f6;--surface: #f7f8f6;--surface-soft: #e1ebe6;--surface-strong: #d2e3dc;--text: #13342e;--text-muted: #49685f;--text-soft: #244a42;--border: rgba(31, 111, 95, .16);--border-strong: rgba(31, 111, 95, .32);--shadow: 0 24px 70px rgba(31, 111, 95, .16);--shadow-soft: 0 12px 30px rgba(31, 111, 95, .11);--focus-ring: 0 0 0 3px rgba(47, 160, 132, .32);--selection-bg: rgba(47, 160, 132, .28);--selection-text: #0f2a24;--code-bg: #12352e;--danger-surface: rgba(31, 111, 95, .09);--danger-text: #13342e}:root[data-theme=dark]{--bg: #0f2a24;--bg-elevated: #15322c;--surface: #1a3a32;--surface-soft: #20483e;--surface-strong: #25584b;--text: #edf7f2;--text-muted: #bad0c7;--text-soft: #d9ebe4;--border: rgba(111, 207, 151, .2);--border-strong: rgba(111, 207, 151, .36);--shadow: 0 24px 80px rgba(3, 19, 16, .44);--shadow-soft: 0 14px 34px rgba(3, 19, 16, .22);--focus-ring: 0 0 0 3px rgba(111, 207, 151, .42);--selection-bg: rgba(111, 207, 151, .34);--selection-text: #edf7f2;--code-bg: #0b211c;--danger-surface: rgba(111, 207, 151, .1);--danger-text: #edf7f2}*{box-sizing:border-box}::selection{background:var(--selection-bg);color:var(--selection-text)}.app-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,rgba(47,160,132,.14),transparent 34%),linear-gradient(315deg,rgba(31,111,95,.2),transparent 38%),var(--bg);color:var(--text);transition:background .28s ease,color .28s ease}button,input{font:inherit}button{transition:background .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease,opacity .2s ease,transform .16s ease}button:focus-visible,input:focus-visible,.history-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}button:disabled,input:disabled{cursor:not-allowed;opacity:.56}.theme-toggle{position:fixed;top:1rem;right:1rem;z-index:30;width:44px;height:44px;display:grid;place-items:center;border:1px solid var(--border-strong);border-radius:999px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-soft);cursor:pointer}.theme-toggle:hover{background:var(--surface-soft);transform:translateY(-1px)}.settings-toggle{position:fixed;top:1rem;right:4.35rem;z-index:30;width:44px;height:44px;display:grid;place-items:center;border:1px solid var(--border-strong);border-radius:999px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-soft);cursor:pointer}.settings-toggle:hover{background:var(--surface-soft);transform:translateY(-1px)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:1rem;background:#031310b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.settings-panel{width:min(980px,100%);max-height:min(860px,92vh);overflow:auto;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);color:var(--text);box-shadow:var(--shadow);padding:1.1rem}.settings-header,.settings-section-title,.settings-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.settings-kicker{margin:0 0 .2rem;color:var(--gg-highlight);font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.settings-header h2,.settings-section h3{margin:0;color:var(--text)}.settings-close{width:40px;height:40px;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--text);cursor:pointer;font-size:1.35rem}.provider-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:1rem 0;padding:.35rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated)}.provider-tabs button,.activate-button,.refresh-models-button{border:1px solid var(--border);border-radius:8px;padding:.75rem .9rem;background:var(--surface-soft);color:var(--text);cursor:pointer;font-weight:800}.provider-tabs button.active,.activate-button{background:var(--gg-primary);border-color:var(--gg-primary);color:#edf7f2}.provider-tabs button:hover,.activate-button:hover,.refresh-models-button:hover{background:var(--gg-secondary);border-color:var(--gg-secondary);color:#edf7f2}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.settings-section{display:grid;gap:.85rem;min-width:0;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);padding:1rem}.settings-section-title span{flex:0 0 auto;border:1px solid var(--border);border-radius:999px;padding:.26rem .55rem;color:var(--text-muted);font-size:.72rem;font-weight:800}.settings-field{display:grid;gap:.42rem;color:var(--text-muted);font-size:.86rem;font-weight:750}.settings-field input{width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);padding:.82rem .9rem;outline:none}.settings-button-row{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.model-list{display:grid;gap:.55rem;max-height:280px;overflow:auto;padding-right:.25rem;scrollbar-color:var(--gg-primary) var(--surface-soft);scrollbar-width:thin}.model-option{display:grid;gap:.24rem;width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);padding:.72rem .8rem;cursor:pointer;text-align:left}.model-option:hover,.model-option.active{border-color:var(--gg-highlight);background:var(--surface-soft)}.model-option span{font-weight:850}.model-option small,.settings-empty,.settings-footer p{color:var(--text-muted);line-height:1.45}.settings-empty{border:1px dashed var(--border-strong);border-radius:8px;padding:.9rem}.settings-footer{align-items:flex-start;margin-top:1rem;border-top:1px solid var(--border);padding-top:1rem;color:var(--text-muted);font-size:.88rem}.settings-footer p{margin:0;text-align:right}.home-card,.chat-card,.history-card{width:min(760px,100%);background:color-mix(in srgb,var(--surface) 94%,transparent);border:1px solid var(--border);border-radius:8px;padding:1.6rem;box-shadow:var(--shadow);transition:background .28s ease,border-color .28s ease,box-shadow .28s ease}.chat-card{width:min(780px,100%);min-height:min(860px,calc(100vh - 2rem));display:flex;flex-direction:column;gap:.8rem}.hero-copy{display:grid;gap:1rem}.brand-logo{display:block;flex:0 0 auto;border:1px solid var(--border-strong);border-radius:8px;background:var(--bg);box-shadow:var(--shadow-soft)}.home-logo{width:clamp(112px,24vw,172px);aspect-ratio:1;object-fit:contain}.header-logo{width:54px;height:54px;object-fit:contain}.brand-heading{display:flex;align-items:center;gap:.85rem;min-width:0}.brand-heading>div{min-width:0}.greeting{margin:0;color:var(--gg-highlight);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.86rem}.home-card h1{margin:0;color:var(--text);font-size:clamp(2.35rem,8vw,4rem);line-height:1;font-weight:800;letter-spacing:0;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}.subtext,.chat-subtitle,.empty-state{color:var(--text-muted);line-height:1.7;margin:0;font-size:.96rem}.home-actions,.history-list,.chat-title-row{display:grid;gap:.8rem}.home-actions{margin-top:1.8rem}.start-button,.history-button,.back-button,.delete-history-button,.delete-session-button,.update-button,.clear-photo{border:1px solid var(--border);border-radius:8px;padding:.9rem 1.1rem;cursor:pointer;font-weight:750}.start-button,.send-button,.update-button{background:var(--gg-primary);color:#edf7f2;border-color:var(--gg-primary)}.start-button:hover,.send-button:hover:not(:disabled),.update-button:hover{background:var(--gg-secondary);border-color:var(--gg-secondary);transform:translateY(-1px)}.history-button,.back-button,.delete-history-button,.delete-session-button,.clear-photo{background:var(--surface-soft);color:var(--text)}.history-button:hover,.back-button:hover,.delete-history-button:hover,.delete-session-button:hover,.clear-photo:hover{background:var(--surface-strong)}.history-header,.chat-header-top,.history-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem}.history-header{margin-bottom:1.25rem}.history-actions{justify-content:flex-end}.history-item-row{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:center}.history-item{width:100%;min-width:0;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--surface-soft);border:1px solid var(--border);border-radius:8px;padding:1rem;color:var(--text);cursor:pointer;text-align:left}.history-item:hover{background:var(--surface-strong);border-color:var(--border-strong)}.history-title{font-weight:750}.history-meta,.history-count{color:var(--text-muted);font-size:.88rem}.chat-header{display:grid;gap:1rem}.chat-icons{display:flex;gap:.55rem}.icon-pill,.chat-history-btn{border:1px solid var(--border);border-radius:8px;padding:.7rem .85rem;background:var(--surface-soft);color:var(--text);cursor:pointer;box-shadow:var(--shadow-soft)}.chat-history-btn{width:auto}.icon-pill:hover,.chat-history-btn:hover{background:var(--surface-strong);transform:translateY(-1px)}.chat-title{margin:0;color:var(--text);font-size:1.45rem;font-weight:800;line-height:1.25}.messages-panel{flex:1;display:grid;align-content:start;gap:.9rem;min-height:48vh;max-height:64vh;overflow-y:auto;padding:1rem;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);scroll-behavior:smooth;scrollbar-color:var(--gg-primary) var(--surface-soft);scrollbar-width:thin}.messages-panel::-webkit-scrollbar,.code-block::-webkit-scrollbar,.markdown-table-wrapper::-webkit-scrollbar{width:10px;height:10px}.messages-panel::-webkit-scrollbar-track,.code-block::-webkit-scrollbar-track,.markdown-table-wrapper::-webkit-scrollbar-track{background:var(--surface-soft);border-radius:999px}.messages-panel::-webkit-scrollbar-thumb,.code-block::-webkit-scrollbar-thumb,.markdown-table-wrapper::-webkit-scrollbar-thumb{background:var(--gg-primary);border-radius:999px;border:2px solid var(--surface-soft)}.message-row{display:flex}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message-bubble{max-width:min(76%,620px);min-width:72px;border-radius:18px;padding:.85rem 1rem;line-height:1.65;border:1px solid var(--border);box-shadow:var(--shadow-soft)}.user-bubble{background:var(--gg-primary);border-color:var(--gg-secondary);color:#edf7f2}.assistant-bubble{background:var(--surface);color:var(--text)}.message-role{margin-bottom:.45rem;color:currentColor;font-size:.76rem;font-weight:800;opacity:.72;text-transform:uppercase;letter-spacing:.06em}.message-content{color:currentColor;line-height:1.75;white-space:normal}.message-bubble p{margin:0}.message-content strong{font-weight:850}.message-content em{font-style:italic}.message-heading{margin:.55rem 0 .35rem;color:currentColor;font-size:1.04rem;font-weight:850;line-height:1.35}.message-heading:first-child{margin-top:0}.message-spacer{height:.45rem}.assistant-badge{display:inline-flex;align-items:center;justify-content:center;margin-bottom:.65rem;border-radius:999px;padding:.28rem .7rem;background:#6fcf9726;color:var(--gg-highlight);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.draft-content{opacity:.96}.typing-caret{display:inline-block;margin-left:.3rem;animation:blinkCaret .9s steps(2,start) infinite}@keyframes blinkCaret{0%,50%{opacity:1}50.1%,to{opacity:0}}.typing-bubble{min-width:170px;padding:1rem 1.2rem}.typing-dots{display:flex;align-items:center;gap:.55rem;justify-content:center;padding:.55rem 0}.typing-dots span{width:9px;height:9px;border-radius:999px;background:var(--gg-highlight);opacity:.35;animation:blinkDot .95s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}@keyframes blinkDot{0%,to{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}.message-image{margin-top:1rem;width:100%;max-height:380px;border-radius:8px;object-fit:contain;border:1px solid var(--border);box-shadow:var(--shadow-soft)}.message-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;margin-top:.8rem}.markdown-table-wrapper{overflow-x:auto;margin:.85rem 0}.message-content table{width:100%;border-collapse:collapse;background:var(--surface-soft)}.message-content th,.message-content td{border:1px solid var(--border-strong);padding:.7rem .85rem;text-align:left}.message-content th{background:var(--surface-strong);font-weight:800}.code-block-wrapper{position:relative;margin:1rem 0}.code-block{margin:0;padding:1rem;border-radius:8px;overflow-x:auto;background:var(--code-bg);border:1px solid var(--border-strong);color:#edf7f2;font-family:Source Code Pro,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.92rem;line-height:1.6}.inline-code{display:inline-block;background:#6fcf972e;border:1px solid var(--border);border-radius:6px;padding:.12rem .38rem;color:currentColor}.copy-button{position:absolute;top:.7rem;right:.7rem;border:1px solid rgba(111,207,151,.28);background:#1f6f5fd9;color:#edf7f2;padding:.35rem .65rem;border-radius:999px;cursor:pointer;font-size:.74rem;font-weight:800}.copy-button:hover{background:var(--gg-secondary)}.message-content blockquote{border-left:4px solid var(--gg-highlight);padding:.8rem 1rem;margin:1rem 0;background:#6fcf971f;color:currentColor;border-radius:8px}.message-content ul,.message-content ol{margin:.65rem 0;padding-left:1.25rem}.message-content li{margin:.28rem 0;padding-left:.1rem}.message-content a{color:var(--gg-highlight);font-weight:750;text-decoration:underline;text-underline-offset:.16em}.update-banner,.error-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;border-radius:8px;background:var(--danger-surface);border:1px solid var(--border-strong);color:var(--danger-text);font-weight:650;line-height:1.45}.error-banner{display:block}.composer{position:relative;display:grid;grid-template-columns:auto 1fr auto auto;gap:.55rem;padding:.65rem;border-radius:8px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-soft);align-items:center}.composer-input-wrap{display:contents}.composer-input-wrap input{width:100%;min-width:0;min-height:42px;border:1px solid transparent;border-radius:8px;background:var(--bg-elevated);color:var(--text);outline:none;font-size:.96rem;padding:.7rem .85rem}.composer-input-wrap input::placeholder{color:var(--text-muted)}.attach-button,.send-button,.stop-button,.photo-menu-item{width:42px;height:42px;border-radius:8px;cursor:pointer;display:grid;place-items:center}.attach-button,.photo-menu-item{border:1px solid var(--border);background:var(--surface-soft);color:var(--text)}.attach-button:hover,.attach-button.active,.photo-menu-item:hover{background:var(--surface-strong);border-color:var(--border-strong)}.send-button,.stop-button{border:1px solid var(--gg-primary);padding:0}.stop-button{background:var(--surface-soft);border-color:var(--border-strong);color:var(--gg-highlight)}.stop-button:hover{background:var(--surface-strong);transform:translateY(-1px)}.photo-menu{display:flex;gap:.5rem;padding:.55rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-soft);z-index:10}@media (min-width: 721px){.photo-menu{position:absolute;left:.65rem;bottom:calc(100% + .5rem)}}.photo-menu-item.icon-only{padding:0}.photo-preview{display:flex;align-items:center;gap:.75rem;padding:.7rem;border-radius:8px;background:var(--surface-soft);border:1px solid var(--border)}.photo-preview img{width:72px;height:72px;object-fit:cover;border-radius:8px}.attachment-tray{grid-column:1 / -1;order:-1;display:flex;gap:.55rem;max-width:100%;overflow-x:auto;padding:.25rem .1rem .55rem;scrollbar-width:thin;scrollbar-color:var(--gg-primary) transparent}.attachment-thumb{position:relative;flex:0 0 auto;width:64px;height:64px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface-soft);box-shadow:var(--shadow-soft)}.attachment-thumb img{width:100%;height:100%;object-fit:cover;display:block}.attachment-thumb button{position:absolute;top:4px;right:4px;width:22px;height:22px;display:grid;place-items:center;border:1px solid rgba(237,247,242,.42);border-radius:999px;background:#050606d1;color:#edf7f2;cursor:pointer;font-size:1rem;line-height:1;padding:0}.attachment-thumb button:hover{background:var(--gg-primary)}.chat-workspace{width:min(430px,100%);display:block}.desktop-history-sidebar{display:none}.chat-card{position:relative;width:min(430px,100%);min-height:min(860px,calc(100vh - 2rem));overflow:hidden;border-radius:8px;padding:0;background:#fbfcfc;border:1px solid rgba(31,111,95,.16);box-shadow:0 20px 54px #0f2a2424;color:#07110f;font-family:Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.chat-card:before{display:none}.chat-card .update-banner,.chat-card .error-banner{position:relative;z-index:2;margin:.7rem .8rem 0;background:#e8f6f2;color:#173b35;border-color:#1f6f5f2e}.chat-card .chat-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:.6rem;padding:0 .8rem;background:#f8f9fa;border-bottom:1px solid #dde3e2}.chat-card .chat-header-top{min-height:auto;flex:0 0 auto;order:2}.chat-card .chat-icons{width:auto;display:flex;justify-content:flex-end;align-items:center;gap:.45rem}.chat-card .icon-pill,.chat-card .chat-history-btn{width:40px;height:40px;display:grid;place-items:center;padding:0;border:0;border-radius:999px;background:#dfe5e7;color:#2e3f3c;box-shadow:none;font-size:.92rem}.chat-card .chat-history-btn{min-width:40px;padding-inline:0;font-size:0}.chat-card .icon-pill:hover,.chat-card .chat-history-btn:hover{background:#d2dbdd;transform:none}.chat-card .chat-title-row{flex:1;min-width:0;order:1;place-items:stretch;gap:0}.chat-card .brand-heading{flex-direction:row;gap:.7rem;text-align:left}.chat-card .header-logo{width:42px;height:42px;border-radius:50%;border-color:#1f6f5f29;background:#e1f6f2;box-shadow:none}.chat-card .chat-title{max-width:190px;overflow:hidden;color:#07110f;font-size:1rem;font-weight:850;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.chat-card .chat-subtitle{color:#70807d;font-size:.72rem;line-height:1.25}.chat-card .messages-panel{position:relative;z-index:2;flex:1;min-height:calc(100vh - 180px);max-height:none;margin-top:0;padding:1.55rem 1rem 1.1rem;border:0;border-radius:0;background:#fbfcfc;box-shadow:none;scrollbar-color:rgba(31,111,95,.42) rgba(223,229,231,.6);font-size:1rem}.chat-card .empty-state{align-self:center;justify-self:center;width:min(82%,300px);border-radius:999px;padding:.8rem 1rem;background:#eef2f2;color:#52615f;text-align:center}.chat-card .message-bubble{max-width:82%;border:0;border-radius:14px;padding:.78rem .95rem;box-shadow:none;font-size:1rem;line-height:1.55;overflow-wrap:anywhere}.chat-card .assistant-bubble{max-width:calc(100% - 54px);border-bottom-left-radius:14px;background:transparent;color:#06100e;padding:0 .35rem}.chat-card .user-bubble{border-bottom-right-radius:14px;background:#dfe4e6;color:#07110f}.chat-card .message-role,.chat-card .assistant-badge{display:none}.chat-card .message-row{gap:.65rem}.chat-card .message-row.assistant:before{content:"DS";flex:0 0 38px;width:38px;height:38px;display:grid;place-items:center;align-self:flex-start;margin-top:.1rem;border:1px solid #e2e8e8;border-radius:999px;background:#fff;color:#236f61;font-size:.72rem;font-weight:850;box-shadow:0 3px 12px #0f2a2414}.chat-card .message-row.user:after{content:"";flex:0 0 40px;width:40px;height:40px;align-self:flex-start;border-radius:999px;background:radial-gradient(circle at 50% 40%,transparent 0 5px,#2e3f3c 5.5px 6.8px,transparent 7px),radial-gradient(circle at 50% 68%,transparent 0 8px,#2e3f3c 8.5px 10px,transparent 10.5px),#dfe5e7}.chat-card .message-content{color:currentColor;line-height:1.58}.chat-card .message-content p+p{margin-top:.45rem}.chat-card .message-content table{min-width:260px;background:#eef3f2;color:#07110f}.chat-card .message-content th{background:#dce9e6}.chat-card .message-content th,.chat-card .message-content td{border-color:#1f6f5f29;padding:.55rem .65rem}.chat-card .code-block{background:#14221f;border-color:#1f6f5f3d;font-size:.78rem}.chat-card .copy-button,.chat-card .message-copy-button{border:1px solid rgba(31,111,95,.16);background:#edf4f2;color:#1d4039}.message-copy-button{margin-top:.55rem;border-radius:999px;padding:.32rem .62rem;cursor:pointer;font-size:.7rem;font-weight:800}.message-copy-button:hover{background:#2fa08457}.chat-card .message-image{max-height:250px;border-radius:14px;border-color:#1f6f5f26}.chat-card .message-image-grid{grid-template-columns:repeat(auto-fit,minmax(86px,1fr))}.chat-card .typing-bubble{min-width:84px}.chat-card .composer{position:relative;z-index:3;grid-template-columns:auto 1fr auto auto;gap:.52rem;margin:.75rem .75rem .55rem;padding:.58rem;border-radius:999px;background:#fff;border:1.5px solid #0ea5a4;box-shadow:0 6px 20px #0ea5a41f}.chat-card .attachment-tray{padding:.15rem .2rem .45rem}.chat-card .composer-input-wrap input{min-height:42px;border-radius:999px;background:transparent;color:#07110f;padding:.58rem .7rem;font-size:1rem}.chat-card .composer-input-wrap input::placeholder{color:#9aa5a4}.chat-card .attach-button,.chat-card .send-button,.chat-card .stop-button,.chat-card .photo-menu-item{width:36px;height:36px;border-radius:999px}.chat-card .attach-button,.chat-card .stop-button{background:transparent;border-color:transparent;color:#657370}.chat-card .send-button{background:#e2e8e8;border-color:#e2e8e8;color:#657370}.chat-card .send-button:hover:not(:disabled){background:#0ea5a4;border-color:#0ea5a4;color:#fff;transform:none}.chat-card .photo-menu{left:.75rem;right:.75rem;bottom:calc(100% + .5rem);justify-content:center;background:#fff;border-color:#1f6f5f29}.chat-card .photo-preview{position:relative;z-index:2;background:#fff;border-color:#1f6f5f29;color:#07110f}@media (max-width: 920px){.app-shell{align-items:stretch}.home-card,.history-card{padding:1rem}.chat-card{min-height:calc(100vh - 2rem);padding:1rem .85rem .85rem}.messages-panel{max-height:none;min-height:48vh}.message-bubble{max-width:88%}}@media (max-width: 720px){.app-shell{padding:0;background:#f8f9fa}.app-shell:has(.chat-workspace)>.theme-toggle,.app-shell:has(.chat-workspace)>.settings-toggle{display:none}.theme-toggle{top:.75rem;right:.75rem;width:40px;height:40px}.settings-toggle{top:.75rem;right:3.8rem;width:40px;height:40px}.settings-panel{max-height:94vh;padding:.9rem}.settings-grid,.settings-button-row{grid-template-columns:1fr}.settings-header,.settings-section-title,.settings-footer{align-items:flex-start}.settings-footer{flex-direction:column}.settings-footer p{text-align:left}.history-header,.chat-header-top{align-items:stretch;flex-direction:column}.history-actions{width:100%}.history-actions>button,.chat-history-btn{width:100%}.history-item-row{grid-template-columns:1fr}.history-item{align-items:flex-start;flex-direction:column}.chat-icons{display:grid;grid-template-columns:repeat(3,1fr)}.chat-title{font-size:1.25rem}.chat-subtitle{font-size:.86rem}.home-logo{width:104px}.header-logo{width:46px;height:46px}.brand-heading{gap:.65rem}.messages-panel{padding:.75rem}.message-bubble{max-width:94%;padding:.72rem .85rem;font-size:.92rem}.composer{grid-template-columns:auto 1fr auto auto;gap:.42rem;padding:.5rem}.attach-button,.send-button,.stop-button,.photo-menu-item{width:38px;height:38px}.composer-input-wrap input{min-height:38px;font-size:.9rem;padding-inline:.65rem}.photo-menu{grid-column:1 / -1;justify-content:center;width:100%;order:-1}.photo-preview img{width:56px;height:56px}}@media (max-width: 720px){.chat-workspace,.chat-card{width:100%}.chat-card{min-height:100vh;border:0;border-radius:0;padding:0}.chat-card .chat-header{min-height:72px;padding-inline:.85rem}.chat-card .chat-header-top{align-items:center;flex-direction:row}.chat-card .chat-icons{display:flex}.chat-card .icon-pill:nth-child(2),.chat-card .icon-pill:nth-child(3){display:none}.chat-card .chat-history-btn{width:40px}.chat-card .chat-history-btn:before{content:"<";font-size:1.2rem;line-height:1}.chat-card .icon-pill{font-size:0}.chat-card .icon-pill:before{content:"+";font-size:1.3rem;line-height:1}.chat-card .chat-title{max-width:48vw;font-size:1.08rem}.chat-card .chat-subtitle{display:none}.chat-card .messages-panel{min-height:calc(100vh - 156px);padding:1.45rem .85rem .8rem}.chat-card .message-bubble{max-width:78%;font-size:1rem;line-height:1.55}.chat-card .assistant-bubble{max-width:calc(100% - 52px)}.chat-card .message-row.user:after{flex-basis:40px}.chat-card .composer{margin:.55rem .7rem .45rem;padding:.58rem}.chat-card .composer-input-wrap input{min-height:42px;font-size:1rem}}@media (min-width: 1024px){body{overflow:hidden}.app-shell{align-items:stretch;justify-content:stretch;min-height:100vh;padding:0;overflow:hidden;background:linear-gradient(135deg,rgba(47,160,132,.12),transparent 34%),linear-gradient(315deg,rgba(31,111,95,.18),transparent 38%),var(--bg)}.chat-workspace{width:100%;min-height:100vh;display:grid;grid-template-columns:320px minmax(0,1fr);background:linear-gradient(180deg,rgba(111,207,151,.04),transparent 28%),var(--bg);transition:grid-template-columns .22s ease}.chat-workspace.sidebar-collapsed{grid-template-columns:72px minmax(0,1fr)}.chat-card{width:100%;min-height:100vh;max-height:100vh;display:grid;grid-template-rows:auto minmax(0,1fr) auto auto;gap:.9rem;overflow:hidden;border:0;border-radius:0;padding:1.05rem clamp(1.25rem,4vw,4rem) 1rem;background:linear-gradient(135deg,rgba(47,160,132,.07),transparent 32%),linear-gradient(315deg,rgba(111,207,151,.06),transparent 42%),var(--bg);box-shadow:none;color:var(--text)}.chat-card:before{display:none}.chat-card .chat-header{width:min(1040px,100%);margin-inline:auto;padding:0}.chat-card .chat-header-top{min-height:auto}.chat-card .chat-icons{width:auto;justify-content:flex-start}.chat-card .icon-pill,.chat-card .chat-history-btn{width:42px;height:42px;border:1px solid var(--border);background:var(--surface-soft);color:var(--text)}.chat-card .chat-history-btn{display:none}.chat-card .brand-heading{flex-direction:row;justify-content:flex-start;text-align:left}.chat-card .header-logo{width:48px;height:48px;border-radius:8px;box-shadow:var(--shadow-soft)}.chat-card .chat-title{max-width:min(680px,70vw);color:var(--text);font-size:1.2rem;white-space:nowrap}.chat-card .chat-subtitle{color:var(--text-muted);font-size:.86rem}.chat-card .messages-panel{width:min(1040px,100%);min-height:0;max-height:none;height:100%;margin:0 auto;padding:1.2rem .5rem;overflow-y:auto;background:transparent}.chat-card .empty-state{width:min(480px,100%);background:var(--surface-soft);color:var(--text-muted)}.chat-card .message-bubble{max-width:min(76%,760px);border:1px solid var(--border);border-radius:16px;padding:.85rem 1rem;font-size:.98rem;line-height:1.65;box-shadow:0 14px 36px #03131029}.chat-card .assistant-bubble{border-bottom-left-radius:7px;background:color-mix(in srgb,var(--surface) 90%,var(--bg));color:var(--text)}.chat-card .user-bubble{border-bottom-right-radius:7px;background:var(--gg-primary);color:#edf7f2}.chat-card .message-content{line-height:1.75}.chat-card .message-content table{min-width:420px;background:var(--surface-soft);color:var(--text)}.chat-card .message-content th{background:var(--surface-strong)}.chat-card .code-block{font-size:.92rem}.chat-card .composer,.chat-card .photo-preview,.chat-card .error-banner,.chat-card .update-banner{width:min(1040px,100%);margin-inline:auto}.chat-card .composer{grid-template-columns:auto 1fr auto auto;border-radius:16px;padding:.6rem;background:color-mix(in srgb,var(--surface) 94%,var(--bg));border:1px solid var(--border);box-shadow:0 18px 48px #03131033}.chat-card .composer-input-wrap input{min-height:46px;border-radius:10px;background:var(--bg-elevated);color:var(--text);font-size:1rem}.chat-card .composer-input-wrap input::placeholder{color:var(--text-muted)}.chat-card .attach-button,.chat-card .send-button,.chat-card .stop-button{width:46px;height:46px;border-radius:10px}.chat-card .attach-button,.chat-card .stop-button{background:var(--surface-soft);border-color:var(--border);color:var(--text)}.chat-card .send-button{background:var(--gg-primary);border-color:var(--gg-primary)}.desktop-history-sidebar{display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr);gap:.9rem;min-height:100vh;max-height:100vh;overflow:hidden;padding:1rem;background:color-mix(in srgb,var(--surface) 96%,var(--bg));border-right:1px solid var(--border);box-shadow:18px 0 50px #0313101f;transition:padding .22s ease}.sidebar-collapsed .desktop-history-sidebar{padding:.9rem .65rem}.sidebar-brand{display:flex;align-items:center;gap:.75rem;min-width:0}.sidebar-collapsed .sidebar-brand{justify-content:center}.sidebar-brand p{margin:0;color:var(--text);font-weight:850}.sidebar-brand span,.sidebar-history-item small,.sidebar-empty,.sidebar-section-title{color:var(--text-muted);font-size:.82rem}.sidebar-new-chat{border:1px solid var(--gg-primary);border-radius:8px;padding:.85rem 1rem;background:var(--gg-primary);color:#edf7f2;cursor:pointer;font-weight:850}.sidebar-collapse-button{width:100%;height:38px;border:1px solid var(--border);border-radius:8px;background:var(--surface-soft);color:var(--text);cursor:pointer;font-size:1.4rem;line-height:1}.sidebar-collapse-button:hover{background:var(--surface-strong)}.sidebar-new-chat:hover{background:var(--gg-secondary);border-color:var(--gg-secondary)}.sidebar-section-title{font-weight:850;letter-spacing:.08em;text-transform:uppercase}.sidebar-history-list{display:grid;align-content:start;gap:.55rem;min-height:0;overflow-y:auto;padding-right:.2rem;scrollbar-color:var(--gg-primary) var(--surface-soft);scrollbar-width:thin}.sidebar-history-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.25rem;width:100%;min-width:0;border:1px solid transparent;border-radius:8px;background:transparent;padding:.2rem}.sidebar-history-item{display:grid;gap:.25rem;min-width:0;border:0;background:transparent;color:var(--text);cursor:pointer;padding:.6rem;text-align:left}.sidebar-history-item span{overflow:hidden;font-weight:750;text-overflow:ellipsis;white-space:nowrap}.sidebar-delete-button{width:30px;height:30px;display:grid;place-items:center;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:1.05rem;padding:0}.sidebar-delete-button:hover{border-color:var(--border);background:var(--surface-strong);color:var(--text)}.sidebar-history-row:hover,.sidebar-history-row.active{border-color:var(--border);background:var(--surface-soft)}.chat-card .attachment-tray{padding:.1rem .15rem .55rem}.chat-card .attachment-thumb{width:72px;height:72px}.home-card,.history-card{margin:auto}}body{margin:0;min-height:100vh;background:var(--bg, #0f2a24);color:var(--text, #edf7f2);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}html{min-height:100%}#root{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
