/* =========================================================
   RESUME PAGE
========================================================= */

:root {
  --resume-cream: #f7f3ee;
  --resume-black: #151515;
  --resume-orange: #d9672f;
  --resume-blue: #2f80ed;
  --resume-blue-dark: #1f5fac;
  --resume-muted: rgba(21, 21, 21, 0.7);
}

html { scroll-behavior: smooth; }

.ResumePageWrapper {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(255, 145, 77, 0.16), transparent 34rem),
    radial-gradient(circle at 90% 15%, rgba(20, 20, 20, 0.08), transparent 28rem),
    var(--resume-cream);
  color: var(--resume-black);
  overflow-x: hidden;
}

.ResumeHeader {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px clamp(18px, 4vw, 64px);
  background: rgba(247, 243, 238, 0.84);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(20, 20, 20, 0.08);
}

.ResumeHeader img { width: 46px; }

.ResumeHeader nav {
  display: flex;
  gap: 8px;
}

.ResumeHeader nav a {
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 800;
  padding: 10px 14px;
  border-radius: 999px;
  color: var(--resume-black);
  transition: 0.25s ease;
}

.ResumeHeader nav a:hover {
  background: var(--resume-black);
  color: #fff;
  transform: translateY(-2px);
}

.ResumeHero {
  padding: clamp(70px, 10vw, 140px) clamp(20px, 5vw, 80px) clamp(40px, 7vw, 90px);
}

.ResumeHeroInner {
  max-width: 1120px;
  margin: 0 auto;
}

.ResumeEyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.76rem;
  font-weight: 900;
  color: var(--resume-orange);
  margin-bottom: 12px;
}

.ResumeHero h1 {
  font-size: clamp(3.4rem, 8vw, 8rem);
  letter-spacing: -0.08em;
  line-height: 0.9;
  margin: 0;
  font-weight: 950;
}

.ResumeHero h2 {
  margin: 10px 0 20px;
  font-size: clamp(1.2rem, 2vw, 1.8rem);
  font-weight: 800;
  color: rgba(21, 21, 21, 0.65);
}

.ResumeSummary {
  max-width: 820px;
  line-height: 1.7;
  color: var(--resume-muted);
}

.ResumeHeroButtons {
  display: flex;
  gap: 12px;
  margin-top: 30px;
  flex-wrap: wrap;
}

.ResumeHeroButtons a,
.ResumeHeroButtons button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 900;
  transition: 0.25s ease;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.95rem;
}

.ResumeHeroButtons a:first-child,
.ResumeHeroButtons button {
  background: var(--resume-black);
  color: #fff;
}

.ResumeHeroButtons a:nth-child(2) {
  background: #fff;
  color: var(--resume-black);
  border: 1px solid rgba(21, 21, 21, 0.1);
}

.ResumeHeroButtons a:hover,
.ResumeHeroButtons button:hover { transform: translateY(-3px); }

.ResumeModePanel {
  margin-top: 34px;
  padding: 22px;
  border-radius: 28px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(21,21,21,.08);
  box-shadow: 0 24px 60px rgba(21,21,21,.06);
}

.ResumeModeLabel {
  margin: 0 0 4px;
  font-weight: 950;
}

.ResumeModeHint {
  margin: 0 0 16px;
  color: var(--resume-muted);
  line-height: 1.5;
}

.ResumeModeButtons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ResumeModeButton {
  border: 1px solid rgba(21,21,21,.1);
  background: #fff;
  color: var(--resume-black);
  border-radius: 999px;
  padding: 11px 16px;
  font-weight: 900;
  font-family: inherit;
  cursor: pointer;
  transition: .25s ease;
}

.ResumeModeButton:hover,
.ResumeModeButton.active {
  background: var(--resume-black);
  color: #fff;
  transform: translateY(-2px);
}

.ResumePreviewSection {
  padding: 0 clamp(20px, 5vw, 80px) clamp(70px, 9vw, 120px);
}

.ResumeContent {
  max-width: 980px;
  margin: 0 auto;
}

.ResumeContent h2 {
  font-size: clamp(2.3rem, 5vw, 5rem);
  letter-spacing: -0.06em;
  margin: 0 0 18px;
}

.ResumePreviewIntro {
  margin-bottom: 28px;
}

.ResumePreviewIntro p:last-child {
  color: var(--resume-muted);
  line-height: 1.7;
}

.ResumePaper {
  max-width: 1120px;
  margin: 0 auto;
  background: #fff;
  color: #151515;
  box-shadow: 0 34px 90px rgba(21,21,21,.14);
  border-radius: 26px;
  overflow: hidden;
}

.ResumeSheet {
  width: 100%;
  min-height: 1120px;
  display: grid;
  grid-template-columns: 34% 66%;
  background: #fff;
}

