/* ============================================================
   Mitchell Gits — portfolio
   Aesthetic: editorial minimal. Warm paper, ink text, one slate
   accent, monospace for technical metadata.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Hanken+Grotesk:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --paper:#F6F3ED;
  --paper-2:#EFEBE2;
  --ink:#17171A;
  --muted:#5C5A57;
  --faint:#8C8880;
  --accent:#2B4865;
  --accent-soft:rgba(43,72,101,.10);
  --line:rgba(23,23,26,.12);
  --line-soft:rgba(23,23,26,.07);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Hanken Grotesk',-apple-system,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --maxw:980px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
  /* faint grain/texture for atmosphere */
  background-image:radial-gradient(var(--line-soft) .5px,transparent .5px);
  background-size:22px 22px;
}
img,video{max-width:100%;height:auto;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- nav ---------- */
header.nav{position:sticky;top:0;z-index:50;
  background:rgba(246,243,237,.86);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:18px 28px;
  display:flex;align-items:baseline;justify-content:space-between;gap:20px;flex-wrap:wrap}
.wordmark{font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:-.01em;
  text-decoration:none;color:var(--ink);display:flex;align-items:baseline;gap:9px}
.wordmark .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;transform:translateY(-1px)}
nav.links{display:flex;gap:22px;font-size:14.5px}
nav.links a{color:var(--muted);text-decoration:none;position:relative;padding-bottom:3px;transition:color .2s}
nav.links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--accent);transition:width .25s ease}
nav.links a:hover{color:var(--ink)}
nav.links a:hover::after,nav.links a.active::after{width:100%}
nav.links a.active{color:var(--ink)}

/* ---------- page scaffold ---------- */
main{padding:64px 0 28px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:18px}
h1{font-family:var(--serif);font-weight:500;font-size:clamp(38px,6vw,62px);line-height:1.04;
  letter-spacing:-.02em;margin-bottom:22px}
h2{font-family:var(--serif);font-weight:500;font-size:clamp(24px,3.5vw,32px);letter-spacing:-.01em;margin-bottom:6px}
h3{font-family:var(--sans);font-weight:600;font-size:18px;letter-spacing:-.005em}
.lead{font-size:clamp(18px,2.4vw,21px);line-height:1.6;color:var(--ink);max-width:640px}
p{color:var(--muted);max-width:660px}
p+p{margin-top:14px}
a.inline{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-soft);transition:border-color .2s}
a.inline:hover{border-bottom-color:var(--accent)}

/* section rhythm */
.section{padding:46px 0;border-top:1px solid var(--line)}
.section:first-of-type{border-top:none}
.section-head{display:flex;align-items:baseline;gap:14px;margin-bottom:30px}
.section-head .num{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.1em}

/* ---------- hero (home) ---------- */
.hero{padding:30px 0 10px}
.hero .status{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12.5px;
  color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:6px 13px;margin-bottom:30px}
.hero .status .live{width:7px;height:7px;border-radius:50%;background:#3a9d6b;box-shadow:0 0 0 0 rgba(58,157,107,.5);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(58,157,107,.5)}70%{box-shadow:0 0 0 7px rgba(58,157,107,0)}100%{box-shadow:0 0 0 0 rgba(58,157,107,0)}}
.hero h1 .accent{color:var(--accent)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.btn{font-family:var(--sans);font-weight:600;font-size:15px;text-decoration:none;padding:12px 22px;border-radius:7px;transition:transform .15s,background .2s,border-color .2s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* quick facts grid on home */
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-top:8px}
.fact{background:var(--paper);padding:22px}
.fact .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:7px}
.fact .v{font-family:var(--serif);font-size:19px;color:var(--ink);line-height:1.3}

/* ---------- timeline (experience) ---------- */
.role{display:grid;grid-template-columns:170px 1fr;gap:24px;padding:26px 0;border-top:1px solid var(--line-soft)}
.role:first-child{border-top:none}
.role .when{font-family:var(--mono);font-size:13px;color:var(--faint);padding-top:4px}
.role .co{color:var(--accent);font-weight:500;font-size:14.5px;margin-bottom:14px}
.role ul{list-style:none;margin-top:12px}
.role li{position:relative;padding-left:20px;color:var(--muted);margin-bottom:8px;font-size:15.5px;line-height:1.55}
.role li::before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.55}

