:root{
  /* ===== Notion palette (warm neutrals) ===== */
  --bg:#ffffff;
  --sidebar-bg:rgb(247,247,245);          /* #f7f7f5 */
  --text:rgb(55,53,47);                    /* #37352f */
  --muted:rgb(120,119,116);                /* #787774 */
  --faint:rgb(155,154,151);                /* #9b9a97 — section labels / very muted */
  --nav-text:rgb(95,94,91);                /* #5f5e5b — resting nav row text */
  --hairline:rgba(55,53,47,.09);           /* ≈ #e9e9e7 1px dividers */
  --hairline-solid:#e9e9e7;
  --hover:rgba(55,53,47,.06);              /* hover fill */
  --active:rgba(55,53,47,.08);             /* active/selected fill */
  --row-hover:rgba(55,53,47,.04);          /* full-row list hover */
  --rail-bg:#fbfbfa;                       /* ask rail / right panel */
  --accent:rgb(35,131,226);                /* #2383e2 */
  --accent-hover:#1a6fc4;
  --accent-active:#155a9e;
  --accent-ring:rgba(35,131,226,.35);      /* focus-visible ring */
  --danger:#eb5757;
  --danger-soft:rgba(235,87,87,.08);
  --success:#0f7b6c;                        /* Notion green (text) */
  --success-bg:rgba(15,123,108,.07);
  --success-border:rgba(15,123,108,.22);
  --surface:#ffffff;
  --surface-tint:rgba(55,53,47,.04);       /* light filled input/gray */
  --code-bg:rgba(55,53,47,.06);
  --disabled-bg:rgba(55,53,47,.16);

  --font-sans:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,"Apple Color Emoji",Arial,sans-serif,"Segoe UI Emoji","Segoe UI Symbol";
  --font-mono:ui-monospace,"SFMono-Regular","SF Mono",Menlo,Consolas,"Liberation Mono",monospace;

  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;--s12:48px;

  /* Notion uses a uniform small radius */
  --r-ctl:4px;--r-card:4px;--r-dialog:6px;

  /* Notion's elevation stack — only for popovers/dialogs/snackbar */
  --shadow-pop:rgba(15,15,15,.05) 0px 0px 0px 1px,rgba(15,15,15,.1) 0px 3px 6px,rgba(15,15,15,.2) 0px 9px 24px;
  --shadow-soft:rgba(15,15,15,.05) 0px 0px 0px 1px,rgba(15,15,15,.1) 0px 3px 6px;

  --dur:60ms;          /* default control transition */
  --dur-fast:20ms;     /* presses */
  --dur-slow:120ms;    /* overlays */
  --sidebar-w:240px;
  --content-max:900px;
  --rail-w:400px;
}
*{box-sizing:border-box}
*{scrollbar-width:thin;scrollbar-color:rgba(55,53,47,.2) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:rgba(55,53,47,.2);border:3px solid transparent;background-clip:padding-box;border-radius:8px}
*::-webkit-scrollbar-thumb:hover{background:rgba(55,53,47,.32);background-clip:padding-box}
*::-webkit-scrollbar-track{background:transparent}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{margin:0;font-family:var(--font-sans);font-size:14px;line-height:1.5;background:var(--bg);color:var(--text)}
.hidden{display:none!important}
a{color:var(--accent);text-decoration:none;border-radius:2px;transition:color var(--dur)}
a:hover{text-decoration:underline}
a:active{color:var(--accent-active)}
a:focus-visible{outline:none;box-shadow:var(--accent-ring) 0 0 0 2px}
::selection{background:rgba(35,131,226,.2)}
:focus-visible{outline:none}
code{font-family:var(--font-mono);font-size:.85em;background:var(--code-bg);color:#eb5757;padding:.15em .35em;border-radius:var(--r-ctl);word-break:break-word}
kbd{font-family:var(--font-mono);font-size:.85em;color:var(--text)}
.logo{width:40px;height:40px;margin:0 auto var(--s4);display:block}
.logo.sm{width:18px;height:18px;margin:0}

@keyframes rise{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes shimmer{to{transform:translateX(100%)}}
@keyframes dialog-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ============ AUTH ============ */
.auth{min-height:100vh;display:grid;place-items:center;padding:var(--s5);background:var(--bg)}
.card{width:380px;max-width:100%;background:var(--surface);border-radius:var(--r-dialog);padding:var(--s10) var(--s8);text-align:center;box-shadow:var(--shadow-pop)}
.card h1{font-size:26px;font-weight:700;margin:0 0 var(--s1);letter-spacing:-.02em;color:var(--text)}
.sub{font-size:14px;color:var(--muted);margin:0 0 var(--s6)}
.tabs{display:flex;gap:var(--s1);padding:0;background:transparent;border-bottom:1px solid var(--hairline);margin-bottom:var(--s5)}
.tab{flex:1;border:none;background:transparent;color:var(--muted);padding:var(--s2) 0;height:auto;border-radius:0;border-bottom:2px solid transparent;font-size:14px;font-weight:500;cursor:pointer;transition:color var(--dur),border-color var(--dur);margin-bottom:-1px}
.tab:hover{color:var(--text)}
.tab.active{color:var(--text);border-bottom-color:var(--text);box-shadow:none}
form{display:grid;gap:var(--s3)}
.card form .primary{margin-top:var(--s2);width:100%}
.msg{font-size:12px;min-height:18px;margin:var(--s4) 0 0;color:var(--muted)}
.msg.err{color:var(--danger)}.msg.ok{color:var(--success)}

/* ============ INPUTS (subtle Notion fields) ============ */
input,select,textarea{width:100%;height:32px;padding:0 var(--s3);font-family:inherit;font-size:14px;color:var(--text);background:var(--surface-tint);border:1px solid transparent;border-radius:var(--r-ctl);outline:none;transition:background var(--dur),border-color var(--dur),box-shadow var(--dur)}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:hover,select:hover,textarea:hover{background:var(--hover)}
input:focus,select:focus,textarea:focus,input:focus-visible,select:focus-visible,textarea:focus-visible{background:var(--surface);border-color:var(--accent);box-shadow:var(--accent-ring) 0 0 0 1px}
input:disabled,select:disabled,textarea:disabled{background:var(--surface-tint);color:var(--faint);cursor:not-allowed}
input:disabled::placeholder,textarea:disabled::placeholder{color:rgba(55,53,47,.25)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%23787774' stroke-width='1.8'%3E%3Cpath d='M5 7l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:32px}

/* ============ BUTTONS ============ */
button{font-family:inherit;font-size:14px;cursor:pointer}
button:disabled{cursor:not-allowed}
/* primary = Notion blue, used sparingly for true primary actions */
.primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;background:var(--accent);color:#fff;border-radius:var(--r-ctl);padding:0 var(--s3);height:32px;font-weight:500;line-height:1;box-shadow:none;transition:background var(--dur)}
.primary:hover{background:var(--accent-hover)}
.primary:active{background:var(--accent-active);transition-duration:var(--dur-fast)}
.primary:focus-visible{box-shadow:var(--accent-ring) 0 0 0 2px}
.primary:disabled{background:var(--disabled-bg);color:#fff;opacity:.9}
.primary.sm{height:28px;padding:0 var(--s2);font-size:13px}
/* ghost = quiet button, transparent w/ gray hover */
.ghost{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;border:none;color:var(--text);border-radius:var(--r-ctl);padding:0 var(--s2);height:32px;font-weight:500;line-height:1;transition:background var(--dur),color var(--dur)}
.ghost:hover{background:var(--hover)}
.ghost:active{background:var(--active);transition-duration:var(--dur-fast)}
.ghost:focus-visible{box-shadow:var(--accent-ring) 0 0 0 2px}
.ghost:disabled{color:var(--faint);background:transparent}
.ghost.sm{height:28px;padding:0 var(--s2);font-size:13px;color:var(--muted)}
.ghost.sm:hover{color:var(--text)}
.icon-btn,.close{display:grid;place-items:center;width:28px;height:28px;border-radius:var(--r-ctl);background:transparent;border:none;color:var(--muted);margin:0;transition:background var(--dur),color var(--dur)}
.icon-btn svg,.close svg{width:18px;height:18px}
.icon-btn:hover,.close:hover{background:var(--hover);color:var(--text)}
.icon-btn:active,.close:active{background:var(--active);transition-duration:var(--dur-fast)}
.icon-btn:focus-visible,.close:focus-visible{box-shadow:var(--accent-ring) 0 0 0 2px}
.close{position:absolute;top:var(--s3);right:var(--s3)}
.btn-ic{width:16px;height:16px;flex:0 0 auto}

/* ============ APP SHELL: sidebar + main + rail ============ */
.app{display:flex;align-items:stretch;min-height:100vh}
.sidebar{flex:0 0 var(--sidebar-w);width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--hairline);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:var(--s2) var(--s2) var(--s2);z-index:30}
.sidebar-head{display:flex;align-items:center;gap:var(--s2);padding:6px var(--s2);min-height:28px;border-radius:var(--r-ctl);cursor:default;transition:background var(--dur);margin-bottom:var(--s2)}
.sidebar-head:hover{background:var(--hover)}
.sidebar-name{font-size:14px;font-weight:600;letter-spacing:-.01em;color:var(--text)}
.sidebar-nav{display:flex;flex-direction:column;gap:1px}
.sidebar-label{font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--faint);padding:6px var(--s2) 2px}
.sidebar-sep{height:1px;background:var(--hairline);margin:var(--s2) var(--s2)}

/* Notion sidebar rows — compact, dense */
.navbtn{display:flex;align-items:center;gap:var(--s2);width:100%;min-height:28px;text-align:left;background:transparent;border:none;color:var(--nav-text);font-size:14px;font-weight:500;padding:4px var(--s2);border-radius:var(--r-ctl);cursor:pointer;line-height:1.2;transition:background var(--dur),color var(--dur)}
.navbtn .nav-ic{width:18px;height:18px;flex:0 0 auto;color:var(--faint);transition:color var(--dur)}
.navbtn:hover{background:var(--hover);color:var(--text)}
.navbtn:hover .nav-ic{color:var(--muted)}
.navbtn.active{background:var(--active);color:var(--text);font-weight:600}
.navbtn.active .nav-ic{color:var(--text)}
.navbtn:focus-visible{box-shadow:var(--accent-ring) 0 0 0 2px}
.ask-toggle[aria-pressed="true"]{background:var(--active);color:var(--text);font-weight:600}
.ask-toggle[aria-pressed="true"] .nav-ic{color:var(--accent)}

.sidebar-foot{margin-top:auto;display:flex;align-items:center;gap:var(--s2);padding:6px 6px 6px var(--s2);border-top:1px solid var(--hairline)}
.account{display:flex;align-items:center;gap:var(--s2);min-width:0;flex:1;border-radius:var(--r-ctl);padding:2px;margin:-2px}
.account-avatar{flex:0 0 auto;width:22px;height:22px;border-radius:var(--r-ctl);background:var(--text);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:600;line-height:1;text-transform:uppercase}
.who{color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* mobile hamburger */
.sidebar-toggle{display:none;position:fixed;top:10px;left:10px;z-index:50;width:32px;height:32px;border:none;background:var(--surface);border-radius:var(--r-ctl);color:var(--text);place-items:center;box-shadow:var(--shadow-soft)}
.sidebar-toggle svg{width:18px;height:18px}

/* ============ LAYOUT ============ */
.app-body{display:flex;align-items:stretch;gap:0;flex:1 1 auto;min-width:0}
.main{flex:1 1 auto;min-width:0}
.view{max-width:var(--content-max);margin:0 auto;padding:var(--s12) clamp(var(--s6),6vw,96px) var(--s12)}
.view-title{font-size:32px;font-weight:700;letter-spacing:-.02em;color:var(--text);line-height:1.2;margin:0 0 var(--s2)}
.view-desc{font-size:14px;color:var(--muted);margin:0 0 var(--s8);line-height:1.5}

/* ============ TOOLBAR / SEARCH ============ */
.toolbar{display:flex;gap:var(--s2);align-items:center;margin-bottom:var(--s4)}
.toolbar input[type=search],.toolbar input[type=text]{flex:1;height:32px;border-radius:var(--r-ctl);background:var(--surface-tint);border:1px solid transparent;box-shadow:none;padding:0 var(--s3) 0 32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23787774' stroke-width='2'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cpath d='M11 11l4 4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:10px center;font-size:14px}
.toolbar input[type=search]:hover,.toolbar input[type=text]:hover{background-color:var(--hover)}
.toolbar input[type=search]:focus,.toolbar input[type=text]:focus,.toolbar input[type=search]:focus-visible,.toolbar input[type=text]:focus-visible{background-color:var(--surface);border-color:var(--accent);box-shadow:var(--accent-ring) 0 0 0 1px}
.live{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--muted);user-select:none}
.toolbar .live{margin-left:auto}
#add-source{white-space:nowrap}
.live .dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:livepulse 2.4s infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(15,123,108,.4)}70%{box-shadow:0 0 0 5px rgba(15,123,108,0)}100%{box-shadow:0 0 0 0 rgba(15,123,108,0)}}