.ResumeSidebar {
  background: linear-gradient(180deg, #07111d, #101e2f 58%, #173f73);
  color: #fff;
  padding: 0 26px 28px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.ResumePhoto {
  margin: 0 -26px 14px;
  height: 315px;
  background: #111;
  overflow: hidden;
}

.ResumePhoto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 22%;
  display: block;
}

.ResumeName {
  font-size: clamp(2.4rem, 4vw, 3.5rem);
  line-height: .9;
  font-weight: 950;
  letter-spacing: -.07em;
  margin: 0;
}

.ResumeName span {
  display: block;
  color: var(--resume-blue);
}

.ResumeRole {
  margin: 14px 0 5px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ResumeTagline {
  color: rgba(255,255,255,.8);
  font-size: .9rem;
  line-height: 1.45;
  margin: 0;
}

.ResumeContact {
  display: grid;
  gap: 9px;
  font-size: .92rem;
}

.ResumeContact a,
.ResumeContact span {
  color: #fff;
  text-decoration: none;
}

.ResumeBlockTitle {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 13px;
  color: #fff;
  font-size: .9rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 950;
}

.ResumeBlockTitle::after {
  content: "";
  height: 1px;
  background: rgba(47,128,237,.85);
  flex: 1;
}

.ResumeSkillList {
  display: grid;
  gap: 7px;
}

.ResumeSkill {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
  font-size: .82rem;
}

.Stars {
  color: var(--resume-blue);
  letter-spacing: .06em;
  white-space: nowrap;
}

.Stars .empty {
  color: rgba(255,255,255,.32);
}

.ResumeTools {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ResumeTool {
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 10px;
  padding: 8px 10px;
  font-size: .78rem;
  font-weight: 850;
}

.ResumeQuote {
  margin: auto 0 0;
  border-left: 4px solid var(--resume-blue);
  padding-left: 14px;
  font-style: italic;
  color: rgba(255,255,255,.86);
  line-height: 1.5;
  font-size: .92rem;
}

.ResumeMain {
  padding: 34px 40px 28px;
}

.ResumeSectionHeading {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #0d1d34;
  font-size: 1.15rem;
  text-transform: uppercase;
  letter-spacing: .02em;
  margin: 0 0 12px;
}

.ResumeIcon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: var(--resume-blue);
  color: #fff;
  display: inline-grid;
  place-items: center;
  font-size: 14px;
  flex: 0 0 auto;
}

.ResumeAboutText {
  color: #172033;
  line-height: 1.55;
  margin: 0;
}

.ResumeDivider {
  height: 1px;
  background: rgba(13,29,52,.16);
  margin: 24px 0;
}

.ResumeJob {
  margin-top: 20px;
}

.ResumeJobHeader {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: start;
  margin-bottom: 8px;
}

.ResumeJobTitle {
  margin: 0;
  color: #0c1c32;
  font-size: .98rem;
  text-transform: uppercase;
  letter-spacing: .01em;
}

.ResumeJobTitle span {
  color: var(--resume-blue-dark);
  font-weight: 800;
  text-transform: none;
}

.ResumeDate {
  color: #0c1c32;
  font-weight: 850;
  white-space: nowrap;
  font-size: .9rem;
}

.ResumeJob ul {
  margin: 8px 0 0 18px;
  padding: 0;
}

.ResumeJob li {
  margin: 6px 0;
  line-height: 1.42;
  color: #202b3c;
  font-size: .88rem;
}

.ResumeBottomGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
}

.ResumeMiniList {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 7px;
}

.ResumeMiniList li,
.ResumeMiniList a {
  color: #202b3c;
  text-decoration: none;
  font-size: .9rem;
}

.ResumeAchievementRow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  border-top: 1px solid rgba(13,29,52,.16);
  margin-top: 22px;
  padding-top: 18px;
}

.ResumeAchievement {
  font-size: .78rem;
  line-height: 1.35;
}

.ResumeAchievement strong {
  display: block;
  color: var(--resume-blue-dark);
  margin-bottom: 4px;
}

/* TRUE 8.5 X 11 PDF PAGES */

.ResumePDFHidden {
  position: fixed;
  left: -99999px;
  top: 0;
  width: 8.5in;
  height: auto;
  background: #fff;
  overflow: hidden;
}

.ResumePDFIsGenerating .ResumePDFHidden {
  position: fixed;
  left: 0;
  top: 0;
  z-index: -1;
  opacity: 0;
  width: 8.5in;
}

.ResumePDFPage {
  width: 8.5in !important;
  height: 11in !important;
  min-width: 8.5in !important;
  max-width: 8.5in !important;
  min-height: 11in !important;
  max-height: 11in !important;
  background: #fff;
  overflow: hidden;
  box-sizing: border-box;
  display: block;
}

.ResumePDFPage .ResumeSheet {
  width: 8.5in !important;
  height: 11in !important;
  min-height: 11in !important;
  grid-template-columns: 34% 66%;
}

.ResumePDFPage .ResumeSidebar {
  padding: 0 17px 17px;
  gap: 10px;
}

.ResumePDFPage .ResumePhoto {
  height: 2.35in;
  margin-left: -17px;
  margin-right: -17px;
  margin-bottom: 8px;
}

.ResumePDFPage .ResumePhoto img {
  object-fit: cover;
  object-position: center 18%;
}