/* ---------- project cards ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card{border:1px solid var(--line);border-radius:12px;padding:26px;background:var(--paper);transition:transform .18s,box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 34px -18px rgba(23,23,26,.35);border-color:rgba(43,72,101,.4)}
.card .tag{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:13px;display:block}
.card h3{margin-bottom:9px}
.card p{font-size:14.5px;line-height:1.55}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.chip{font-family:var(--mono);font-size:11.5px;color:var(--muted);background:var(--paper-2);border:1px solid var(--line-soft);border-radius:5px;padding:3px 9px}
.card.feature{grid-column:1/-1;background:linear-gradient(180deg,var(--paper),var(--paper-2));border-color:rgba(43,72,101,.3)}
/* balanced 2x2 grids: flagship card stays highlighted but does not span */
.cards.even .card.feature{grid-column:auto}
/* minimal icons: badge to the left of the card title */
.cicon{float:left;width:46px;height:46px;border-radius:12px;border:1px solid var(--line);background:var(--paper-2);display:grid;place-items:center;margin:1px 15px 0 0;line-height:0}
.cicon svg{width:24px;height:24px;color:var(--ink)}
.cicon img{width:27px;height:27px;object-fit:contain}
.cicon + .tag{margin-bottom:4px}
.card > p{clear:left}
.fact .ficon{display:block;margin-bottom:11px;line-height:0}
.fact .ficon svg{width:24px;height:24px;color:var(--ink)}
/* photo frames (graceful when image absent) */
.portrait{width:100%;aspect-ratio:1/1;border-radius:12px;border:1px solid var(--line);background:var(--paper-2) center/cover no-repeat}
.shot{width:100%;aspect-ratio:16/9;border-radius:12px;border:1px solid var(--line);background:var(--paper-2) center/cover no-repeat;margin-top:6px}
/* about: two-column intro (text + photo) */
.about-intro{display:grid;grid-template-columns:1fr 300px;gap:44px;align-items:center;margin-bottom:8px}
.about-intro .eyebrow,.about-intro h1{margin-top:0}
.about-portrait{aspect-ratio:3/4;border-radius:14px;border:1px solid var(--line);background:var(--paper-2) center/cover no-repeat}
.caption{font-family:var(--mono);font-size:12px;color:var(--faint);margin-top:9px}
@media(max-width:720px){.about-intro{grid-template-columns:1fr;gap:22px}.about-portrait{max-width:300px}}
/* text + photo, sharing section margins */
.split{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.split .shot{margin-top:0}
.split p{max-width:none}
@media(max-width:720px){.split{grid-template-columns:1fr;gap:24px}}

/* ---------- about / skills ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.skill-block{margin-bottom:24px}
.skill-block .label{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.skill-block .items{display:flex;flex-wrap:wrap;gap:7px}
.edu-item{padding:16px 0;border-top:1px solid var(--line-soft)}
.edu-item:first-child{border-top:none}
.edu-item .deg{font-weight:600;font-size:15.5px}
.edu-item .meta{font-family:var(--mono);font-size:12.5px;color:var(--faint);margin-top:3px}

/* ---------- contact ---------- */
.contact-list{margin-top:20px}
.contact-row{display:flex;align-items:baseline;gap:18px;padding:18px 0;border-top:1px solid var(--line-soft);font-size:17px}
.contact-row:first-child{border-top:none}
.contact-row .k{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);width:90px;flex:none}
.contact-row a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--accent-soft);transition:border-color .2s,color .2s}
.contact-row a:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* ---------- footer / colophon ---------- */
footer{border-top:1px solid var(--line);margin-top:40px}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:30px 28px 50px;
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.colophon{font-family:var(--mono);font-size:12px;color:var(--faint);line-height:1.6;max-width:560px}
.colophon .hl{color:var(--accent)}
.foot-inner .copy{font-family:var(--mono);font-size:12px;color:var(--faint)}

/* ---------- page-load reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.reveal:nth-child(1){animation-delay:.04s}.reveal:nth-child(2){animation-delay:.12s}
.reveal:nth-child(3){animation-delay:.2s}.reveal:nth-child(4){animation-delay:.28s}
.reveal:nth-child(5){animation-delay:.36s}.reveal:nth-child(6){animation-delay:.44s}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none}.hero .status .live{animation:none}}

/* ---------- responsive ---------- */
@media(max-width:720px){
  body{font-size:16px}
  main{padding:40px 0 20px}
  .hero h1{font-size:clamp(32px,8vw,52px)}
  .facts{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr;gap:28px}
  .role{grid-template-columns:1fr;gap:6px}
  .role .when{padding-top:0}
  nav.links{gap:16px;font-size:13.5px}
  .nav-inner{padding:14px 22px}
  .wrap{padding:0 22px}
}
