/* ===========================================================
   Jordan Morris — personal site
   Palette: olive green + warm white + soft (non-pure) black
   Edit the brand colors in :root below to retune everything.
   =========================================================== */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Brand */
  --olive:#7a9a3c;        /* brand accent (large / decorative) */
  --olive-strong:#5f7c2c; /* buttons + links on white (AA safe) */
  --olive-text:#4d6a1f;   /* small text links (safest contrast) */
  --olive-deep:#3f561a;   /* hover / darkest */
  --olive-tint:#eef2e1;   /* light fill */
  --olive-soft:#f5f8ec;   /* very light hover wash */

  /* Neutrals — soft, professional blacks (never pure #000) */
  --ink:#20231d;          /* headings */
  --body:#43463d;         /* body text */
  --muted:#686c5c;        /* meta / secondary (AA 4.5:1 contrast) */
  --line:#e7e7de;         /* hairlines */
  --line-2:#d8dbcd;       /* stronger borders */
  --surface:#ffffff;      /* cards / sidebar */
  --bg:#faf9f5;           /* page background (warm white) */
  --dark:#1c1f19;         /* contact band */

  /* System */
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Space Grotesk',var(--sans);
  --mono:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --r:14px;
  --r-sm:10px;
  --side:360px;
  --maxw:780px;
}

html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:var(--sans);color:var(--body);background:var(--bg);font-size:16px;line-height:1.65}
img{max-width:100%;display:block}
a{color:var(--olive-text);text-decoration:none}
h1,h2,h3{font-family:var(--display);color:var(--ink);line-height:1.08;letter-spacing:-.02em;font-weight:600}
::selection{background:var(--olive);color:#fff}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip{position:absolute;left:-9999px;top:0;z-index:10000;background:var(--olive-strong);color:#fff;padding:10px 16px;border-radius:8px}
.skip:focus{left:12px;top:12px}
:focus-visible{outline:2px solid var(--olive-strong);outline-offset:3px;border-radius:4px}

/* ---------- Layout ---------- */
.layout{display:grid;grid-template-columns:var(--side) 1fr;align-items:start}
.main{min-width:0}
.container{max-width:var(--maxw);margin:0 auto;padding:0 44px}
.container--wide{max-width:1100px}
.exp-edu{display:grid;grid-template-columns:1.5fr 1fr;gap:46px;align-items:start}
section{padding:78px 0;border-bottom:1px solid var(--line)}
section:last-of-type{border-bottom:0}

/* ---------- Sidebar ---------- */
.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;
  padding:40px 36px;background:var(--surface);border-right:1px solid var(--line)}
.avatar,.avatar-fallback{width:108px;height:108px;border-radius:50%;
  box-shadow:0 0 0 5px var(--olive-soft),0 0 0 6px var(--line)}
.avatar{object-fit:cover;background:var(--olive-tint)}
.avatar-fallback{display:none;align-items:center;justify-content:center;background:var(--olive);
  color:#fff;font-family:var(--display);font-weight:600;font-size:36px}
.s-name{font-family:var(--display);font-size:28px;color:var(--ink);margin-top:24px;letter-spacing:-.025em}
.s-role{color:var(--olive-text);font-weight:500;margin-top:4px}
.s-place{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;color:var(--muted);margin-top:10px}
.s-place svg{width:15px;height:15px;color:var(--olive-strong)}
.s-pos{color:var(--muted);font-size:14.5px;margin-top:14px;line-height:1.55}
.status{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-top:16px}
.status .dot{position:relative;width:8px;height:8px;border-radius:50%;background:var(--olive)}
.status .dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--olive);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(3.2);opacity:0}}

.s-cta{display:flex;flex-direction:column;gap:10px;margin-top:24px}

.nav{margin-top:30px;display:flex;flex-direction:column;gap:1px}
.nav__link{display:flex;align-items:center;gap:13px;font-family:var(--mono);font-size:12.5px;
  letter-spacing:.03em;text-transform:uppercase;color:var(--muted);padding:9px 0;transition:color .2s}
