/* ==========================================================================
   Drommedhar — personal site styles, shared by index.html and project.html.
   The generalized house style of the Sable and Novalist pages: dark ink,
   hairline cards, glass nav, mono metadata, one calm accent.
   ========================================================================== */
:root{
  --bg:      #0e1016;
  --bg-2:    #12141d;
  --panel:   #151826;
  --panel-2: #1a1e30;
  --line:     rgba(235,237,243,.09);
  --line-soft:rgba(235,237,243,.05);
  --text:    #eceef4;
  --mut:     #9aa0b4;
  --faint:   #6b7188;

  --acc:   #8da6ff;
  --acc-2: #bdcbff;

  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Schibsted Grotesk",system-ui,sans-serif;
  --font-mono:"Spline Sans Mono",ui-monospace,monospace;

  --r-sm:8px; --r-md:13px; --r-lg:18px;
  --maxw:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-size:16.5px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto}
a{color:var(--text)}
:focus-visible{outline:2px solid var(--acc);outline-offset:3px;border-radius:4px}
::selection{background:var(--acc);color:#10131f}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip{position:absolute;left:-999px;top:8px;background:var(--panel);padding:8px 14px;border-radius:8px;z-index:100}
.skip:focus{left:8px}

/* ============================================================
   Nav
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(14,16,22,.8);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav-in{display:flex;align-items:center;gap:28px;height:62px}
.brand{
  display:flex;align-items:center;gap:11px;text-decoration:none;
  font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:.01em;
  line-height:1;
}
.brand img{display:block;width:28px;height:28px;border-radius:99px;border:1px solid var(--line)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{color:var(--mut);text-decoration:none;font-size:14.5px;font-weight:500;line-height:1;transition:color .15s}
.nav-links a:hover{color:var(--text)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.gh-pill{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-mono);font-size:13px;line-height:1;color:var(--mut);
  text-decoration:none;border:1px solid var(--line);border-radius:99px;
  padding:7px 14px;transition:border-color .15s,color .15s;
}
.gh-pill:hover{border-color:var(--acc);color:var(--text)}
.gh-pill svg{width:14px;height:14px;fill:currentColor}

/* ============================================================
   Hero (index)
   ============================================================ */
.hero{
  border-bottom:1px solid var(--line-soft);
  background:radial-gradient(90% 70% at 50% 0%, #151a2c 0%, var(--bg) 70%);
}
.hero-in{display:flex;flex-direction:column;align-items:center;text-align:center;padding:78px 24px 70px}
.avatar{
  width:104px;height:104px;border-radius:99px;border:1px solid var(--line);
  box-shadow:0 18px 60px -18px rgba(141,166,255,.35);margin-bottom:24px;
}
h1{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(32px,5vw,52px);line-height:1.06;letter-spacing:-.02em;
  margin:0 0 14px;
}
h1 span{color:var(--acc)}
.bio{max-width:58ch;color:var(--mut);font-size:17.5px;margin:0 0 28px}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.chip{
  font-family:var(--font-mono);font-size:12.5px;line-height:1.5;color:var(--mut);
  border:1px solid var(--line);border-radius:99px;padding:5px 13px;
  text-decoration:none;display:inline-flex;align-items:center;gap:7px;
}
a.chip:hover{border-color:var(--acc);color:var(--text)}
.chip .dot{width:6px;height:6px;border-radius:99px;background:var(--acc)}

/* ============================================================
   Sections
   ============================================================ */
section{padding:78px 0}
.sec-label{
  font-family:var(--font-mono);font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--faint);margin:0 0 12px;
}
h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(26px,3.4vw,38px);letter-spacing:-.015em;line-height:1.12;
  margin:0 0 12px;
}
.sec-sub{color:var(--mut);max-width:62ch;margin:0 0 40px;font-size:16px}
.sec-sub a{color:var(--mut)}
.sec-sub a:hover{color:var(--acc-2)}

.note{
  border:1px solid var(--line);border-radius:var(--r-md);
  background:var(--panel);color:var(--mut);font-size:14.5px;
  padding:16px 20px;margin:8px 0;
}
.note a{color:var(--acc-2)}