/* ============ ADD SOURCE ============ */
.add-actions{display:flex;align-items:center;gap:var(--s2);margin-top:var(--s4)}
#add-msg{margin-left:auto}
.opt{color:var(--muted);font-weight:400}
textarea#add-input{width:100%;min-height:120px;height:auto;resize:vertical;font:inherit;line-height:1.5;padding:var(--s3)}
#add-hint{font-size:12px;color:var(--muted);min-height:16px;margin:6px 0}

/* ============ LIST / ROWS (Notion clean rows, hairline-separated) ============ */
.list{display:flex;flex-direction:column;border-top:1px solid var(--hairline)}
.item{position:relative;background:transparent;border:none;border-bottom:1px solid var(--hairline);border-radius:0;padding:var(--s3) var(--s2);cursor:pointer;transition:background var(--dur);animation:rise 160ms ease both}
.item:hover{background:var(--row-hover)}
.item:active{background:var(--active);transition-duration:var(--dur-fast)}
.item:focus-visible{box-shadow:var(--accent-ring) 0 0 0 2px inset}
.item .t{font-size:14px;font-weight:500;color:var(--text);margin-bottom:3px;line-height:1.4;overflow:hidden;text-overflow:ellipsis}
.item .meta{font-size:12px;color:var(--muted);display:flex;gap:var(--s3);flex-wrap:wrap;align-items:center}
.badge{display:inline-flex;align-items:center;height:18px;padding:0 6px;font-size:11px;font-weight:500;letter-spacing:.01em;text-transform:capitalize;background:var(--code-bg);color:var(--muted);border-radius:var(--r-ctl);white-space:nowrap}
.tag{font-size:12px;color:var(--faint);font-weight:500}
.empty{display:grid;justify-items:center;gap:var(--s2);text-align:center;padding:var(--s12) var(--s6);color:var(--muted);font-size:14px;line-height:1.5;animation:fade 160ms ease both}
.empty .empty-icon{width:48px;height:48px;margin-bottom:var(--s1);display:grid;place-items:center;border-radius:var(--r-card);background:var(--code-bg);color:var(--faint)}
.empty .empty-icon svg{width:24px;height:24px}
.empty h3{font-size:15px;font-weight:600;color:var(--text);margin:0}
.empty div{max-width:340px}
.newkey{background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--r-card);padding:var(--s4);margin-bottom:var(--s4);color:var(--success);font-size:13px;font-weight:500;animation:rise 160ms ease both}
.newkey code{display:block;word-break:break-all;margin:var(--s3) 0;background:var(--surface);color:var(--text);font-weight:400;padding:var(--s3);border-radius:var(--r-ctl);border:1px solid var(--hairline)}
.newkey .ghost{background:var(--surface);border:1px solid var(--hairline);color:var(--text)}
.newkey .ghost:hover{background:var(--hover)}