.nav__link::before{content:"";width:18px;height:1.5px;background:var(--line-2);transition:width .28s,background .28s}
.nav__link:hover{color:var(--ink)}
.nav__link:hover::before,.nav__link.is-active::before{width:32px;background:var(--olive)}
.nav__link.is-active{color:var(--ink)}

.s-foot{margin-top:auto;padding-top:28px;display:flex;align-items:center;gap:12px}
.s-loc{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin-right:auto}
.s-loc svg{width:15px;height:15px}
.icon-btn{width:38px;height:38px;border-radius:9px;border:1px solid var(--line-2);
  display:inline-flex;align-items:center;justify-content:center;color:var(--ink);transition:all .2s}
.icon-btn:hover{background:var(--olive-soft);border-color:var(--olive);color:var(--olive-text)}
.icon-btn svg{width:18px;height:18px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);
  font-weight:500;font-size:15px;line-height:1;padding:13px 19px;border-radius:var(--r-sm);
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
  transition:background .2s,color .2s,border-color .2s,transform .3s cubic-bezier(.2,.8,.2,1)}
.btn svg{width:17px;height:17px;flex:0 0 auto}
.btn--block{width:100%}
.btn--primary{background:var(--olive-strong);color:#fff}
.btn--primary:hover{background:var(--olive-deep)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--olive);color:var(--olive-text);background:var(--olive-soft)}
.btn--light{background:var(--olive);color:var(--ink)}
.btn--light:hover{background:#8aab46}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.32)}
.btn--outline-light:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* ---------- Section heads ---------- */
.s-head{display:flex;align-items:baseline;gap:14px;margin-bottom:34px}
.s-head__n{font-family:var(--mono);font-size:13px;color:var(--olive-text)}
.s-head h2{font-size:clamp(24px,3.4vw,32px)}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--mono);font-size:12.5px;
  letter-spacing:.06em;text-transform:uppercase;color:var(--olive-text)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--olive)}

/* ---------- Hero ---------- */
.hero{padding-top:90px}
.hero-grid{display:flex;gap:34px;align-items:center}
.hero-photo,.hero-photo-fallback{flex:0 0 auto;width:210px;height:248px;border-radius:20px}
.hero-photo{object-fit:cover;object-position:center top;box-shadow:0 0 0 1px var(--line)}
.hero-photo-fallback{display:none;align-items:center;justify-content:center;background:var(--olive);color:#fff;font-family:var(--display);font-weight:600;font-size:58px}
.hero-copy{min-width:0}
.hero-title{font-size:clamp(34px,5.2vw,55px);margin-top:22px;letter-spacing:-.03em}
.hero-title .hl{color:var(--olive-text);position:relative;white-space:nowrap}
.hero__sub{font-size:clamp(16px,1.6vw,19px);color:var(--body);margin-top:24px;max-width:60ch}
.hero__cta{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap}

/* ---------- Metrics ---------- */
.metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px;
  transition:border-color .2s,transform .3s cubic-bezier(.2,.8,.2,1)}
.metric:hover{border-color:var(--olive);transform:translateY(-3px)}
.metric__num{font-family:var(--display);font-weight:600;font-size:clamp(28px,4vw,42px);
  color:var(--olive-strong);letter-spacing:-.03em}
.metric__label{color:var(--muted);font-size:14px;margin-top:9px;line-height:1.45}
.win-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:14px}
.win-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px;
  transition:border-color .2s,transform .3s cubic-bezier(.2,.8,.2,1)}