.skel{position:relative;overflow:hidden;background:var(--panel);border-radius:var(--r-md);min-height:120px}
.skel::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,transparent 30%,rgba(235,237,243,.05) 50%,transparent 70%);
  animation:shimmer 1.4s infinite;
}
@keyframes shimmer{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

/* ============================================================
   Project cards
   ============================================================ */
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.proj{
  border:1px solid var(--line);border-radius:var(--r-lg);
  background:linear-gradient(180deg,var(--panel) 0%,var(--bg-2) 100%);
  padding:24px 24px 20px;display:flex;flex-direction:column;gap:10px;
  position:relative;text-decoration:none;color:inherit;
  transition:border-color .15s,transform .12s;
}
.proj:hover{border-color:rgba(141,166,255,.5);transform:translateY(-2px)}
.proj.featured{border-color:rgba(141,166,255,.35)}
.proj-feat{
  position:absolute;top:-10px;right:14px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  background:var(--acc);color:#10131f;border-radius:99px;padding:3px 10px;font-weight:600;
}
.proj-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.proj-name{font-family:var(--font-display);font-weight:700;font-size:19px;line-height:1.2}
.proj-arch{
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--line);color:var(--faint);border-radius:99px;padding:2px 9px;
}
.proj-desc{margin:0;color:var(--mut);font-size:14.5px;line-height:1.55;min-height:2.6em}
.proj-topics{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.proj-topics span{
  font-family:var(--font-mono);font-size:11px;color:var(--acc-2);
  background:rgba(141,166,255,.08);border-radius:6px;padding:2.5px 8px;
}
.proj-meta{
  display:flex;flex-wrap:wrap;gap:6px 16px;align-items:center;margin-top:auto;padding-top:12px;
  font-family:var(--font-mono);font-size:12px;color:var(--faint);
  border-top:1px solid var(--line-soft);
}
.proj-meta .lang-dot{width:9px;height:9px;border-radius:99px;display:inline-block;margin-right:6px;vertical-align:-1px}
.proj-meta .star svg{width:11px;height:11px;fill:var(--faint);vertical-align:-1px;margin-right:4px}
.proj-actions{display:flex;gap:8px;margin-left:auto}
.proj-actions a{
  font-family:var(--font-body);font-size:12.5px;font-weight:600;line-height:1;
  text-decoration:none;color:var(--mut);border:1px solid var(--line);
  border-radius:99px;padding:6px 12px;transition:color .15s,border-color .15s;
}
.proj-actions a:hover{color:var(--text);border-color:var(--acc)}
.proj-actions a.primary{color:#10131f;background:var(--acc);border-color:var(--acc)}
.proj-actions a.primary:hover{background:var(--acc-2);border-color:var(--acc-2);color:#10131f}

/* ============================================================
   Project overview page (project.html)
   ============================================================ */
.proj-hero{border-bottom:1px solid var(--line-soft);background:var(--bg-2)}
.proj-hero-in{padding:56px 0 36px}
.crumb{
  font-family:var(--font-mono);font-size:12.5px;color:var(--faint);margin:0 0 16px;
}
.crumb a{color:var(--faint);text-decoration:none}
.crumb a:hover{color:var(--acc-2)}
.proj-title{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:0 0 10px}
.proj-title h1{font-size:clamp(28px,4vw,44px);margin:0}
.proj-sub{color:var(--mut);font-size:16.5px;max-width:68ch;margin:0 0 22px}
.btn-row{display:flex;flex-wrap:wrap;gap:10px}
.btn{
  display:inline-flex;align-items:center;gap:8px;text-decoration:none;
  border-radius:10px;padding:10px 18px;font-weight:600;font-size:14.5px;line-height:1;
  transition:filter .15s,border-color .15s;
}
.btn-primary{background:var(--acc);color:#10131f}
.btn-primary:hover{filter:brightness(1.1)}
.btn-ghost{border:1px solid var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--acc)}
.proj-stats{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:22px;font-family:var(--font-mono);font-size:12.5px;color:var(--faint)}

.doc-layout{
  display:grid;grid-template-columns:250px minmax(0,1fr);gap:48px;
  align-items:start;padding:44px 0 96px;
}
.doc-toc{
  position:sticky;top:84px;
  max-height:calc(100vh - 108px);overflow-y:auto;
  border:1px solid var(--line);border-radius:var(--r-lg);
  background:var(--panel);padding:18px 8px 18px 18px;font-size:13.5px;
}
.doc-toc .toc-head{
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--faint);margin:0 0 12px;
}
.doc-toc a{
  display:block;color:var(--mut);text-decoration:none;
  padding:5px 10px;border-radius:7px;line-height:1.4;
  border-left:2px solid transparent;
}
.doc-toc a:hover{color:var(--text);background:rgba(235,237,243,.04)}
.doc-toc a.active{color:var(--text);border-left-color:var(--acc);background:rgba(141,166,255,.08)}
.doc-toc a.toc-h3{padding-left:24px;font-size:12.5px;color:var(--faint)}
.doc-toc a.toc-h3:hover{color:var(--mut)}

.doc-body{font-size:15.5px;color:#c9cdda;min-width:0}
.doc-body h1{
  font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;
  font-size:clamp(28px,4vw,40px);line-height:1.1;color:var(--text);margin:0 0 18px;
}
.doc-body h2{
  font-family:var(--font-display);font-weight:700;letter-spacing:-.015em;
  font-size:clamp(22px,2.8vw,28px);color:var(--text);
  margin:50px 0 14px;padding-top:18px;border-top:1px solid var(--line-soft);
  scroll-margin-top:80px;
}
.doc-body h3{
  font-family:var(--font-display);font-weight:700;font-size:18.5px;color:var(--text);
  margin:32px 0 10px;scroll-margin-top:80px;
}
.doc-body h4{font-weight:600;font-size:16px;margin:24px 0 8px;scroll-margin-top:80px}
.doc-body p{margin:0 0 14px}
.doc-body strong{color:var(--text);font-weight:600}
.doc-body a{color:var(--acc-2)}
.doc-body code{
  font-family:var(--font-mono);font-size:.86em;background:rgba(235,237,243,.07);
  padding:1.5px 6px;border-radius:5px;
}
.doc-body pre{
  background:#0b0d13;border:1px solid var(--line-soft);border-radius:10px;
  padding:14px 18px;overflow-x:auto;margin:0 0 16px;
}
.doc-body pre code{background:none;padding:0;font-size:13px;line-height:1.6}
.doc-body ul,.doc-body ol{margin:0 0 14px;padding-left:24px}
.doc-body li{margin-bottom:7px}
.doc-body blockquote{
  margin:0 0 14px;padding:12px 18px;border-left:3px solid var(--acc);
  background:var(--panel);border-radius:0 10px 10px 0;color:var(--mut);
}
.doc-body hr{border:0;border-top:1px solid var(--line-soft);margin:32px 0}
.doc-body table{
  width:100%;border-collapse:collapse;margin:0 0 20px;font-size:14px;
  display:block;overflow-x:auto;
}
.doc-body th{
  text-align:left;font-family:var(--font-mono);font-size:11.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--faint);
  padding:9px 14px;border-bottom:1px solid var(--line);
}
.doc-body td{padding:9px 14px;border-bottom:1px solid var(--line-soft);vertical-align:top}
.doc-body img{border:1px solid var(--line);border-radius:10px;margin:6px 0 12px;background:var(--bg-2)}

/* ============================================================
   Footer
   ============================================================ */
footer{border-top:1px solid var(--line-soft);padding:48px 0 54px;background:var(--bg-2)}
.foot-in{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;align-items:flex-start}
.foot-brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:700;font-size:17px;line-height:1;
}
.foot-brand img{display:block;width:26px;height:26px;border-radius:99px;border:1px solid var(--line)}
.foot-links{display:flex;flex-direction:column;gap:9px;font-size:14px}
.foot-links a{color:var(--mut);text-decoration:none}
.foot-links a:hover{color:var(--acc-2)}
.foot-links .fl-head{
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--faint);margin-bottom:3px;
}
.support-row{display:flex;flex-direction:column;gap:9px}
.support-row a{
  font-size:13.5px;font-weight:600;line-height:1;text-decoration:none;color:var(--text);
  border:1px solid var(--line);border-radius:99px;padding:8px 16px;align-self:flex-start;
}
.support-row a:hover{border-color:var(--acc)}
.foot-truth{
  margin-top:36px;padding-top:20px;border-top:1px solid var(--line-soft);
  font-family:var(--font-mono);font-size:12px;color:var(--faint);
  display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:space-between;
}
.foot-truth a{color:var(--faint)}

/* ============================================================
   Responsive + motion
   ============================================================ */
@media (max-width:920px){
  .proj-grid{grid-template-columns:1fr}
  .doc-layout{grid-template-columns:1fr;gap:28px}
  .doc-toc{position:static;max-height:none}
}
@media (max-width:680px){
  .nav-links{display:none}
  section{padding:60px 0}
  .hero-in{padding:56px 20px 56px}
  .proj-actions{margin-left:0;width:100%}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .skel::after{animation:none}
  .proj{transition:none}
  *{transition:none !important}
}
