/* Stuart Lane — Personal site, 2026 refresh (minimalist) */
:root{
  --bg:#0b0c0e;
  --bg-2:#101216;
  --ink:#ececee;
  --muted:#9aa0aa;
  --soft:#c8ccd3;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.16);
  --accent:#d2cfc4;       /* warm off-white */
  --accent-2:#a7c4bc;     /* muted sage */
  --warm:#e7c8a9;         /* soft clay */
  --serif:"Fraunces","Source Serif Pro",ui-serif,Georgia,serif;
  --sans:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;letter-spacing:-0.005em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(231,200,169,0.25);color:#fff}

/* Subtle background */
.bg-grid{position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image: radial-gradient(900px 500px at 80% -20%, rgba(255,255,255,0.04), transparent 60%),
                    radial-gradient(800px 500px at 0% 10%, rgba(255,255,255,0.03), transparent 60%);
}

/* Layout */
.container{max-width:1080px;margin:0 auto;padding:0 24px;position:relative;z-index:1}
.section{padding:88px 0}
.section-sm{padding:48px 0}

/* Nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(140%) blur(14px);background:rgba(11,12,14,0.7);border-bottom:1px solid var(--line)}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:12px;font-weight:500;letter-spacing:-0.01em;font-size:15px}
.brand-mark{width:24px;height:24px;border-radius:50%;background:#1a1c20;border:1px solid var(--line-2);position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);font-size:11px;font-weight:600}
.brand-name{color:var(--ink)}
.brand-name span{color:var(--muted)}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{padding:8px 12px;border-radius:8px;font-size:14px;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-cta{display:none}

/* Eyebrow */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:0.14em}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--accent)}

/* Hero */
.hero{padding:96px 0 56px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(38px,6vw,68px);line-height:1.04;letter-spacing:-0.02em;margin:18px 0 22px}
.hero h1 em{font-style:italic;color:var(--soft)}
.hero p.lede{font-size:18px;color:var(--soft);max-width:560px;line-height:1.6;margin:0}
.hero-cta{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}

/* Headshot card */
.headshot{aspect-ratio:4/5;border-radius:14px;background:#15171b;border:1px solid var(--line);overflow:hidden;position:relative}
.headshot.square{aspect-ratio:1/1}
.headshot.wide{aspect-ratio:5/4}
.headshot.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;background:repeating-linear-gradient(45deg,#15171b 0,#15171b 6px,#191b1f 6px,#191b1f 12px)}
.headshot.placeholder .label{padding:8px 12px;border-radius:8px;border:1px dashed var(--line-2);background:rgba(11,12,14,0.65);color:var(--muted);font-size:12px;letter-spacing:0.1em;text-transform:uppercase}
.headshot img{width:100%;height:100%;object-fit:cover}

/* Buttons (subtle, no CTA-y feel) */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;border:1px solid var(--line-2);font-size:14px;font-weight:400;color:var(--ink);transition:.2s;background:transparent}
.btn:hover{border-color:rgba(255,255,255,0.32);background:rgba(255,255,255,0.03)}
.btn-quiet{border-color:var(--line);color:var(--muted)}
.btn-quiet:hover{color:var(--ink);border-color:var(--line-2)}

/* Section heads */
.section-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:36px}
.section-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3vw,38px);letter-spacing:-0.02em;margin:0}
.section-head p{color:var(--muted);max-width:520px;margin:0;font-size:15px}

/* Cards / lists */
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid-2,.grid-3{grid-template-columns:1fr}}

.row-list{border-top:1px solid var(--line)}
.row-list a{display:grid;grid-template-columns:120px 1fr auto;gap:24px;padding:22px 0;border-bottom:1px solid var(--line);transition:padding .2s, color .2s;align-items:baseline}
.row-list a:hover{padding-left:6px}
.row-list .meta{color:var(--muted);font-size:13px;letter-spacing:0.05em;text-transform:uppercase;font-feature-settings:"tnum"}
.row-list .title{font-family:var(--serif);font-size:22px;letter-spacing:-0.01em;color:var(--ink)}
.row-list .desc{color:var(--muted);font-size:14px;margin-top:6px}
.row-list .arrow{color:var(--muted);font-size:14px}
.row-list a:hover .arrow{color:var(--ink)}
@media(max-width:760px){
  .row-list a{grid-template-columns:1fr;gap:8px}
  .row-list .arrow{display:none}
}