/* ============ PANELS ============ */
.panel{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-card);padding:var(--s6)}
.panel h2{font-size:17px;font-weight:600;margin:0 0 var(--s2);letter-spacing:-.01em;color:var(--text)}
.steps{line-height:1.7;font-size:14px;color:var(--text);padding-left:var(--s5)}
.steps li{margin:var(--s2) 0}
.set-help{font-size:14px;color:var(--muted);margin:2px 0 var(--s5);line-height:1.5}
.steps code{color:var(--text);background:var(--code-bg);font-weight:500;padding:.12em .4em}
.steps a{font-weight:500}
.steps b{font-weight:600}
.steps ul{margin:var(--s2) 0;padding-left:var(--s5)}

/* ============ SKELETON ============ */
.skeleton{position:relative;overflow:hidden;background:var(--code-bg);border-radius:var(--r-ctl)}
.skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);animation:shimmer 1.3s infinite}
.skel-card{border-bottom:1px solid var(--hairline);padding:var(--s3) var(--s2);display:grid;gap:var(--s3)}
.skel-line{height:13px}.skel-line.t{height:15px;width:55%}.skel-line.m{width:35%;height:11px}

/* ============ MODAL / DIALOG ============ */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:var(--s6);background:rgba(15,15,15,.4);animation:fade 120ms ease both}
.modal-body{background:var(--surface);border-radius:var(--r-dialog);max-width:720px;width:100%;max-height:88vh;overflow:auto;padding:var(--s8);position:relative;box-shadow:var(--shadow-pop);animation:dialog-in 140ms ease both}
.modal-body h2{font-size:28px;font-weight:700;margin:0 0 var(--s3);letter-spacing:-.02em;color:var(--text);line-height:1.2}
.detail-meta{font-size:12px;color:var(--muted);margin-bottom:var(--s5);display:flex;gap:var(--s2);flex-wrap:wrap;align-items:center}
.md{font-size:15px;line-height:1.6;color:var(--text)}
.md>:first-child{margin-top:0}
.md>:last-child{margin-bottom:0}
.md p{margin:var(--s3) 0}
.md h1{font-size:24px;font-weight:700;letter-spacing:-.01em;line-height:1.3;margin:var(--s5) 0 var(--s2)}
.md h2{font-size:20px;font-weight:600;line-height:1.3;margin:var(--s5) 0 var(--s2)}
.md h3{font-size:16px;font-weight:600;line-height:1.3;margin:var(--s4) 0 var(--s1)}
.md ul,.md ol{margin:var(--s3) 0;padding-left:var(--s5)}
.md li{margin:var(--s1) 0}
.md a{color:var(--accent)}
.md strong{font-weight:600}
.md img{max-width:100%;display:block;margin:var(--s3) 0;border-radius:var(--r-card);border:1px solid var(--hairline)}
.md blockquote{border-left:3px solid var(--hairline-solid);margin:var(--s3) 0;padding:2px var(--s4);color:var(--muted)}
.md code{word-break:break-word}
.md pre{background:var(--code-bg);padding:var(--s4);border-radius:var(--r-card);overflow:auto;font-family:var(--font-mono);font-size:13px;line-height:1.6;margin:var(--s3) 0}
.md pre code{background:transparent;color:var(--text);padding:0}

