/* ===========================================================
   Nicole Beaulieu, PhD - personal site
   Warm monochrome. Fraunces (display) / Inter (text).
   =========================================================== */

:root{
  --paper:#F6F3EC;
  --paper-dim:#EDE8DE;
  --ink:#1C1815;
  --ink-soft:#46403A;
  --muted:#8A8176;
  --line:#E1DBCF;
  --blue:#496090;
  --blue-deep:#37507A;

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;

  --measure:62ch;
  --maxw:1080px;
  --pad:clamp(1.5rem,5vw,5rem);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.08;margin:0;letter-spacing:-0.01em;}
p{margin:0 0 1rem;}
a{color:var(--blue);text-decoration:none;border-bottom:1px solid rgba(73,96,144,0.35);transition:border-color .15s,color .15s;}
a:hover{color:var(--blue-deep);border-bottom-color:var(--blue-deep);}
a:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:1px;}
img{max-width:100%;display:block;}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:.6rem 1rem;z-index:50;}
.skip:focus{left:.5rem;top:.5rem;}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);}

/* ---------- eyebrow / section labels ---------- */
.eyebrow{font-family:var(--sans);font-size:0.72rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue);}

.section{padding:clamp(3rem,7vw,5.5rem) 0;border-top:1px solid var(--line);}
.section .eyebrow{display:block;margin-bottom:1.6rem;}

/* ---------- hero ---------- */
.hero{padding:clamp(2.5rem,7vw,5rem) 0 clamp(2.5rem,6vw,4rem);}
.hero-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
.hero h1{font-size:clamp(2.6rem,6vw,4.4rem);letter-spacing:-0.02em;}
.hero .role{font-family:var(--sans);font-size:0.8rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin:1.1rem 0 1.4rem;}
.hero .lead{font-family:var(--serif);font-size:clamp(1.2rem,2.2vw,1.5rem);line-height:1.4;color:var(--ink-soft);max-width:30ch;font-weight:400;}
.hero-links{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:1.8rem;font-size:0.95rem;}

.portrait{
  position:relative;
  background:#fff;
  box-shadow:0 26px 54px -30px rgba(40,52,82,0.45);
  align-self:stretch;
}
.portrait::after{content:"";position:absolute;inset:0;border:1px solid rgba(73,96,144,0.14);pointer-events:none;}
.portrait img{width:100%;height:auto;display:block;image-orientation:none;}

/* ---------- prose ---------- */
.prose{max-width:var(--measure);font-size:1.075rem;color:var(--ink-soft);}
.prose strong{color:var(--ink);font-weight:600;}

/* ---------- stat line ---------- */
/* ---------- by the numbers ---------- */
.numbers{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:clamp(1.6rem,3vw,2.4rem) clamp(1.5rem,3vw,2.6rem);margin-top:.5rem;}
.num{border-top:2px solid var(--blue);padding-top:.9rem;}
.num .v{font-family:var(--serif);font-size:clamp(2.1rem,4.4vw,3.1rem);line-height:1;color:var(--ink);font-weight:400;display:block;font-variant-numeric:lining-nums tabular-nums;}
.num .k{font-family:var(--sans);font-size:0.8rem;color:var(--muted);margin-top:.55rem;line-height:1.4;display:block;}
.num .sub{color:var(--muted);font-size:0.7rem;letter-spacing:0.04em;}

/* ---------- experience list ---------- */
.xp{display:flex;flex-direction:column;}
.xp-row{display:grid;grid-template-columns:1fr 2fr;gap:clamp(1rem,3vw,3rem);padding:1.5rem 0;border-top:1px solid var(--line);}
.xp-row:first-child{border-top:0;}
.xp-org{font-family:var(--serif);font-size:1.3rem;}
.xp-when{font-family:var(--sans);font-size:0.82rem;color:var(--muted);margin-top:.25rem;}
.xp-role{font-weight:600;}
.xp-note{color:var(--ink-soft);margin:.25rem 0 0;font-size:1rem;}

/* ---------- selected work ---------- */
.work{display:flex;flex-direction:column;gap:1.25rem;max-width:760px;}
.work-item{padding-bottom:1.25rem;border-bottom:1px solid var(--line);}
.work-item:last-child{border-bottom:0;}
.work-item .t{font-family:var(--serif);font-size:1.15rem;}
.work-item .m{font-size:0.88rem;color:var(--muted);margin-top:.3rem;}
.work-more{margin-top:.5rem;font-size:0.95rem;}

/* ---------- connect ---------- */
.connect-grid{display:flex;flex-wrap:wrap;gap:1rem 3rem;}
.connect-grid a{font-size:1.05rem;}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--line);padding:2.5rem 0;color:var(--muted);font-size:0.85rem;}

/* ---------- responsive ---------- */
@media (max-width:760px){
  .hero-grid{grid-template-columns:1fr;gap:2rem;}
  .portrait{order:-1;max-width:340px;}
  .xp-row{grid-template-columns:1fr;gap:.4rem;}
}