/* Project / post tile with image */
.tile{display:block;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#101216;transition:.25s;color:inherit}
.tile:hover{border-color:var(--line-2);transform:translateY(-2px)}
.tile .cover{aspect-ratio:16/9;background:#15171b;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;background-image:repeating-linear-gradient(45deg,#15171b 0,#15171b 6px,#191b1f 6px,#191b1f 12px)}
.tile .cover img{width:100%;height:100%;object-fit:cover}
.tile .body{padding:20px}
.tile .pill{display:inline-block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:8px}
.tile h3{font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:-0.01em;margin:0 0 6px}
.tile p{color:var(--muted);font-size:14px;line-height:1.6;margin:0}

/* About-style content */
.intro p{font-size:18px;line-height:1.75;color:var(--soft);margin:0 0 16px}
.intro p strong{color:var(--ink);font-weight:500}

.skill-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.skill{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);color:var(--soft);background:transparent}

.fact-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}
.fact-list li{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--line);font-size:14px}
.fact-list li .k{color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;font-size:12px}
.fact-list li .v{color:var(--soft)}

/* Timeline (cleaner) */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--line-2)}
.tl-item{position:relative;padding:0 0 28px 0}
.tl-item::before{content:"";position:absolute;left:-21px;top:8px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:1px solid var(--line-2)}
.tl-item.now::before{background:var(--accent);border-color:var(--accent)}
.tl-meta{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:0.12em}
.tl-title{font-family:var(--serif);font-size:20px;letter-spacing:-0.01em;margin:6px 0 4px;font-weight:400}
.tl-co{color:var(--muted);font-style:italic}
.tl-bullets{margin:8px 0 0;padding-left:18px;color:var(--soft);font-size:14px;line-height:1.7}

/* Footer */
.footer{padding:48px 0 32px;border-top:1px solid var(--line);margin-top:32px}
.footer .row{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.footer .links{display:flex;gap:16px;flex-wrap:wrap}
.footer .links a:hover{color:var(--ink)}

/* Article */
.article{max-width:680px;margin:0 auto}
.article .meta{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:0.14em}
.article h1{font-family:var(--serif);font-weight:400;font-size:clamp(32px,4.2vw,48px);letter-spacing:-0.02em;line-height:1.1;margin:14px 0 16px}
.article .lede{font-size:18px;color:var(--soft);line-height:1.6}
.article h2{font-family:var(--serif);font-size:24px;letter-spacing:-0.01em;margin:40px 0 12px;font-weight:400}
.article h3{font-size:16px;margin:24px 0 6px;color:var(--ink)}
.article p,.article li{color:var(--soft);line-height:1.8;font-size:16px}
.article p{margin:0 0 14px}
.article ul{padding-left:20px}
.article blockquote{border-left:1px solid var(--line-2);padding:6px 0 6px 16px;color:var(--muted);font-style:italic;margin:18px 0}
.article code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;padding:2px 6px;border-radius:4px;background:#15171b;border:1px solid var(--line);color:var(--accent)}
.article .cover-img{margin:0 0 24px;border-radius:12px;border:1px solid var(--line);overflow:hidden;aspect-ratio:16/9;background:#15171b;background-image:repeating-linear-gradient(45deg,#15171b 0,#15171b 6px,#191b1f 6px,#191b1f 12px)}

/* Misc */
.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;padding:2px 6px;border-radius:6px;border:1px solid var(--line);background:#15171b;color:var(--muted)}
.divider{height:1px;background:var(--line);margin:32px 0}
.link-arrow{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:14px}
.link-arrow:hover{color:var(--ink)}

.fadeup{opacity:0;transform:translateY(8px);transition:opacity .7s ease, transform .7s ease}
.fadeup.in{opacity:1;transform:translateY(0)}