.win-card:hover{border-color:var(--olive);transform:translateY(-3px)}
.win-card__icon{width:42px;height:42px;border-radius:11px;background:var(--olive-tint);color:var(--olive-strong);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:background .25s,color .25s}
.win-card:hover .win-card__icon{background:var(--olive-strong);color:#fff}
.win-card__icon svg{width:22px;height:22px}
.win-card__text{color:var(--body);font-size:15px;line-height:1.5}

/* ---------- Focus marquee ---------- */
.marquee{position:relative;overflow:hidden;border:1px solid var(--line);background:var(--olive-soft);
  border-radius:var(--r);padding:16px 0;display:flex;flex-direction:column;gap:12px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee__row{display:flex;gap:12px;width:max-content;will-change:transform}
.marquee__row--ltr{animation:marquee-ltr 42s linear infinite}
.marquee__row--rtl{animation:marquee-rtl 38s linear infinite}
.marquee:hover .marquee__row{animation-play-state:paused}
@keyframes marquee-ltr{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marquee-rtl{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.chip{display:inline-flex;align-items:center;gap:10px;padding:13px 19px;border-radius:999px;
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-weight:500;
  font-size:15px;white-space:nowrap;transition:border-color .2s,background .2s}
.chip:hover{border-color:var(--olive);background:var(--olive-soft)}
.chip svg{width:18px;height:18px;color:var(--olive-strong);flex:0 0 auto}

/* ---------- Experience ---------- */
.exp{display:flex;gap:26px;padding:32px 0;border-top:1px solid var(--line)}
.exp:first-child{border-top:0;padding-top:0}
.exp__logo{flex:0 0 120px;padding-top:3px}
.exp__logo img{max-height:30px;max-width:120px;width:auto;height:auto;object-fit:contain;object-position:left center}
.exp__logo--mck img{max-height:46px}
.exp__logo--seal img{max-height:42px;border-radius:50%}
.exp__logo--box img{max-height:46px}
.exp__wordmark{font-family:var(--display);font-weight:600;font-size:19px;color:var(--ink)}
.exp__body{min-width:0}
.exp__role,.exp__company{font-family:var(--display);font-weight:600;font-size:19px;color:var(--ink)}
.exp__meta{font-family:var(--mono);font-size:13px;color:var(--muted);margin-top:5px}
.exp__roles{list-style:none;margin-top:2px;display:flex;flex-direction:column;gap:6px}
.exp__roles li{display:flex;justify-content:space-between;gap:14px;font-size:16px;color:var(--ink)}
.exp__roles .r{font-weight:500}
.exp__roles .d{font-family:var(--mono);font-size:13px;color:var(--muted);white-space:nowrap}
.exp__desc{margin-top:13px;color:var(--body)}
.exp__highlights{list-style:none;margin-top:15px;display:flex;flex-direction:column;gap:11px}
.exp__highlights li{position:relative;padding-left:22px;font-size:15px;color:var(--body)}
.exp__highlights li::before{content:"";position:absolute;left:1px;top:8px;width:7px;height:7px;
  background:var(--olive);transform:rotate(45deg)}

/* ---------- Education ---------- */
.edu{display:flex;gap:24px;padding:28px 0;border-top:1px solid var(--line)}
.edu:first-child{border-top:0;padding-top:0}
.mono-tile{flex:0 0 64px;width:64px;height:64px;border-radius:14px;border:1px solid var(--line);
  background:var(--olive-tint);color:var(--olive-deep);font-family:var(--display);font-weight:700;
  font-size:22px;display:flex;align-items:center;justify-content:center;letter-spacing:-.02em}
.logo-tile{flex:0 0 64px;width:64px;height:64px;border-radius:14px;border:1px solid var(--line);
  background:#fff;display:flex;align-items:center;justify-content:center;padding:10px;overflow:hidden}
.logo-tile img{max-width:100%;max-height:100%;object-fit:contain}
.edu__school{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink);line-height:1.25}
.edu__deg{color:var(--olive-text);font-weight:500;font-size:15px;margin-top:4px}
.edu__meta{font-family:var(--mono);font-size:13px;color:var(--muted);margin-top:5px}
.edu__note{color:var(--body);font-size:14.5px;margin-top:9px}

/* ---------- Personal ---------- */
.personal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.p-card{display:flex;gap:16px;padding:22px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--surface);transition:border-color .2s,transform .3s cubic-bezier(.2,.8,.2,1)}
.p-card:hover{border-color:var(--olive);transform:translateY(-3px)}
.p-card__icon{flex:0 0 46px;width:46px;height:46px;border-radius:12px;background:var(--olive-tint);
  color:var(--olive-strong);display:flex;align-items:center;justify-content:center;
  transition:background .25s,color .25s,transform .25s}
.p-card:hover .p-card__icon{background:var(--olive-strong);color:#fff;transform:rotate(-6deg) scale(1.06)}
.p-card__icon svg{width:24px;height:24px}
.p-card__title{font-family:var(--display);font-weight:600;font-size:17px;color:var(--ink)}
.p-card__text{color:var(--body);font-size:14.5px;margin-top:6px;line-height:1.55}
.p-card__text a{color:var(--olive-text);font-weight:500;text-decoration:underline;text-underline-offset:2px}
.p-card__text a:hover{color:var(--olive-deep)}

/* ---------- Contact band ---------- */
.contact{background:var(--dark);border-bottom:0}
.contact .eyebrow{color:#bcd07f}
.contact .eyebrow::before{background:var(--olive)}
.contact h2{color:#fff;font-size:clamp(30px,4.6vw,48px);margin-top:16px;letter-spacing:-.03em}
.contact__sub{color:rgba(255,255,255,.74);margin-top:18px;max-width:50ch}
.contact__cta{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.contact__alt{margin-top:24px;color:rgba(255,255,255,.55);font-size:13.5px;font-family:var(--mono)}

/* ---------- Footer ---------- */
.footer{padding:30px 0}
.footer .container{display:flex;justify-content:space-between;align-items:center;gap:16px;
  flex-wrap:wrap;font-family:var(--mono);font-size:13px;color:var(--muted)}
.footer a:hover{color:var(--olive-text)}

/* ---------- Reveal on scroll ---------- */
.js .reveal{opacity:0;transform:translateY(18px);
  transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.08s}
.js .reveal.d2{transition-delay:.16s}
.js .reveal.d3{transition-delay:.24s}

/* ---------- Custom cursor (desktop, fine pointer only) ---------- */
.cursor-ring{position:fixed;top:0;left:0;width:30px;height:30px;margin:-15px 0 0 -15px;
  border:1.5px solid var(--olive);border-radius:50%;pointer-events:none;z-index:9999;opacity:.7;
  transition:width .22s,height .22s,margin .22s,background .22s,opacity .3s}
.cursor-ring.is-hover{width:52px;height:52px;margin:-26px 0 0 -26px;background:rgba(122,154,60,.12);opacity:1}

/* ---------- Responsive ---------- */
@media (max-width:1024px){:root{--side:300px}.container{padding:0 36px}}

@media (max-width:860px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--line);padding:30px 28px}
  .nav{flex-direction:row;flex-wrap:wrap;gap:4px 18px;margin-top:24px}
  .nav__link::before{display:none}
  .nav__link{padding:6px 0}
  .s-cta{flex-direction:row;flex-wrap:wrap}
  .s-foot{margin-top:24px}
  .container{padding:0 28px}
  .container--wide{max-width:var(--maxw)}
  .exp-edu{grid-template-columns:1fr;gap:40px}
  .hero{padding-top:56px}
  section{padding:56px 0}
}

@media (max-width:560px){
  .exp,.edu{flex-direction:column;gap:13px}
  .exp__logo{flex-basis:auto}
  .s-cta .btn{flex:1}
  .metric{padding:22px 20px}
  .metrics{grid-template-columns:1fr}
  .personal-grid{grid-template-columns:1fr}
  .hero-grid{flex-direction:column;align-items:flex-start;gap:22px}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .marquee__row{animation:none!important}
  .marquee{overflow-x:auto}
  .status .dot::after{animation:none!important}
  *{scroll-behavior:auto!important}
}