.ResumePDFPage .ResumeName { font-size: 31px; }

.ResumePDFPage .ResumeRole {
  font-size: 9.2px;
  margin: 9px 0 3px;
}

.ResumePDFPage .ResumeTagline,
.ResumePDFPage .ResumeContact,
.ResumePDFPage .ResumeQuote { font-size: 8.3px; }

.ResumePDFPage .ResumeContact { gap: 5px; }

.ResumePDFPage .ResumeBlockTitle {
  font-size: 8.8px;
  margin-bottom: 6px;
}

.ResumePDFPage .ResumeSkillList { gap: 4px; }

.ResumePDFPage .ResumeSkill {
  font-size: 7.6px;
  gap: 6px;
}

.ResumePDFPage .ResumeTool {
  font-size: 7.4px;
  padding: 4px 5px;
  border-radius: 7px;
}

.ResumePDFPage .ResumeMain { padding: 20px 24px 16px; }

.ResumePDFPage .ResumeSectionHeading {
  font-size: 11.8px;
  margin-bottom: 6px;
  gap: 8px;
}

.ResumePDFPage .ResumeIcon {
  width: 21px;
  height: 21px;
  font-size: 9px;
}

.ResumePDFPage .ResumeAboutText {
  font-size: 8.9px;
  line-height: 1.36;
}

.ResumePDFPage .ResumeDivider { margin: 10px 0; }

.ResumePDFPage .ResumeJob { margin-top: 8px; }

.ResumePDFPage .ResumeJobHeader {
  gap: 10px;
  margin-bottom: 4px;
}

.ResumePDFPage .ResumeJobTitle { font-size: 9.1px; }

.ResumePDFPage .ResumeDate { font-size: 8px; }

.ResumePDFPage .ResumeJob ul { margin-top: 4px; }

.ResumePDFPage .ResumeJob li {
  font-size: 8px;
  margin: 2.4px 0;
  line-height: 1.25;
}

.ResumePDFPage .ResumeBottomGrid { gap: 14px; }

.ResumePDFPage .ResumeMiniList { gap: 4px; }

.ResumePDFPage .ResumeMiniList li,
.ResumePDFPage .ResumeMiniList a { font-size: 8px; }

.ResumePDFPage .ResumeAchievementRow {
  gap: 7px;
  margin-top: 8px;
  padding-top: 8px;
}

.ResumePDFPage .ResumeAchievement { font-size: 7.1px; }

.ResumePDFPage2 {
  padding: .45in;
}

.ResumePDFHeader {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  border-bottom: 2px solid var(--resume-blue);
  padding-bottom: 14px;
  margin-bottom: 20px;
  gap: 24px;
}

.ResumePDFHeader h2 {
  margin: 0;
  font-size: 30px;
  letter-spacing: -.05em;
}

.ResumePDFHeader p {
  margin: 5px 0 0;
  color: rgba(21,21,21,.7);
  font-size: 10.5px;
  line-height: 1.4;
}

.ResumePortfolioBlock {
  text-align: right;
  font-size: 10.5px;
}

.ResumePortfolioBlock p {
  margin: 0 0 3px;
  text-transform: uppercase;
  font-weight: 900;
  color: #0c1c32;
  letter-spacing: .08em;
}

.ResumePortfolioBlock a {
  color: var(--resume-blue-dark);
  font-weight: 900;
  text-decoration: none;
}

.ResumePortfolioBlock img {
  width: .86in;
  height: .86in;
  margin-top: 8px;
  object-fit: contain;
}

.ResumePDFTwoCol {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.ResumePDFSection {
  margin-bottom: 18px;
}

.ResumePDFSection h3 {
  margin: 0 0 9px;
  text-transform: uppercase;
  font-size: 13px;
  color: #0c1c32;
}

.ResumePDFSection p,
.ResumePDFSection li {
  font-size: 10.5px;
  line-height: 1.42;
}

.ResumePDFSection ul {
  margin: 0 0 0 17px;
  padding: 0;
}

.ResumePDFSection li { margin: 5px 0; }

.ResumePDFSkillGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px 14px;
}

.ResumePDFSkillGrid div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 10px;
}

/* FOOTER */

.ResumePageWrapper .FooterSection {
  background: #151515;
  color: #fff;
}

/* RESPONSIVE */

@media (max-width: 900px) {
  .ResumeSheet { grid-template-columns: 1fr; }
  .ResumePhoto { height: 360px; }
  .ResumeMain { padding: 28px 24px; }
  .ResumeBottomGrid,
  .ResumeAchievementRow { grid-template-columns: 1fr; }
  .ResumeJobHeader {
    grid-template-columns: 1fr;
    gap: 5px;
  }
}

@media (max-width: 700px) {
  .ResumeHeader {
    flex-direction: column;
    text-align: center;
  }

  .ResumeHeader nav {
    flex-wrap: wrap;
    justify-content: center;
  }

  .ResumeHeroButtons { flex-direction: column; }

  .ResumeHeroButtons a,
  .ResumeHeroButtons button { width: 100%; }
}
