@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg: #F5F4F0;--bg-surface: #FFFFFF;--bg-elevated: #ECEAE4;--bg-input: #F0EEE8;--bg-user-msg: #6D28D9;--code-bg: #18161A;--code-text: #EAE6F0;--text-primary: #1A1714;--text-secondary: #6A6560;--text-muted: #A09B94;--text-on-accent: #FFFFFF;--accent: #7C3AED;--accent-hover: #6D28D9;--accent-glow: rgba(124, 58, 237, .14);--accent-light: #F5F3FF;--accent-subtle: rgba(124, 58, 237, .07);--danger: #DC2626;--danger-bg: rgba(220, 38, 38, .07);--success: #059669;--border: rgba(0, 0, 0, .07);--border-input: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .16);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .05), 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .1), 0 4px 16px rgba(0, 0, 0, .06);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .12), 0 8px 24px rgba(0, 0, 0, .07);--radius-xs: 5px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--navbar-height: 56px;--sidebar-width: 252px;--max-content: 720px;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-sans: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M3.32031%2011.6835C3.32031%2016.6541%207.34975%2020.6835%2012.3203%2020.6835C16.1075%2020.6835%2019.3483%2018.3443%2020.6768%2015.032C19.6402%2015.4486%2018.5059%2015.6834%2017.3203%2015.6834C12.3497%2015.6834%208.32031%2011.654%208.32031%206.68342C8.32031%205.50338%208.55165%204.36259%208.96453%203.32996C5.65605%204.66028%203.32031%207.89912%203.32031%2011.6835Z'%20stroke='%23000000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e")}[data-theme=dark]{--bg: #0E0D0B;--bg-surface: #161412;--bg-elevated: #1E1C19;--bg-input: #242220;--bg-user-msg: #6D28D9;--code-bg: #0A0908;--code-text: #EAE6F0;--text-primary: #F0EDE7;--text-secondary: #8A8480;--text-muted: #585450;--text-on-accent: #FFFFFF;--accent: #A78BFA;--accent-hover: #C4B5FD;--accent-glow: rgba(167, 139, 250, .18);--accent-light: #1C1530;--accent-subtle: rgba(167, 139, 250, .08);--danger: #F87171;--danger-bg: rgba(248, 113, 113, .09);--success: #34D399;--border: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .13);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 1px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55), 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .65), 0 8px 24px rgba(0, 0, 0, .5);--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Transformed%20by:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%20stroke='%23000000'%3e%3cg%20id='SVGRepo_bgCarrier'%20stroke-width='0'/%3e%3cg%20id='SVGRepo_tracerCarrier'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cg%20id='SVGRepo_iconCarrier'%3e%3cpath%20d='M12%203V4M12%2020V21M4%2012H3M6.31412%206.31412L5.5%205.5M17.6859%206.31412L18.5%205.5M6.31412%2017.69L5.5%2018.5001M17.6859%2017.69L18.5%2018.5001M21%2012H20M16%2012C16%2014.2091%2014.2091%2016%2012%2016C9.79086%2016%208%2014.2091%208%2012C8%209.79086%209.79086%208%2012%208C14.2091%208%2016%209.79086%2016%2012Z'%20stroke='%23e58415'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e")}.typing-row{display:flex;align-items:flex-end;gap:12px;max-width:var(--max-content);margin:0 auto;width:100%;padding:4px 24px 20px;animation:typing-fade-in .25s ease-out}@keyframes typing-fade-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.typing-avatar{width:30px;height:30px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#7c3aed,#a855f7);flex-shrink:0;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #7c3aed40}.typing-avatar-dot{width:12px;height:12px;background:#ffffffe6;border-radius:50%;display:block}.typing-bubble{display:flex;align-items:center;gap:5px;background:var(--bg-elevated);border:1px solid var(--border-input);padding:12px 16px;border-radius:16px 16px 16px 4px;box-shadow:var(--shadow-xs)}.dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);display:inline-block;animation:dot-pulse 1.4s infinite ease-in-out}.dot:nth-child(1){animation-delay:0s}.dot:nth-child(2){animation-delay:.18s}.dot:nth-child(3){animation-delay:.36s}@keyframes dot-pulse{0%,60%,to{transform:translateY(0);opacity:.3}30%{transform:translateY(-5px);opacity:1}}:root{--bg: #F5F4F0;--bg-surface: #FFFFFF;--bg-elevated: #ECEAE4;--bg-input: #F0EEE8;--bg-user-msg: #6D28D9;--code-bg: #18161A;--code-text: #EAE6F0;--text-primary: #1A1714;--text-secondary: #6A6560;--text-muted: #A09B94;--text-on-accent: #FFFFFF;--accent: #7C3AED;--accent-hover: #6D28D9;--accent-glow: rgba(124, 58, 237, .14);--accent-light: #F5F3FF;--accent-subtle: rgba(124, 58, 237, .07);--danger: #DC2626;--danger-bg: rgba(220, 38, 38, .07);--success: #059669;--border: rgba(0, 0, 0, .07);--border-input: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .16);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .05), 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .1), 0 4px 16px rgba(0, 0, 0, .06);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .12), 0 8px 24px rgba(0, 0, 0, .07);--radius-xs: 5px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--navbar-height: 56px;--sidebar-width: 252px;--max-content: 720px;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-sans: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M3.32031%2011.6835C3.32031%2016.6541%207.34975%2020.6835%2012.3203%2020.6835C16.1075%2020.6835%2019.3483%2018.3443%2020.6768%2015.032C19.6402%2015.4486%2018.5059%2015.6834%2017.3203%2015.6834C12.3497%2015.6834%208.32031%2011.654%208.32031%206.68342C8.32031%205.50338%208.55165%204.36259%208.96453%203.32996C5.65605%204.66028%203.32031%207.89912%203.32031%2011.6835Z'%20stroke='%23000000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e")}[data-theme=dark]{--bg: #0E0D0B;--bg-surface: #161412;--bg-elevated: #1E1C19;--bg-input: #242220;--bg-user-msg: #6D28D9;--code-bg: #0A0908;--code-text: #EAE6F0;--text-primary: #F0EDE7;--text-secondary: #8A8480;--text-muted: #585450;--text-on-accent: #FFFFFF;--accent: #A78BFA;--accent-hover: #C4B5FD;--accent-glow: rgba(167, 139, 250, .18);--accent-light: #1C1530;--accent-subtle: rgba(167, 139, 250, .08);--danger: #F87171;--danger-bg: rgba(248, 113, 113, .09);--success: #34D399;--border: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .13);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 1px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55), 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .65), 0 8px 24px rgba(0, 0, 0, .5);--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Transformed%20by:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%20stroke='%23000000'%3e%3cg%20id='SVGRepo_bgCarrier'%20stroke-width='0'/%3e%3cg%20id='SVGRepo_tracerCarrier'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cg%20id='SVGRepo_iconCarrier'%3e%3cpath%20d='M12%203V4M12%2020V21M4%2012H3M6.31412%206.31412L5.5%205.5M17.6859%206.31412L18.5%205.5M6.31412%2017.69L5.5%2018.5001M17.6859%2017.69L18.5%2018.5001M21%2012H20M16%2012C16%2014.2091%2014.2091%2016%2012%2016C9.79086%2016%208%2014.2091%208%2012C8%209.79086%209.79086%208%2012%208C14.2091%208%2016%209.79086%2016%2012Z'%20stroke='%23e58415'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e")}.notes-panel{width:340px;min-width:340px;display:flex;flex-direction:column;background:var(--bg-surface);border-left:1px solid var(--border);height:100%;overflow:hidden;animation:panel-slide-in .24s cubic-bezier(.16,1,.3,1);flex-shrink:0}@keyframes panel-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notes-panel-header{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--bg-surface);flex-shrink:0}.notes-panel-icon{font-size:16px;line-height:1}.notes-panel-title{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.notes-panel-chat-name{font-size:11.5px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.notes-panel-close{margin-left:auto;width:26px;height:26px;border-radius:var(--radius-xs);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;flex-shrink:0}.notes-panel-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.notes-panel-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:var(--border-input) transparent}.notes-draft-box{background:var(--bg-elevated);border:1px solid var(--border-input);border-radius:var(--radius-md);padding:12px;transition:border-color .15s,box-shadow .15s}.notes-draft-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.notes-draft-textarea{width:100%;min-height:68px;font-family:var(--font-sans);font-size:13.5px;line-height:1.65;color:var(--text-primary);background:transparent;border:none;outline:none;resize:none;caret-color:var(--accent)}.notes-draft-textarea::placeholder{color:var(--text-muted)}.notes-draft-actions{display:flex;justify-content:flex-end;margin-top:8px}.notes-save-btn{padding:5px 16px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s,transform .12s;box-shadow:0 2px 8px var(--accent-glow)}.notes-save-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.03)}.notes-save-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.notes-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:32px 0;text-align:center}.notes-empty-icon{font-size:32px;opacity:.3;margin-bottom:4px}.notes-empty-text{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-secondary);margin:0;letter-spacing:-.01em}.notes-empty-hint{font-size:12px;color:var(--text-muted);margin:0}.notes-list{display:flex;flex-direction:column;gap:8px}.notes-date-group{display:flex;flex-direction:column;gap:6px}.notes-date-divider{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:4px 0 2px}.note-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:11px 12px;transition:border-color .15s,box-shadow .15s;animation:note-appear .22s ease-out both}.note-card:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border));box-shadow:var(--shadow-xs)}@keyframes note-appear{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.note-card-content{font-size:13px;line-height:1.7;color:var(--text-primary);margin:0 0 8px;white-space:pre-wrap;word-break:break-word;cursor:text}.note-card-edit-textarea{width:100%;min-height:56px;font-family:var(--font-sans);font-size:13px;line-height:1.65;color:var(--text-primary);background:var(--bg-surface);border:1.5px solid var(--accent);border-radius:var(--radius-xs);padding:6px 8px;outline:none;resize:none;caret-color:var(--accent);margin-bottom:8px;box-shadow:0 0 0 3px var(--accent-glow)}.note-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.note-card-time{font-size:10.5px;color:var(--text-muted);letter-spacing:.01em}.note-card-edited{font-style:italic}.note-card-actions{display:flex;gap:3px;opacity:0;transition:opacity .15s}.note-card:hover .note-card-actions,.note-card:focus-within .note-card-actions{opacity:1}.note-action-btn{width:24px;height:24px;border-radius:var(--radius-xs);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s,border-color .12s}.note-action-btn:hover{background:var(--bg-surface);color:var(--text-secondary);border-color:var(--border-input)}.note-action-btn.danger:hover{color:var(--danger);background:var(--danger-bg);border-color:color-mix(in srgb,var(--danger) 30%,transparent)}.notes-history-link{display:block;width:100%;padding:11px 16px;border-top:1px solid var(--border);background:transparent;border-left:none;border-right:none;border-bottom:none;color:var(--accent);font-size:12.5px;font-weight:500;text-align:center;cursor:pointer;transition:background .12s;flex-shrink:0}.notes-history-link:hover{background:var(--accent-subtle)}@media (max-width: 768px){.notes-panel{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;max-width:100%;z-index:300;border-left:none;border-radius:0;animation:overlay-in .22s ease}}.notes-history-page{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);min-height:0}.notes-history-topbar{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 92%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-shrink:0}.notes-history-back-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-input);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;flex-shrink:0}.notes-history-back-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.notes-history-heading{display:flex;flex-direction:column;overflow:hidden}.notes-history-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-weight:700}.notes-history-chat-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}.notes-history-body{flex:1;overflow-y:auto;padding:28px 20px;max-width:700px;width:100%;margin:0 auto;scrollbar-width:thin;scrollbar-color:var(--border-input) transparent}.notes-history-date-group{margin-bottom:28px}.notes-history-date-label{font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.notes-history-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:8px;transition:border-color .15s,box-shadow .15s;animation:fade-up .3s ease-out both}.notes-history-card:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--border));box-shadow:var(--shadow-sm)}.notes-history-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:60px 0;text-align:center}.notes-history-empty-icon{font-size:44px;opacity:.3;margin-bottom:8px}.notes-history-empty-text{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text-secondary);margin:0;letter-spacing:-.02em}.notes-history-empty-hint{font-size:13px;color:var(--text-muted);margin:0}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}:root{--bg: #F5F4F0;--bg-surface: #FFFFFF;--bg-elevated: #ECEAE4;--bg-input: #F0EEE8;--bg-user-msg: #6D28D9;--code-bg: #18161A;--code-text: #EAE6F0;--text-primary: #1A1714;--text-secondary: #6A6560;--text-muted: #A09B94;--text-on-accent: #FFFFFF;--accent: #7C3AED;--accent-hover: #6D28D9;--accent-glow: rgba(124, 58, 237, .14);--accent-light: #F5F3FF;--accent-subtle: rgba(124, 58, 237, .07);--danger: #DC2626;--danger-bg: rgba(220, 38, 38, .07);--success: #059669;--border: rgba(0, 0, 0, .07);--border-input: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .16);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .05), 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .1), 0 4px 16px rgba(0, 0, 0, .06);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .12), 0 8px 24px rgba(0, 0, 0, .07);--radius-xs: 5px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--navbar-height: 56px;--sidebar-width: 252px;--max-content: 720px;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-sans: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M3.32031%2011.6835C3.32031%2016.6541%207.34975%2020.6835%2012.3203%2020.6835C16.1075%2020.6835%2019.3483%2018.3443%2020.6768%2015.032C19.6402%2015.4486%2018.5059%2015.6834%2017.3203%2015.6834C12.3497%2015.6834%208.32031%2011.654%208.32031%206.68342C8.32031%205.50338%208.55165%204.36259%208.96453%203.32996C5.65605%204.66028%203.32031%207.89912%203.32031%2011.6835Z'%20stroke='%23000000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e")}[data-theme=dark]{--bg: #0E0D0B;--bg-surface: #161412;--bg-elevated: #1E1C19;--bg-input: #242220;--bg-user-msg: #6D28D9;--code-bg: #0A0908;--code-text: #EAE6F0;--text-primary: #F0EDE7;--text-secondary: #8A8480;--text-muted: #585450;--text-on-accent: #FFFFFF;--accent: #A78BFA;--accent-hover: #C4B5FD;--accent-glow: rgba(167, 139, 250, .18);--accent-light: #1C1530;--accent-subtle: rgba(167, 139, 250, .08);--danger: #F87171;--danger-bg: rgba(248, 113, 113, .09);--success: #34D399;--border: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .13);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 1px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55), 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .65), 0 8px 24px rgba(0, 0, 0, .5);--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Transformed%20by:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%20stroke='%23000000'%3e%3cg%20id='SVGRepo_bgCarrier'%20stroke-width='0'/%3e%3cg%20id='SVGRepo_tracerCarrier'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cg%20id='SVGRepo_iconCarrier'%3e%3cpath%20d='M12%203V4M12%2020V21M4%2012H3M6.31412%206.31412L5.5%205.5M17.6859%206.31412L18.5%205.5M6.31412%2017.69L5.5%2018.5001M17.6859%2017.69L18.5%2018.5001M21%2012H20M16%2012C16%2014.2091%2014.2091%2016%2012%2016C9.79086%2016%208%2014.2091%208%2012C8%209.79086%209.79086%208%2012%208C14.2091%208%2016%209.79086%2016%2012Z'%20stroke='%23e58415'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e")}.chat-page-wrapper{display:flex;flex-direction:row;flex:1;overflow:hidden;min-height:0}.chat-page{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;min-width:0}.tutor-header{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);flex-shrink:0}.tutor-header-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.tutor-header-specialty{font-size:12px;color:var(--text-muted);font-weight:400}.notes-toggle-btn{position:relative;margin-left:auto;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border-input);background:transparent;color:var(--text-muted);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s;flex-shrink:0}.notes-toggle-btn:hover{background:var(--bg-elevated);border-color:var(--border-strong);color:var(--text-primary)}.notes-toggle-btn.active{background:var(--accent-subtle);border-color:var(--accent);color:var(--accent)}.notes-count-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;border-radius:var(--radius-full);background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none;letter-spacing:0;box-shadow:0 0 0 2px var(--bg-surface)}.welcome-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;max-width:var(--max-content);margin:0 auto;width:100%;overflow-y:auto}.welcome-icon-wrap{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,#7c3aed,#a855f7,#6d28d9);display:flex;align-items:center;justify-content:center;margin-bottom:28px;box-shadow:0 8px 32px #7c3aed59,0 2px 8px #7c3aed33;animation:icon-pop .55s cubic-bezier(.34,1.56,.64,1);position:relative}.welcome-icon-wrap:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,#ffffff4d,#ffffff0d);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}@keyframes icon-pop{0%{transform:scale(.5) rotate(-10deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.welcome-icon{width:28px;height:28px;filter:brightness(0) invert(1);display:block}.welcome-title{font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.04em;margin-bottom:10px;color:var(--text-primary);animation:fade-up .5s ease-out .12s both;line-height:1.2}.welcome-subtitle{font-size:15px;color:var(--text-secondary);max-width:400px;line-height:1.7;margin-bottom:40px;animation:fade-up .5s ease-out .22s both;font-weight:400}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.prompt-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;animation:fade-up .5s ease-out .32s both}.chip{padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--border-input);background:var(--bg-surface);color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:border-color .15s,color .15s,background .15s,transform .12s,box-shadow .15s;box-shadow:var(--shadow-xs)}.chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.chat-actions{display:flex;justify-content:center;padding:18px 20px 4px}.clear-btn{padding:5px 14px;border-radius:var(--radius-full);border:1px solid var(--border-input);background:transparent;color:var(--text-muted);font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all .15s}.clear-btn:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.messages-list{flex:1;overflow-y:auto;min-height:0;max-width:var(--max-content);margin:0 auto;width:100%;padding:20px 24px;display:flex;flex-direction:column}.message-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px;animation:msg-appear .3s ease-out both}@keyframes msg-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-row.user{flex-direction:row-reverse}.msg-avatar{width:30px;height:30px;border-radius:var(--radius-sm);flex-shrink:0;margin-top:2px;overflow:hidden}.ai-avatar{background:linear-gradient(135deg,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);box-shadow:0 2px 8px #7c3aed40}.ai-avatar img{width:14px;height:14px;filter:brightness(0) invert(1);display:block}.user-avatar-icon{border-radius:50%}.user-avatar-icon img{width:30px;height:30px;border-radius:50%;object-fit:cover;display:block;border:1.5px solid var(--border-input)}.ai-content{flex:1;font-size:15px;line-height:1.8;color:var(--text-primary);min-width:0}.ai-content p{margin-bottom:12px;color:var(--text-primary)}.ai-content p:last-child{margin-bottom:0}.ai-content ul,.ai-content ol{margin:10px 0 12px}.ai-content li{margin-bottom:5px;line-height:1.75}.ai-content h1{font-size:22px;margin:20px 0 10px}.ai-content h2{font-size:18px;margin:18px 0 8px}.ai-content h3{font-size:15px;margin:14px 0 6px}.ai-content blockquote{border-left:3px solid var(--accent);padding:8px 16px;margin:12px 0;background:var(--accent-subtle);border-radius:0 var(--radius-xs) var(--radius-xs) 0;color:var(--text-secondary);font-style:italic}.user-bubble{background:var(--bg-user-msg);color:#fff;padding:11px 18px;border-radius:18px 18px 4px;font-size:15px;line-height:1.65;max-width:80%;box-shadow:0 2px 12px #6d28d94d;word-break:break-word}.user-bubble p{color:#fff;margin:0;font-size:inherit;line-height:inherit}.code-block-wrapper{border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.07);margin:14px 0;font-size:13px}.code-block-header{display:flex;align-items:center;justify-content:space-between;background:#1e1e1e;padding:6px 12px;border-bottom:1px solid rgba(255,255,255,.08);min-height:34px}.code-lang-label{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);opacity:.9}.copy-button{padding:3px 10px;border-radius:var(--radius-xs);background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#9ca3af;font-size:11px;font-family:var(--font-sans);font-weight:500;cursor:pointer;transition:background .15s,color .15s;letter-spacing:.01em;margin-left:auto}.copy-button:hover{background:#ffffff1f;color:#e5e7eb}.input-area{flex-shrink:0;padding:8px 20px 16px;background:linear-gradient(to bottom,transparent 0%,var(--bg) 30%)}.input-form{max-width:var(--max-content);margin:0 auto}.input-wrapper{display:flex;align-items:flex-end;gap:10px;background:var(--bg-surface);border:1px solid var(--border-input);border-radius:var(--radius-lg);padding:10px 10px 10px 18px;box-shadow:var(--shadow-md);transition:border-color .2s,box-shadow .2s}.input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow),var(--shadow-md)}.msg-input{flex:1;font-family:var(--font-sans);font-size:15px;line-height:1.6;color:var(--text-primary);background:transparent;border:none;outline:none;resize:none;padding:2px 0;max-height:160px;min-height:26px;caret-color:var(--accent)}.msg-input::placeholder{color:var(--text-muted)}.send-btn{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:background .15s,transform .12s,opacity .15s,box-shadow .15s;align-self:flex-end;box-shadow:0 2px 8px #7c3aed4d}.send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.07);box-shadow:0 4px 12px #7c3aed66}.send-btn:disabled{opacity:.25;cursor:not-allowed;transform:none;box-shadow:none}.send-btn img{width:14px;height:14px;filter:brightness(0) invert(1);display:block}.input-hint{text-align:center;font-size:11px;color:var(--text-muted);margin-top:6px;line-height:1}.footer-attribution{display:flex;justify-content:center;margin-top:6px}.footer-attribution p{font-size:11px;color:var(--text-muted);line-height:1.4}.footer-attribution a{color:var(--text-muted);font-weight:500;transition:color .15s}.footer-attribution a:hover{color:var(--accent)}@media (max-width: 768px){.messages-list{padding:14px 16px}.welcome-state{padding:40px 20px 28px}.welcome-title{font-size:24px}.welcome-subtitle{font-size:14px}.chip{font-size:12.5px;padding:7px 14px}.user-bubble{max-width:86%;padding:10px 15px;font-size:14.5px}.ai-content{font-size:14.5px}.input-area{padding:6px 14px 14px}.input-wrapper{padding:9px 9px 9px 16px}.msg-input{font-size:14.5px}.input-hint{display:none}}:root{--bg: #F5F4F0;--bg-surface: #FFFFFF;--bg-elevated: #ECEAE4;--bg-input: #F0EEE8;--bg-user-msg: #6D28D9;--code-bg: #18161A;--code-text: #EAE6F0;--text-primary: #1A1714;--text-secondary: #6A6560;--text-muted: #A09B94;--text-on-accent: #FFFFFF;--accent: #7C3AED;--accent-hover: #6D28D9;--accent-glow: rgba(124, 58, 237, .14);--accent-light: #F5F3FF;--accent-subtle: rgba(124, 58, 237, .07);--danger: #DC2626;--danger-bg: rgba(220, 38, 38, .07);--success: #059669;--border: rgba(0, 0, 0, .07);--border-input: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .16);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .05), 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .1), 0 4px 16px rgba(0, 0, 0, .06);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .12), 0 8px 24px rgba(0, 0, 0, .07);--radius-xs: 5px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--navbar-height: 56px;--sidebar-width: 252px;--max-content: 720px;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-sans: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M3.32031%2011.6835C3.32031%2016.6541%207.34975%2020.6835%2012.3203%2020.6835C16.1075%2020.6835%2019.3483%2018.3443%2020.6768%2015.032C19.6402%2015.4486%2018.5059%2015.6834%2017.3203%2015.6834C12.3497%2015.6834%208.32031%2011.654%208.32031%206.68342C8.32031%205.50338%208.55165%204.36259%208.96453%203.32996C5.65605%204.66028%203.32031%207.89912%203.32031%2011.6835Z'%20stroke='%23000000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e")}[data-theme=dark]{--bg: #0E0D0B;--bg-surface: #161412;--bg-elevated: #1E1C19;--bg-input: #242220;--bg-user-msg: #6D28D9;--code-bg: #0A0908;--code-text: #EAE6F0;--text-primary: #F0EDE7;--text-secondary: #8A8480;--text-muted: #585450;--text-on-accent: #FFFFFF;--accent: #A78BFA;--accent-hover: #C4B5FD;--accent-glow: rgba(167, 139, 250, .18);--accent-light: #1C1530;--accent-subtle: rgba(167, 139, 250, .08);--danger: #F87171;--danger-bg: rgba(248, 113, 113, .09);--success: #34D399;--border: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .13);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 1px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55), 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .65), 0 8px 24px rgba(0, 0, 0, .5);--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Transformed%20by:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%20stroke='%23000000'%3e%3cg%20id='SVGRepo_bgCarrier'%20stroke-width='0'/%3e%3cg%20id='SVGRepo_tracerCarrier'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cg%20id='SVGRepo_iconCarrier'%3e%3cpath%20d='M12%203V4M12%2020V21M4%2012H3M6.31412%206.31412L5.5%205.5M17.6859%206.31412L18.5%205.5M6.31412%2017.69L5.5%2018.5001M17.6859%2017.69L18.5%2018.5001M21%2012H20M16%2012C16%2014.2091%2014.2091%2016%2012%2016C9.79086%2016%208%2014.2091%208%2012C8%209.79086%209.79086%208%2012%208C14.2091%208%2016%209.79086%2016%2012Z'%20stroke='%23e58415'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e")}.navbar{position:sticky;top:0;height:var(--navbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:color-mix(in srgb,var(--bg-surface) 88%,transparent);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0}.navbar-left{display:flex;align-items:center}.sidebar-toggle{width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-secondary);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.sidebar-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.toggle-icon{display:block;line-height:1}.navbar-actions{display:flex;align-items:center;gap:8px}.login-area{display:flex;align-items:center}.profile{position:relative;cursor:pointer}.img-profile{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border-input);display:block;transition:border-color .2s,transform .2s,box-shadow .2s;object-fit:cover}.img-profile:hover{border-color:var(--accent);transform:scale(1.06);box-shadow:0 0 0 3px var(--accent-glow)}.dropdown{position:absolute;top:calc(100% + 8px);right:0;z-index:1001;min-width:232px}.dropdown-content{background:var(--bg-surface);border:1px solid var(--border-input);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);padding:6px;overflow:hidden;animation:dropdown-in .18s cubic-bezier(.16,1,.3,1)}@keyframes dropdown-in{0%{opacity:0;transform:scale(.97) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.dropdown-user{display:flex;align-items:center;gap:10px;padding:10px 10px 12px}.dropdown-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;object-fit:cover;border:1.5px solid var(--border)}.dropdown-name{font-size:13px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3;letter-spacing:-.01em}.dropdown-email{font-size:11.5px;color:var(--text-muted);margin:0;line-height:1.5}.dropdown-item{display:block;padding:7px 10px;font-size:13px;color:var(--text-secondary);border-radius:var(--radius-xs);transition:background .12s,color .12s;cursor:pointer}.dropdown-item:hover{background:var(--bg-elevated);color:var(--text-primary);text-decoration:none}.dropdown-divider{height:1px;background:var(--border);margin:4px 2px}.dropdown-logout{width:100%;text-align:left;padding:7px 10px;border-radius:var(--radius-xs);font-size:13px;font-family:var(--font-sans);font-weight:500;color:var(--danger);cursor:pointer;transition:background .12s;display:block}.dropdown-logout:hover{background:var(--danger-bg)}.login-buttons{display:flex;align-items:center;gap:7px}.btn-google-login{display:flex;align-items:center;gap:7px;padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border-input);background:var(--bg-surface);color:var(--text-primary);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all .15s;box-shadow:var(--shadow-xs)}.btn-google-login:hover{background:var(--bg-elevated);border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.btn-github-login{display:flex;align-items:center;gap:7px;padding:6px 14px;border-radius:var(--radius-full);border:1px solid transparent;background:#1a1a1a;color:#f4f4f4;font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all .15s;box-shadow:var(--shadow-xs)}.btn-github-login:hover{background:#111;box-shadow:var(--shadow-sm)}[data-theme=dark] .btn-github-login{background:#ffffff14;border-color:#ffffff1a;color:var(--text-primary)}[data-theme=dark] .btn-github-login:hover{background:#ffffff21}@media (max-width: 768px){.navbar{padding:0 14px}.btn-google-login span,.btn-github-login span{display:none}.btn-google-login,.btn-github-login{padding:6px 10px;gap:0}}.theme-toggle{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-input);cursor:pointer;transition:background .15s,border-color .15s,transform .15s;flex-shrink:0}.theme-toggle:hover{background:var(--bg-input);border-color:var(--border-strong);transform:scale(1.06)}.theme-icon{opacity:.7;display:block;transition:opacity .2s,transform .3s ease}[data-theme=dark] .theme-icon{filter:brightness(1.8);opacity:.8}.theme-toggle:hover .theme-icon{opacity:1;transform:rotate(15deg)}.sidebar{width:var(--sidebar-width, 252px);min-width:var(--sidebar-width, 252px);height:100vh;display:flex;flex-direction:column;background:var(--bg-surface);border-right:1px solid var(--border);overflow:hidden;transition:width .25s cubic-bezier(.4,0,.2,1),min-width .25s cubic-bezier(.4,0,.2,1),opacity .2s ease;flex-shrink:0}.sidebar.sidebar-collapsed{width:0;min-width:0;border-right:none;opacity:0;pointer-events:none}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 14px 14px;border-bottom:1px solid var(--border);gap:8px;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:9px;overflow:hidden}.sidebar-brand img{flex-shrink:0;opacity:.7;filter:var(--brand-icon-filter, none)}[data-theme=dark] .sidebar-brand img{opacity:.65;filter:brightness(0) invert(1)}.sidebar-brand span{font-family:var(--font-display);font-size:13.5px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.new-chat-btn{flex-shrink:0;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--bg-elevated);color:var(--text-secondary);font-size:1.15rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,transform .15s}.new-chat-btn:hover{background:var(--accent-subtle);border-color:var(--accent);color:var(--accent);transform:scale(1.05)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0 16px}.sidebar-empty{font-size:12.5px;color:var(--text-muted);text-align:center;padding:28px 16px;line-height:1.6}.chat-list{list-style:none;margin:0;padding:0 8px;display:flex;flex-direction:column;gap:1px}.chat-item{display:flex;align-items:center;border-radius:var(--radius-sm);overflow:hidden;position:relative;transition:background .12s}.chat-item:hover{background:var(--bg-elevated)}.chat-item.active,.chat-item.active:hover{background:var(--accent-subtle)}.chat-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2.5px;height:60%;background:var(--accent);border-radius:0 2px 2px 0}.chat-item-btn{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:9px 10px 9px 12px;background:transparent;border:none;cursor:pointer;text-align:left;min-width:0}.chat-item-title-row{display:flex;align-items:center;gap:7px;width:100%;min-width:0}.chat-item-title{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;line-height:1.3}.chat-item.active .chat-item-title{color:var(--accent)}.chat-item-date{font-size:11px;color:var(--text-muted);letter-spacing:.01em}.chat-delete-btn,.chat-rename-btn{flex-shrink:0;width:24px;height:24px;border:none;background:transparent;font-size:13px;line-height:1;cursor:pointer;border-radius:var(--radius-xs);display:none;align-items:center;justify-content:center;transition:color .12s,background .12s;color:var(--text-muted)}.chat-rename-btn{margin-right:2px;font-size:11px}.chat-delete-btn{margin-right:6px}.chat-item:hover .chat-delete-btn,.chat-item:hover .chat-rename-btn{display:flex}.chat-rename-btn:hover{color:var(--accent);background:var(--accent-subtle)}.chat-delete-btn:hover{color:var(--danger);background:var(--danger-bg)}.chat-item-edit{flex:1;padding:8px 10px 8px 12px;min-width:0}.chat-title-input{width:100%;background:var(--bg-surface);border:1.5px solid var(--accent);border-radius:var(--radius-xs);padding:3px 8px;font-size:13px;font-family:var(--font-sans);font-weight:500;color:var(--text-primary);outline:none;box-shadow:0 0 0 3px var(--accent-glow)}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;height:100%;width:280px;min-width:280px;z-index:200;transform:translate(0);transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .2s ease;box-shadow:var(--shadow-xl)}.sidebar.sidebar-collapsed{width:280px;min-width:280px;transform:translate(-100%);opacity:1;pointer-events:none;border-right:1px solid var(--border)}.chat-item .chat-delete-btn,.chat-item .chat-rename-btn{display:flex}}.tutor-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;backdrop-filter:blur(6px) saturate(150%);-webkit-backdrop-filter:blur(6px) saturate(150%);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px;animation:overlay-fade-in .18s ease}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.tutor-picker-modal{background:var(--bg-surface);border:1px solid var(--border-input);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:580px;max-height:88vh;overflow-y:auto;animation:modal-spring .28s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-spring{0%{opacity:0;transform:scale(.93) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.tutor-picker-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:24px 24px 18px}.tutor-picker-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--text-primary);margin:0 0 5px;letter-spacing:-.025em;line-height:1.2}.tutor-picker-subtitle{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.tutor-picker-close{flex-shrink:0;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border-input);background:transparent;color:var(--text-muted);font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.tutor-picker-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.tutor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 20px}.tutor-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:7px;padding:16px 15px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:border-color .15s,transform .14s cubic-bezier(.34,1.56,.64,1),box-shadow .15s;overflow:hidden}.tutor-card:hover{border-color:var(--agent-color, var(--accent));transform:translateY(-3px) scale(1.01);box-shadow:0 6px 20px #0000001a}[data-theme=dark] .tutor-card:hover{box-shadow:0 6px 20px #00000073}.tutor-card-accent{position:absolute;top:0;left:0;right:0;height:2.5px;background:var(--agent-color, var(--accent));border-radius:var(--radius-md) var(--radius-md) 0 0;opacity:.85}.tutor-card-icon{font-size:1.45rem;line-height:1;margin-top:3px}.tutor-card-name{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--text-primary);line-height:1.2;letter-spacing:-.01em}.tutor-card-desc{font-size:.72rem;color:var(--text-secondary);line-height:1.45}.tutor-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.tutor-tag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:var(--radius-xs);background:var(--bg-surface);border:1px solid var(--border-input);color:var(--text-muted);white-space:nowrap;letter-spacing:.01em}.tutor-picker-footer{padding:14px 20px 22px}.tutor-auto-btn{width:100%;display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--accent-subtle);border:1px solid var(--accent-glow);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:border-color .15s,background .15s,transform .12s}.tutor-auto-btn:hover{border-color:color-mix(in srgb,var(--accent) 50%,transparent);background:var(--accent-light);transform:translateY(-1px)}.tutor-auto-icon{font-size:1.4rem;flex-shrink:0}.tutor-auto-label{font-size:.875rem;font-weight:600;color:var(--accent);font-family:var(--font-display);letter-spacing:-.01em}.tutor-auto-hint{font-size:12px;color:var(--text-secondary);margin-top:2px}@media (max-width: 540px){.tutor-grid{grid-template-columns:repeat(2,1fr);padding:0 16px}.tutor-picker-header{padding:20px 16px 14px}.tutor-picker-footer{padding:12px 16px 20px}}#root{width:100%;min-height:100vh;background-color:var(--bg);color:var(--text-primary)}.app-shell{display:flex;height:100vh;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;min-height:0;background:var(--bg)}.sidebar-overlay,.notes-panel-overlay{display:none}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:199;animation:overlay-in .2s ease}.notes-panel-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:299;animation:overlay-in .2s ease}}:root{--bg: #F5F4F0;--bg-surface: #FFFFFF;--bg-elevated: #ECEAE4;--bg-input: #F0EEE8;--bg-user-msg: #6D28D9;--code-bg: #18161A;--code-text: #EAE6F0;--text-primary: #1A1714;--text-secondary: #6A6560;--text-muted: #A09B94;--text-on-accent: #FFFFFF;--accent: #7C3AED;--accent-hover: #6D28D9;--accent-glow: rgba(124, 58, 237, .14);--accent-light: #F5F3FF;--accent-subtle: rgba(124, 58, 237, .07);--danger: #DC2626;--danger-bg: rgba(220, 38, 38, .07);--success: #059669;--border: rgba(0, 0, 0, .07);--border-input: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .16);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .05), 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .1), 0 4px 16px rgba(0, 0, 0, .06);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .12), 0 8px 24px rgba(0, 0, 0, .07);--radius-xs: 5px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--navbar-height: 56px;--sidebar-width: 252px;--max-content: 720px;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-sans: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M3.32031%2011.6835C3.32031%2016.6541%207.34975%2020.6835%2012.3203%2020.6835C16.1075%2020.6835%2019.3483%2018.3443%2020.6768%2015.032C19.6402%2015.4486%2018.5059%2015.6834%2017.3203%2015.6834C12.3497%2015.6834%208.32031%2011.654%208.32031%206.68342C8.32031%205.50338%208.55165%204.36259%208.96453%203.32996C5.65605%204.66028%203.32031%207.89912%203.32031%2011.6835Z'%20stroke='%23000000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e")}[data-theme=dark]{--bg: #0E0D0B;--bg-surface: #161412;--bg-elevated: #1E1C19;--bg-input: #242220;--bg-user-msg: #6D28D9;--code-bg: #0A0908;--code-text: #EAE6F0;--text-primary: #F0EDE7;--text-secondary: #8A8480;--text-muted: #585450;--text-on-accent: #FFFFFF;--accent: #A78BFA;--accent-hover: #C4B5FD;--accent-glow: rgba(167, 139, 250, .18);--accent-light: #1C1530;--accent-subtle: rgba(167, 139, 250, .08);--danger: #F87171;--danger-bg: rgba(248, 113, 113, .09);--success: #34D399;--border: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .13);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 1px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55), 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .65), 0 8px 24px rgba(0, 0, 0, .5);--background: var(--bg);--imput-color: var(--bg-input);--imput-text-color: var(--text-primary);--bg-img-toggle: url("data:image/svg+xml,%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Transformed%20by:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20width='800px'%20height='800px'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%20stroke='%23000000'%3e%3cg%20id='SVGRepo_bgCarrier'%20stroke-width='0'/%3e%3cg%20id='SVGRepo_tracerCarrier'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3cg%20id='SVGRepo_iconCarrier'%3e%3cpath%20d='M12%203V4M12%2020V21M4%2012H3M6.31412%206.31412L5.5%205.5M17.6859%206.31412L18.5%205.5M6.31412%2017.69L5.5%2018.5001M17.6859%2017.69L18.5%2018.5001M21%2012H20M16%2012C16%2014.2091%2014.2091%2016%2012%2016C9.79086%2016%208%2014.2091%208%2012C8%209.79086%209.79086%208%2012%208C14.2091%208%2016%209.79086%2016%2012Z'%20stroke='%23e58415'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e")}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:var(--font-sans);font-size:15px;line-height:1.65;font-weight:400;color:var(--text-primary);background-color:var(--bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:var(--accent);text-decoration:none;font-weight:500;transition:color .15s}a:hover{color:var(--accent-hover)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.25;letter-spacing:-.025em;color:var(--text-primary)}p{color:var(--text-primary);line-height:1.75}ul,ol{padding-left:1.5em}li{margin-bottom:4px;line-height:1.7}strong{font-weight:650}button{font-family:var(--font-sans);font-size:14px;font-weight:500;cursor:pointer;border:none;background:none;color:inherit;transition:all .15s ease}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-xs)}code{font-family:var(--font-mono);font-size:13px;font-weight:500;background:var(--bg-elevated);padding:2px 6px;border-radius:var(--radius-xs);color:var(--accent);border:1px solid var(--border-input)}pre{font-family:var(--font-mono);font-size:13px;background:var(--code-bg)!important;color:var(--code-text)!important;padding:20px!important;border-radius:var(--radius-md)!important;overflow-x:auto;width:100%;line-height:1.7;position:relative;border:1px solid rgba(255,255,255,.06);margin:14px 0}pre code{background:none!important;padding:0;font-size:inherit;color:inherit!important;border-radius:0;border:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-glow);color:var(--text-primary)}.focus-ring:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
