/* Dive Club's self-hosted Neue Plak (Framer CDN, CORS-open) — exact brand match.
   Deliberately NOT committed to the repo: commercial typeface, loaded from the
   same CDN the local app uses. The app's only third-party origin. */
@font-face{font-family:'Neue Plak Ext Bold';src:url(https://framerusercontent.com/assets/KgeUgHtVhCTDMMowSQhV1aVszQ.ttf) format('truetype');font-display:swap}
@font-face{font-family:'Neue Plak Ext SemiBold';src:url(https://framerusercontent.com/assets/BmthWzoM6xLa3DXuPCi8ZPrqm5Q.ttf) format('truetype');font-display:swap}
@font-face{font-family:'Neue Plak Regular';src:url(https://framerusercontent.com/assets/cckfmmUVtbBL6TWdv2ZnyU4LWs.ttf) format('truetype');font-display:swap}

:root{
  --bg:#091314; --surface:#0e1f21; --text:#fff; --soft:rgba(255,255,255,.52);
  --rule:rgba(98,210,224,.16); --accent:#62d2e0; --cream:#fffbd8;
  --danger:#ff9a8a;
  --display:"Neue Plak Ext Bold","Inter",sans-serif;
  --semi:"Neue Plak Ext SemiBold","Inter",sans-serif;
  --body:"Neue Plak Regular","Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{margin:0;background:var(--bg);color:var(--text);font:16px/1.62 var(--body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(58% 42% at 50% -10%, rgba(98,210,224,.10), transparent 70%),
             radial-gradient(38% 30% at 92% 2%, rgba(255,251,216,.06), transparent 70%);}
header,main,form{position:relative;z-index:1;}
header{position:sticky;top:0;z-index:5;background:var(--bg);padding:20px 22px;
  border-bottom:1px solid var(--rule);display:flex;align-items:baseline;gap:9px;}
header b{font-family:var(--display);font-weight:400;font-size:22px;letter-spacing:-.01em;}
header span{color:var(--soft);font-size:13px;flex:1;}
#settings-btn{font-size:18px;line-height:1;color:var(--soft);background:transparent;border:1px solid transparent;
  border-radius:9px;padding:4px 9px;cursor:pointer;align-self:center;transition:color .2s,border-color .2s;}
#settings-btn:hover,#settings-btn:focus-visible{color:var(--accent);border-color:var(--rule);outline:none;}
#settings-btn.haskey::after{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--accent);margin-left:6px;vertical-align:2px;}
main{max-width:760px;margin:0 auto;padding:26px 16px 170px;}

/* Empty state */
.hero{margin:8vh 0 0;text-align:center;}
.hero h1{font-family:var(--display);font-weight:400;font-size:30px;letter-spacing:-.01em;margin:0 0 8px;}
.hero p{color:var(--soft);margin:0 auto 10px;font-size:14.5px;max-width:560px;}
.hero p:last-of-type{margin-bottom:26px;}
.suggestions{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;}
.suggestions button{font:14px/1.4 var(--body);color:var(--text);background:var(--surface);
  border:1px solid var(--rule);border-radius:999px;padding:9px 16px;cursor:pointer;transition:border-color .2s;}
.suggestions button:hover{border-color:var(--accent);}

/* Messages */
.msg{margin:0 0 24px;scroll-margin-top:84px;} /* clears the sticky header when pinned to top */
.role{font-family:var(--semi);font-weight:400;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:7px;}
.role .phase{color:var(--soft);text-transform:none;letter-spacing:0;margin-left:8px;}
.you .role{color:var(--soft);}
.bubble{background:var(--surface);border:1px solid var(--rule);border-radius:14px;padding:14px 17px;}
.you .bubble{background:transparent;border-color:transparent;padding:0;color:rgba(255,255,255,.92);}
.bubble a{color:var(--accent);text-underline-offset:2px;}
.bubble a.cite{display:inline-block;font-family:var(--semi);font-size:12px;line-height:1.65;
  color:var(--accent);background:rgba(98,210,224,.10);border:1px solid var(--rule);
  border-radius:7px;padding:0 7px;text-decoration:none;white-space:nowrap;vertical-align:baseline;}
.bubble a.cite:hover{background:rgba(98,210,224,.20);}
.bubble p{margin:0 0 .7em;} .bubble p:last-child{margin-bottom:0;}
.bubble ul{margin:.2em 0 .75em;padding-left:1.25em;}
.bubble ul:last-child{margin-bottom:0;}
.bubble li{margin:.18em 0;} .bubble li::marker{color:var(--accent);}
.bubble .mh{font-family:var(--semi);font-weight:400;font-size:1.02em;margin:1.15em 0 .35em;}
.bubble .mh:first-child{margin-top:0;}
.bubble strong{font-family:var(--semi);font-weight:400;}
.bubble .err{color:var(--danger);font-style:normal;}
.bubble .err a{color:var(--danger);text-decoration:underline;}
.bubble .retry{margin-top:8px;}
.sources{margin-top:14px;padding-top:12px;border-top:1px solid var(--rule);font-size:13.5px;}
.sources .h{font-family:var(--semi);color:var(--soft);text-transform:uppercase;
  letter-spacing:.14em;font-size:10.5px;margin-bottom:7px;}
.sources a{display:block;color:var(--accent);text-decoration:none;padding:3px 6px;line-height:1.4;
  margin:0 -6px;border-radius:7px;transition:background .25s;}
.sources a:hover{text-decoration:underline;}
.sources a .n{display:inline-block;min-width:1.7em;color:var(--soft);font-variant-numeric:tabular-nums;}
.sources a.flash{background:rgba(98,210,224,.16);text-decoration:none;}
.bubble a.fn{color:var(--accent);font-size:.74em;font-weight:600;vertical-align:.32em;
  text-decoration:none;padding:0 1px;cursor:pointer;}
.bubble a.fn:hover{text-decoration:underline;}
.cursor::after{content:"▍";color:var(--accent);animation:blink 1s steps(2) infinite;}
@keyframes blink{50%{opacity:0;}}

/* No-key excerpt cards + banner */
.banner{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;
  background:rgba(255,251,216,.05);border:1px solid var(--rule);border-radius:11px;
  padding:10px 13px;margin-bottom:13px;font-size:13.5px;color:var(--soft);}
.banner button{font-family:var(--semi);font-size:13px;color:#06181a;background:var(--accent);
  border:0;border-radius:9px;padding:6px 13px;cursor:pointer;}
.card{border:1px solid var(--rule);border-radius:11px;padding:11px 13px;margin:0 0 10px;}
.card .t{font-family:var(--semi);font-size:14px;margin-bottom:3px;}
.card .snip{color:var(--soft);font-size:13.5px;margin:4px 0 7px;}

/* Form */
form{position:fixed;bottom:0;left:0;right:0;padding:16px 0 max(16px, env(safe-area-inset-bottom));z-index:5;
  background:var(--bg);border-top:1px solid var(--rule);}
form::before{content:"";position:absolute;left:0;right:0;top:-26px;height:26px;
  pointer-events:none;background:linear-gradient(180deg,rgba(9,19,20,0),var(--bg));}
.bar{max-width:760px;margin:0 auto;padding:0 16px;display:flex;gap:10px;}
textarea{flex:1;resize:none;font:16px/1.5 var(--body);color:var(--text);background:var(--surface);
  border:1px solid var(--rule);border-radius:12px;padding:12px 14px;max-height:160px;
  overflow-y:hidden;scrollbar-width:thin;scrollbar-color:rgba(98,210,224,.35) transparent;}
textarea::-webkit-scrollbar{width:8px;}
textarea::-webkit-scrollbar-thumb{background:rgba(98,210,224,.35);border-radius:8px;
  border:2px solid transparent;background-clip:content-box;}
textarea::-webkit-scrollbar-track{background:transparent;}
textarea::placeholder{color:var(--soft);}
textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(98,210,224,.16);}
button#send{font-family:var(--semi);font-weight:400;font-size:15px;color:#06181a;background:var(--accent);
  border:0;border-radius:12px;padding:0 22px;cursor:pointer;transition:filter .15s;}
button#send:hover{filter:brightness(1.07);}
button#send:disabled{opacity:.45;cursor:default;}
button#send.stop{background:var(--cream);}
.hint{max-width:760px;margin:9px auto 0;padding:0 16px;color:var(--soft);font-size:12px;}
.hint a{color:var(--soft);}
.hint .progress{color:var(--accent);}

/* Settings modal */
dialog#settings{background:var(--surface);color:var(--text);border:1px solid var(--rule);
  border-radius:16px;padding:0;max-width:430px;width:calc(100vw - 32px);}
dialog#settings::backdrop{background:rgba(4,10,11,.66);backdrop-filter:blur(2px);}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 0;}
.modal-head b{font-family:var(--display);font-weight:400;font-size:17px;}
.modal-head button{font-size:15px;color:var(--soft);background:transparent;border:0;cursor:pointer;padding:4px 8px;}
.modal-body{padding:14px 18px 18px;font-size:14px;}
.seg{display:flex;border:1px solid var(--rule);border-radius:10px;overflow:hidden;margin-bottom:14px;}
.seg button{flex:1;font-family:var(--semi);font-size:13.5px;padding:8px 0;color:var(--soft);
  background:transparent;border:0;cursor:pointer;}
.seg button[aria-pressed="true"]{color:#06181a;background:var(--accent);}
.field{margin-bottom:12px;}
.field label{display:block;font-family:var(--semi);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--soft);margin-bottom:5px;}
.keyrow{display:flex;gap:7px;}
.keyrow input{flex:1;font:14px/1.4 var(--body);color:var(--text);background:var(--bg);
  border:1px solid var(--rule);border-radius:9px;padding:9px 11px;min-width:0;}
.keyrow input:focus{outline:none;border-color:var(--accent);}
.keyrow button{font-size:13px;color:var(--soft);background:transparent;border:1px solid var(--rule);
  border-radius:9px;padding:0 11px;cursor:pointer;}
.keyrow button:hover{color:var(--accent);}
select{font:14px/1.4 var(--body);color:var(--text);background:var(--bg);border:1px solid var(--rule);
  border-radius:9px;padding:8px 10px;width:100%;}
.checkrow{display:flex;gap:8px;align-items:center;color:var(--soft);font-size:13px;margin:10px 0 2px;}
.checkrow input{accent-color:var(--accent);}
.status{min-height:20px;font-size:13px;margin:8px 0 2px;}
.status.ok{color:var(--accent);}
.status.bad{color:var(--danger);}
.status a{color:inherit;}
.saved{display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:var(--bg);border:1px solid var(--rule);border-radius:9px;padding:9px 11px;
  font-family:ui-monospace,monospace;font-size:13px;}
.saved button{font-size:12.5px;color:var(--danger);background:transparent;border:0;cursor:pointer;}
.modal-actions{display:flex;gap:9px;margin-top:14px;}
.modal-actions button{font-family:var(--semi);font-size:14px;border-radius:10px;padding:9px 18px;cursor:pointer;}
.modal-actions .primary{color:#06181a;background:var(--accent);border:0;}
.modal-actions .primary:disabled{opacity:.5;cursor:default;}
.trust{color:var(--soft);font-size:12.5px;line-height:1.55;margin-top:13px;border-top:1px solid var(--rule);padding-top:11px;}
.trust a{color:var(--soft);}

@media (max-width:560px){
  main{padding-top:16px;}
  .hero{margin-top:4vh;}
  .hero h1{font-size:24px;}
}
