:root{
  --black:#070707; --ink:#111111; --dark:#0e0e10; --cream:#f7f1ec; --cream2:#efe5df;
  --rose:#f5bdc9; --rose2:#d88fa0; --burgundy:#4a111d; --muted:#a99d99;
  --line:rgba(255,255,255,.14); --shadow:0 28px 90px rgba(0,0,0,.45);
  --serif: Georgia, "Times New Roman", serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);background:radial-gradient(circle at 20% 0%, rgba(245,189,201,.22), transparent 28rem),radial-gradient(circle at 100% 20%, rgba(95,14,29,.36), transparent 34rem),linear-gradient(180deg,#050505 0%,#121011 38%,#080808 100%);color:var(--cream);min-height:100vh;overflow-x:hidden}
button,a{font-family:inherit} button{cursor:pointer} a{color:inherit;text-decoration:none} img{max-width:100%;display:block}
.noise{position:fixed;inset:0;pointer-events:none;opacity:.08;z-index:20;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.65'/%3E%3C/svg%3E")}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--rose),#fff,var(--rose2));z-index:80;box-shadow:0 0 24px rgba(245,189,201,.65)}
.cursor-glow{position:fixed;width:22rem;height:22rem;border-radius:50%;background:radial-gradient(circle,rgba(245,189,201,.14),transparent 70%);pointer-events:none;transform:translate(-50%,-50%);z-index:1}
.site-header{width:min(1160px, calc(100% - 32px));position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:30;display:flex;align-items:center;gap:24px;padding:12px 16px;border:1px solid var(--line);border-radius:26px;background:rgba(10,10,11,.66);backdrop-filter:blur(18px);box-shadow:0 16px 60px rgba(0,0,0,.28)}
.logo{font-family:var(--serif);font-size:28px;letter-spacing:.03em}.desktop-nav{display:flex;gap:22px;margin-inline:auto;font-size:12px;color:rgba(247,241,236,.78)}.desktop-nav a{position:relative}.desktop-nav a:after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--rose);transition:.3s}.desktop-nav a:hover:after{width:100%}
.nav-cta,.btn,.text-link{font-size:12px}.nav-cta{border:1px solid rgba(245,189,201,.35);padding:10px 14px;border-radius:999px}.menu-btn,.menu-close{display:none;background:none;border:0;color:var(--cream);font-size:26px}.mobile-menu{display:none}
.section{width:min(1160px, calc(100% - 32px));margin:0 auto;padding:96px 0;scroll-margin-top:120px}.hero{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:56px;padding-top:142px}
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--muted);margin:0 0 16px}.hero h1,.section h2{font-family:var(--serif);font-weight:400;line-height:.88;margin:0}.hero h1{font-size:clamp(64px,9vw,138px)}.hero h1 em,.section h2 em{color:var(--rose);font-style:italic}
.role{font-size:18px;margin:28px 0 8px}.tags,.location{color:rgba(247,241,236,.74);margin:8px 0}.availability{display:inline-flex;margin:20px 0 26px;padding:11px 16px;border:1px solid rgba(245,189,201,.35);border-radius:999px;color:var(--rose);text-transform:uppercase;font-size:12px;letter-spacing:.08em;background:rgba(245,189,201,.05)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:14px;border-radius:4px;padding:16px 22px;border:1px solid rgba(245,189,201,.26);transition:.25s}.btn:hover,.project-card:hover,.repo-card:hover{transform:translateY(-6px)}.primary{background:var(--rose);color:#111;border-color:var(--rose)}.ghost{background:rgba(255,255,255,.03);color:var(--cream)}
.hero-visual{position:relative;min-height:620px;display:flex;align-items:center;justify-content:center}.portrait-frame{width:min(430px,80vw);aspect-ratio:3/4;border-radius:48% 48% 8px 8px;overflow:hidden;background:linear-gradient(#f3c5ce,#8b303d);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.22);transition:transform .16s ease}.portrait-frame img{width:100%;height:100%;object-fit:cover;object-position:center 33%;filter:saturate(1.04) contrast(1.03)}
.portrait-orbit{position:absolute;width:150px;height:150px;border:1px solid rgba(245,189,201,.38);border-radius:50%;right:4%;top:18%;display:grid;place-items:center;color:var(--rose);font-family:var(--serif);font-size:34px;background:rgba(15,15,16,.55);backdrop-filter:blur(10px)}.portrait-orbit:after{content:"2026"}.portrait-orbit span{position:absolute;inset:-18px;border-radius:50%;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(247,241,236,.65);animation:spin 18s linear infinite;text-align:center}@keyframes spin{to{transform:rotate(360deg)}}.hand-note{position:absolute;left:4%;top:34%;font-family:var(--serif);font-style:italic;font-size:34px;color:var(--rose);transform:rotate(-10deg);opacity:.86}.mini-card{position:absolute;right:0;bottom:8%;width:250px;padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(15,15,16,.58);backdrop-filter:blur(14px)}.mini-card strong{display:block;margin-bottom:8px}.mini-card span{color:rgba(247,241,236,.7);font-size:13px}
.stats-bar{width:min(1160px,calc(100% - 32px));margin:-30px auto 20px;display:grid;grid-template-columns:repeat(4,1fr);background:var(--cream);color:var(--ink);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.stats-bar div{display:grid;gap:4px;text-align:center;border-right:1px solid rgba(0,0,0,.1)}.stats-bar div:last-child{border-right:0}.stats-bar strong{font-family:var(--serif);font-size:30px;color:var(--burgundy)}.stats-bar span{text-transform:uppercase;font-size:11px;letter-spacing:.1em;color:#655a57}
.motion-strip{overflow:hidden;border-block:1px solid rgba(255,255,255,.1);background:rgba(245,189,201,.04)}.marquee{display:flex;white-space:nowrap}.marquee span{display:inline-block;padding:18px 0;font-family:var(--serif);font-size:28px;color:rgba(245,189,201,.8);animation:marquee 30s linear infinite}.marquee span+span{margin-left:42px}@keyframes marquee{to{transform:translateX(-100%)}}
.section-heading,.section-top{display:flex;justify-content:space-between;align-items:end;gap:28px;margin-bottom:34px}.section h2{font-size:clamp(44px,6vw,82px)}.section-subtitle{max-width:680px;color:#655a57;line-height:1.55;margin:18px 0 0}
.about,.projects{background:var(--cream);color:var(--ink);width:100%;padding-inline:max(16px, calc((100vw - 1160px)/2));border-radius:42px 42px 0 0}.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px}.about-text{font-family:var(--serif);font-size:24px;line-height:1.35;color:#231d1b}.value-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.value-grid article{border:1px solid rgba(0,0,0,.12);border-radius:24px;padding:24px;background:rgba(255,255,255,.42)}.value-grid span{color:var(--rose2);font-family:var(--serif);font-size:28px}.value-grid h3{font-family:var(--serif);font-size:28px;margin:14px 0 10px}.value-grid p{color:#655a57}
.folder-tabs{display:flex;gap:10px;flex-wrap:wrap}.folder-tab{border:1px solid rgba(0,0,0,.14);background:transparent;border-radius:999px;padding:12px 16px;cursor:pointer}.folder-tab.active{background:#111;color:#fff}.folder-panel{display:none}.folder-panel.active{display:block}.project-carousel{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(340px,1fr);gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 4px 18px}.project-carousel::-webkit-scrollbar{height:6px}.project-carousel::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px}
.project-card{scroll-snap-align:start;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:26px;overflow:hidden;transition:.3s;box-shadow:0 24px 50px rgba(0,0,0,.08);text-align:left;padding:0;color:#111;min-width:0}.project-card.featured{box-shadow:0 34px 80px rgba(74,17,29,.18)}.project-card img{width:100%;aspect-ratio:16/10;object-fit:cover}.project-card div{padding:22px}.project-card p{color:#655a57;margin:0 0 8px}.project-card h3{font-family:var(--serif);font-size:32px;margin:0 0 12px}.project-card span{font-size:11px;letter-spacing:.12em;color:#7f6c69}
.code-lab,.cv,.stack,.contact{background:#0d0d0f}.text-link{color:var(--rose)}.repo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.repo-card{border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));padding:22px;min-height:250px;display:flex;flex-direction:column;transition:.3s;position:relative;overflow:hidden}.repo-card:before{content:"";position:absolute;inset:auto -30% -30% auto;width:160px;height:160px;background:var(--rose);filter:blur(70px);opacity:.15}.repo-top{display:flex;justify-content:space-between;align-items:center}.repo-icon{width:34px;height:34px;border-radius:8px;background:var(--rose);color:#111;display:grid;place-items:center;font-weight:700}.repo-more{background:transparent;border:0;color:var(--muted);font-size:20px}.repo-card h3{font-family:var(--serif);font-size:25px;margin:20px 0 10px}.repo-card p{color:rgba(247,241,236,.68);font-size:14px;line-height:1.5;flex:1}.chips{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}.chips span{font-size:11px;border:1px solid var(--line);border-radius:999px;padding:6px 9px;color:rgba(247,241,236,.72)}.repo-card a{font-size:13px;color:var(--rose)}
.cv-panel{display:grid;grid-template-columns:1fr 320px;gap:22px;border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.04);padding:20px}.tabs{grid-column:1/-1;display:flex;border:1px solid var(--line);border-radius:999px;padding:6px;gap:6px;width:max-content}.tab{background:transparent;border:0;color:var(--cream);padding:12px 22px;border-radius:999px;cursor:pointer}.tab.active{background:var(--rose);color:#111}.tab-content{display:none}.tab-content.active{display:block}.timeline-item{position:relative;padding:0 0 28px 30px;border-left:1px solid rgba(245,189,201,.28)}.timeline-item:before{content:"";position:absolute;left:-6px;top:3px;width:11px;height:11px;border-radius:50%;background:var(--rose)}.timeline-item span{color:var(--rose);font-size:12px}.timeline-item h3{font-family:var(--serif);font-size:28px;margin:8px 0}.timeline-item p{color:rgba(247,241,236,.7);line-height:1.55}.cv-side{display:grid;gap:14px}.cv-side div{border:1px solid var(--line);border-radius:18px;padding:18px;background:rgba(255,255,255,.04)}.cv-side strong{display:block;color:var(--rose);margin-bottom:8px}.cv-side span{color:rgba(247,241,236,.7);font-size:14px}
.stack-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}.stack-grid span{border:1px solid var(--line);border-radius:18px;padding:18px;text-align:center;background:rgba(255,255,255,.04);transition:.25s}.stack-grid span:hover{background:var(--rose);color:#111;transform:translateY(-4px)}
.contact-card{display:grid;grid-template-columns:1.3fr .7fr;gap:30px;align-items:center;border-radius:34px;padding:34px;background:linear-gradient(135deg,var(--cream),#f3cbd3);color:#111;overflow:hidden}.contact-card h2{font-family:var(--serif);font-size:clamp(40px,6vw,76px);line-height:.95;margin:0}.contact-card p{font-size:18px;line-height:1.5;color:#4c403d}.contact-card img{height:420px;width:100%;object-fit:cover;border-radius:28px;filter:saturate(1.04);object-position:center}.contact-links{display:flex;gap:12px;flex-wrap:wrap}.contact-links a{border:1px solid rgba(0,0,0,.16);border-radius:999px;padding:12px 16px}
.project-modal{width:min(1080px,calc(100% - 32px));border:1px solid rgba(245,189,201,.28);border-radius:32px;padding:0;background:#0b0b0d;color:var(--cream);box-shadow:0 40px 140px rgba(0,0,0,.7);overflow:hidden}.project-modal::backdrop{background:rgba(0,0,0,.72);backdrop-filter:blur(8px)}.modal-close{position:absolute;right:18px;top:14px;z-index:2;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:rgba(0,0,0,.32);color:#fff;font-size:28px}.modal-layout{display:grid;grid-template-columns:.95fr 1.05fr}.modal-media{background:var(--cream);display:flex;align-items:center}.modal-media img{width:100%;height:100%;object-fit:cover}.modal-copy{padding:44px;max-height:80vh;overflow:auto}.modal-copy h2{font-family:var(--serif);font-weight:400;font-size:clamp(42px,5vw,78px);line-height:.92;margin:0 0 18px}.modal-copy>p{color:rgba(247,241,236,.72);line-height:1.55}.modal-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0}.modal-columns div{border:1px solid var(--line);border-radius:18px;padding:16px;background:rgba(255,255,255,.04)}.modal-columns strong{display:block;color:var(--rose);margin-bottom:8px}.modal-columns span{font-size:13px;color:rgba(247,241,236,.72)}.modal-section h3{font-family:var(--serif);font-size:28px;margin:24px 0 8px}.modal-section p{color:rgba(247,241,236,.72);line-height:1.6}.modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
footer{width:min(1160px,calc(100% - 32px));margin:0 auto;padding:36px 0 60px;display:flex;justify-content:space-between;gap:20px;color:rgba(247,241,236,.6);font-size:13px}.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}.reveal.visible{opacity:1;transform:none}
@media (max-width:1100px){.repo-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:900px){.desktop-nav,.nav-cta{display:none}.menu-btn{display:block;margin-left:auto}.site-header{border-radius:20px}.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(340px,100%);background:#09090a;z-index:50;padding:24px;display:flex;flex-direction:column;gap:22px;transform:translateX(100%);transition:.3s;border-left:1px solid var(--line)}.mobile-menu.open{transform:none}.menu-close{display:block;align-self:flex-end}.hero{grid-template-columns:1fr;gap:20px}.hero-visual{min-height:500px}.hand-note{left:0}.mini-card{display:none}.stats-bar,.stack-grid{grid-template-columns:1fr 1fr}.about-grid,.cv-panel,.contact-card,.modal-layout{grid-template-columns:1fr}.about,.projects{border-radius:28px 28px 0 0}.section-heading,.section-top{display:block}.folder-tabs{margin-top:20px}.modal-copy{max-height:none}.modal-media img{max-height:320px}}
@media (max-width:560px){.section{padding:72px 0}.hero h1{font-size:64px}.hero-actions{display:grid}.btn{justify-content:center}.stats-bar,.repo-grid,.stack-grid{grid-template-columns:1fr}.stats-bar div{border-right:0;border-bottom:1px solid rgba(0,0,0,.1);padding:12px}.project-carousel{grid-auto-columns:86vw}.tabs{width:100%;overflow:auto}.tab{white-space:nowrap}.contact-card{padding:22px}.contact-card img{height:300px}.about-text{font-size:20px}.value-grid{grid-template-columns:1fr}.modal-copy{padding:28px}.modal-columns{grid-template-columns:1fr}footer{flex-direction:column}}


/* ---------- recruiter-focused portfolio v5 additions ---------- */

.recruiter-snapshot {
  background: #0d0d0f;
}
.recruiter-snapshot .section-subtitle.light,
.section-subtitle.light {
  color: rgba(247,241,236,.66);
}
.hire-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.hire-grid article {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  min-height: 250px;
}
.hire-grid span {
  color: var(--rose);
  font-family: var(--serif);
  font-size: 36px;
}
.hire-grid h3 {
  font-family: var(--serif);
  font-size: 28px;
  margin: 56px 0 12px;
}
.hire-grid p {
  color: rgba(247,241,236,.68);
  line-height: 1.55;
  margin: 0;
}

.repo-grid.expanded {
  grid-template-columns: repeat(4, 1fr);
}
.featured-repo {
  border-color: rgba(245,189,201,.36);
  box-shadow: 0 26px 70px rgba(245,189,201,.10);
}
.repo-links {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.repo-links a {
  color: var(--rose);
}

.modal-media {
  padding: 22px;
}
.modal-media img {
  object-fit: contain;
  border-radius: 18px;
  max-height: 76vh;
  background: var(--cream);
}

.cv-side {
  align-content: start;
}

@media (max-width: 1100px) {
  .hire-grid,
  .repo-grid.expanded {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .hire-grid,
  .repo-grid.expanded {
    grid-template-columns: 1fr;
  }
  .hire-grid h3 {
    margin-top: 32px;
  }
}


/* ---------- v6 recruiter conversion improvements ---------- */

.hero-proof {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: 12px;
  margin-top: 22px;
  max-width: 720px;
}
.hero-proof div {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,.045);
  backdrop-filter: blur(12px);
}
.hero-proof strong {
  display: block;
  color: var(--rose);
  margin-bottom: 8px;
}
.hero-proof span {
  color: rgba(247,241,236,.68);
  font-size: 13px;
  line-height: 1.45;
}

.cv-panel {
  grid-template-columns: minmax(0, 1fr) 380px;
}
.cv-side div {
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
}

.project-modal {
  width: min(1040px, calc(100% - 32px));
}
.modal-layout {
  grid-template-columns: .85fr 1.15fr;
}
.modal-media {
  padding: 30px;
}
.modal-media img {
  width: 100%;
  height: auto;
  max-height: 70vh;
  object-fit: contain;
}

.contact-links a {
  transition: .25s ease;
}
.contact-links a:hover {
  transform: translateY(-3px);
  background: rgba(0,0,0,.06);
}

@media (max-width: 900px) {
  .hero-proof,
  .cv-panel {
    grid-template-columns: 1fr;
  }
}


/* ---------- v6.1 contact photo orientation fix ---------- */
.contact-card img {
  object-fit: cover;
  object-position: center 36%;
  transform: none !important;
}