/* ============ SHARE BAR ============ */
.share-bar{display:flex;align-items:center;gap:var(--s2);margin:var(--s6) 0 0;flex-wrap:wrap;padding-top:var(--s4);border-top:1px solid var(--hairline)}
#share-btn{color:var(--muted)}
#share-btn:hover{color:var(--text)}
.share-link{display:flex;align-items:center;gap:var(--s2);flex-wrap:wrap;width:100%}
.share-link input{flex:1;min-width:220px;height:28px;font-size:13px;font-family:var(--font-mono)}
.share-link a.ghost{display:inline-flex;align-items:center;text-decoration:none}
.share-link a.ghost:hover{text-decoration:none}
#share-revoke{color:var(--danger)}
#share-revoke:hover{background:var(--danger-soft);color:var(--danger)}

/* ============ ASK RAIL (calm Notion side panel) ============ */
.ask-rail{flex:0 0 var(--rail-w);width:var(--rail-w);align-self:stretch;display:flex;flex-direction:column;background:var(--rail-bg);border-left:1px solid var(--hairline);position:sticky;top:0;height:100vh;z-index:20;overflow:hidden}
.ask-rail-head{display:flex;align-items:center;gap:var(--s1);height:45px;padding:0 var(--s2) 0 var(--s4);border-bottom:1px solid var(--hairline);flex:0 0 auto}
.ask-rail-title{flex:1;min-width:0;font-size:14px;font-weight:600;display:flex;align-items:center;gap:var(--s2);letter-spacing:-.01em;color:var(--text)}
.ask-rail-title svg{color:var(--accent);flex:0 0 auto}
/* #ask-clear is created in JS with class "icon-btn ghost" but holds the word "Clear" */
#ask-clear{width:auto;min-width:0;padding:0 var(--s2);height:28px;font-size:12px;font-weight:500;color:var(--muted)}
#ask-clear:hover{color:var(--text);background:var(--hover)}
.ask-thread{flex:1 1 auto;min-height:0;overflow-y:auto;padding:var(--s4);display:flex;flex-direction:column;gap:var(--s3)}
/* question bubble — subtle gray fill, dark text (not bright blue) */
.ask-q{align-self:flex-end;max-width:85%;background:var(--hover);color:var(--text);padding:var(--s2) var(--s3);border-radius:var(--r-card);font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;animation:rise 140ms ease both}
/* answer — plain on white */
.ask-a{align-self:flex-start;max-width:100%;background:transparent;border:none;border-radius:0;padding:var(--s1) 0;font-size:14px;box-shadow:none;animation:rise 140ms ease both}
.ask-md{font-size:14px;line-height:1.6}
.ask-md p{margin:var(--s2) 0}.ask-md>:first-child{margin-top:0}.ask-md>:last-child{margin-bottom:0}
.ask-md h1,.ask-md h2,.ask-md h3{font-size:15px;font-weight:600;margin:var(--s3) 0 var(--s1)}
.ask-typing{display:inline-flex;gap:5px;padding:var(--s1) 2px}
.ask-typing span{width:6px;height:6px;border-radius:50%;background:#c4c3bf;animation:ask-blink 1.2s infinite both}
.ask-typing span:nth-child(2){animation-delay:.15s}.ask-typing span:nth-child(3){animation-delay:.3s}
@keyframes ask-blink{0%,80%,100%{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}
.ask-md.streaming::after{content:"";display:inline-block;width:2px;height:1.05em;vertical-align:-2px;margin-left:1px;background:var(--text);animation:caret 1s steps(1) infinite}
@keyframes caret{50%{opacity:0}}
.cite{cursor:pointer;color:var(--accent);background:rgba(35,131,226,.12);border-radius:var(--r-ctl);padding:0 4px;margin-left:2px;font-size:10px;font-weight:600;vertical-align:super;line-height:1;transition:background var(--dur)}
.cite:hover{background:var(--accent);color:#fff}
.ask-sources{margin-top:var(--s3);border-top:1px solid var(--hairline);padding-top:var(--s3);display:grid;gap:var(--s1)}
.ask-sources-h{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}
.ask-source{display:flex;gap:var(--s2);align-items:flex-start;cursor:pointer;background:transparent;border:none;border-radius:var(--r-ctl);padding:var(--s2);transition:background var(--dur)}
.ask-source:hover{background:var(--hover)}
.ask-source-n{flex:0 0 auto;width:18px;height:18px;border-radius:var(--r-ctl);background:var(--code-bg);color:var(--muted);font-size:11px;font-weight:600;display:grid;place-items:center;margin-top:1px}
.ask-source-body{display:grid;gap:1px;min-width:0}
.ask-source-title{font-size:14px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ask-source-domain{font-size:12px;color:var(--muted)}
.ask-source.flash{animation:src-flash 1.1s ease}
@keyframes src-flash{0%{background:rgba(35,131,226,.14)}100%{background:transparent}}
.ask-model-tag{margin-top:var(--s2);font-size:12px;color:var(--faint);text-align:right}
.ask-err{margin:0;color:var(--danger);font-size:13px}
.ask-notice{padding:var(--s4)}
.ask-notice h2{font-size:15px;font-weight:600;margin:0 0 var(--s2)}
.ask-notice-p{font-size:13px;color:var(--muted);margin:0 0 var(--s4);line-height:1.6}
.ask-bar{flex:0 0 auto;display:flex;gap:var(--s2);align-items:center;padding:var(--s3) var(--s4);border-top:1px solid var(--hairline);background:var(--rail-bg)}
.ask-bar input{flex:1;height:32px;border-radius:var(--r-ctl);padding:0 var(--s3);background:var(--surface);border:1px solid var(--hairline)}
.ask-bar input:hover{background:var(--surface);border-color:rgba(55,53,47,.16)}
.ask-bar input:focus{background:var(--surface);border-color:var(--accent);box-shadow:var(--accent-ring) 0 0 0 1px}
.ask-bar input:disabled{background:var(--surface-tint);border-color:var(--hairline)}
.ask-bar .primary{flex:0 0 auto;height:32px;width:32px;min-width:32px;padding:0}
.ask-bar .primary svg{width:18px;height:18px}

/* ============ SETTINGS ============ */
.ask-settings{padding:var(--s4) 0 0}
.ask-settings-summary{display:flex;align-items:center;gap:var(--s2);background:var(--surface-tint);border:1px solid var(--hairline);border-radius:var(--r-card);padding:var(--s3) var(--s4);font-size:13px;color:var(--muted)}
.ask-settings-summary .set-icon{flex:0 0 auto;font-size:14px;color:var(--muted)}
.ask-settings-summary .set-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ask-settings-details{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-card);padding:var(--s1) var(--s5) var(--s5)}
.ask-settings-details>summary{cursor:pointer;list-style:none;padding:var(--s3) 0;font-size:14px;font-weight:500;color:var(--accent);border-radius:var(--r-ctl);transition:color var(--dur)}
.ask-settings-details>summary:hover{color:var(--accent-hover)}
.ask-settings-details>summary:focus-visible{outline:none;box-shadow:var(--accent-ring) 0 0 0 2px}
.ask-settings-details>summary::-webkit-details-marker{display:none}
.ask-settings-form{display:grid;gap:var(--s4);padding-top:var(--s2)}
.fld{display:grid;gap:var(--s1)}
.fld>span{font-size:12px;font-weight:500;color:var(--muted)}
.fld select,.fld input{height:32px;font-size:14px}
.ask-settings-actions{display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap}

/* ============ SNACKBAR ============ */
.snackbar{position:fixed;left:50%;bottom:var(--s6);transform:translateX(-50%) translateY(120%);background:var(--text);color:#fff;font-size:14px;padding:var(--s2) var(--s4);border-radius:var(--r-card);box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:var(--s4);z-index:80;opacity:0;transition:transform 180ms ease,opacity 120ms}
.snackbar.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ============ RESPONSIVE ============ */
@media (max-width:1180px){:root{--rail-w:340px}}
@media (max-width:900px){
  .sidebar-toggle{display:grid}
  .sidebar{position:fixed;inset:0 auto 0 0;height:100vh;transform:translateX(-100%);transition:transform 200ms ease;box-shadow:var(--shadow-pop)}
  body.nav-open .sidebar{transform:translateX(0)}
  .nav-backdrop{display:none}
  body.nav-open .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(15,15,15,.35);z-index:25;animation:fade 120ms both}
  .view{padding:var(--s10) var(--s5) var(--s12)}
  .ask-rail{position:fixed;inset:0 0 0 auto;height:100vh;width:min(420px,92vw);flex-basis:auto;z-index:70;box-shadow:var(--shadow-pop);transform:translateX(100%);transition:transform 200ms ease;border-left:1px solid var(--hairline)}
  body.ask-open .ask-rail{display:flex;transform:translateX(0)}
  body.ask-closed .ask-rail{display:flex;transform:translateX(100%)}
  .ask-backdrop{display:none}
  body.ask-open .ask-backdrop{display:block;position:fixed;inset:0;background:rgba(15,15,15,.35);z-index:65;animation:fade 120ms both}
  .main{width:100%}
}
.ask-backdrop,.nav-backdrop{display:none}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.live .dot{animation:none}.ask-md.streaming::after{animation:none}}
