/* ============================================================
   Profile pages · Engineering Blueprint
   ============================================================ */

/* MAGAZINE HERO ------------------------------------------------ */
.profile-hero{
  position:relative;
  padding-top:var(--s-7);
  padding-bottom:var(--s-9);
  overflow:hidden;
}
.profile-hero .backlink{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:var(--s-6);
  transition:color .2s var(--t-fast);
}
.profile-hero .backlink:hover{color:var(--signal)}

.profile-hero-grid{
  display:grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--s-7);
  align-items: end;
}
.profile-portrait{
  position:relative;
  aspect-ratio: 4/5;
  background:var(--paper-tint);
  border:1px solid var(--rule);
  overflow:hidden;
}
.profile-portrait img{
  width:100%;height:100%;object-fit:cover; object-position:top;
  display:block;
  filter: contrast(1.05) saturate(.85);
}
.profile-portrait::before{
  content:""; position:absolute; top:-1px; left:-1px;
  width:36px;height:36px;
  border-top:1px solid var(--ink); border-left:1px solid var(--ink);
}
.profile-portrait::after{
  content:""; position:absolute; bottom:-1px; right:-1px;
  width:36px;height:36px;
  border-bottom:1px solid var(--ink); border-right:1px solid var(--ink);
}

.profile-meta{
  position:absolute; top:var(--s-4); left:var(--s-4);
  font-family:var(--font-mono);
  font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--paper); background:var(--ink);
  padding:5px 10px;
}

.profile-hero-text{}
.profile-eyebrow{
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:var(--s-4);
  display:inline-flex; align-items:center; gap:10px;
}
.profile-eyebrow .dot{width:6px;height:6px;background:var(--signal);border-radius:50%}
.profile-hero h1{
  font-size: clamp(2.6rem, 5.5vw, 5.2rem);
  font-weight:400; line-height:0.95; letter-spacing:-.025em;
  margin-bottom:var(--s-5);
}
.profile-hero h1 .em{
  display:block;
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 80, "WONK" 1;
}
.profile-role{
  font-family:var(--font-display);
  font-weight:400;
  font-size: clamp(1.05rem, 1.6vw, 1.3rem);
  font-variation-settings:"opsz" 18,"SOFT" 50;
  color:var(--ink-soft);
  line-height:1.4;
  margin-bottom:var(--s-5);
  max-width:46ch;
}
.profile-role .signal{color:var(--signal); font-style:italic}
.profile-contact{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-top:var(--s-4);
}
.profile-contact a{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;
  border:1px solid var(--rule);
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft);
  transition:background .2s var(--t-fast), border-color .2s var(--t-fast), color .2s var(--t-fast);
}
.profile-contact a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.profile-contact svg{width:14px;height:14px}

@media(max-width:900px){
  .profile-hero-grid{grid-template-columns:1fr;gap:var(--s-5)}
}

/* POSITIONING -------------------------------------------------- */
.positioning{
  display:grid;
  grid-template-columns: 7fr 5fr;
  gap: var(--s-7);
  align-items:start;
}
.positioning .claim{
  font-family:var(--font-display);
  font-weight:400;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  font-variation-settings:"opsz" 36,"SOFT" 50;
  letter-spacing:-.015em;
  line-height:1.2;
  margin-bottom:var(--s-5);
  color:var(--ink);
  max-width:34ch;
}
.positioning .claim .signal{
  font-style:italic;
  color:var(--signal);
  font-variation-settings:"opsz" 36,"SOFT" 60,"WONK" 1;
}
.positioning p{font-size:var(--t-body);color:var(--ink-soft);max-width:54ch;line-height:1.65}

.quickfacts{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:1px; background:var(--rule); border:1px solid var(--rule);
  margin-top:var(--s-5);
}
.quickfact{
  background:var(--paper); padding:var(--s-4);
  display:flex;flex-direction:column;gap:4px;
}
.quickfact strong{
  font-family:var(--font-display); font-weight:500;
  font-size:1.1rem; color:var(--ink); letter-spacing:-.01em;
}
.quickfact span{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-muted);
}

.positioning-side h3{
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:var(--s-4); font-weight:600;
  display:flex; align-items:center; gap:10px;
}
.positioning-side h3::after{content:""; flex:1; height:1px; background:var(--rule)}

.core-list{list-style:none;padding:0;margin:0 0 var(--s-6);display:flex;flex-direction:column}
.core-list li{
  padding:var(--s-3) 0;
  border-bottom:1px solid var(--rule);
  font-size:var(--t-small); color:var(--ink-soft);
  display:flex;align-items:center;gap:12px;
}
.core-list li::before{
  content:""; width:5px;height:5px;background:var(--signal);
}

/* STATIONS (timeline) ----------------------------------------- */
.stations{
  display:flex;flex-direction:column;
  border-top:1px solid var(--rule);
  margin-bottom:var(--s-5);
}
.station{
  display:grid;
  grid-template-columns: 100px 1fr;
  gap:var(--s-4);
  padding:var(--s-4) 0;
  border-bottom:1px solid var(--rule);
  position:relative;
}
.station::before{
  content:""; position:absolute; top:24px; left:80px;
  width:6px;height:6px;background:var(--signal);
  transform:rotate(45deg);
}
.station-time{
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.1em;
  color:var(--ink); font-weight:600;
  padding-top:6px;
  font-feature-settings:"tnum";
}
.station-role{
  font-family:var(--font-display); font-weight:500;
  font-size:1rem; color:var(--ink); letter-spacing:-.005em;
  margin-bottom:2px;
}
.station-org{font-size:var(--t-small);color:var(--ink-muted);margin-bottom:6px}
.station-note{
  font-family:var(--font-display); font-weight:400; font-style:italic;
  font-variation-settings:"opsz" 14,"SOFT" 60;
  font-size:.92rem; color:var(--ink-soft); line-height:1.4;
  max-width:50ch;
}

@media(max-width:900px){
  .positioning{grid-template-columns:1fr;gap:var(--s-6)}
  .quickfacts{grid-template-columns:1fr 1fr}
  .station{grid-template-columns:1fr;gap:6px}
  .station::before{display:none}
}

/* MINDSET / WORKING APPROACH ---------------------------------- */
.mindset{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px; background:var(--rule); border:1px solid var(--rule);
}
.mindset-item{
  background:var(--paper);
  padding:var(--s-5) var(--s-4) var(--s-5);
  display:flex;flex-direction:column;
  position:relative;
  transition:background .25s var(--t-fast);
}
.mindset-item:hover{background:var(--paper-tint)}
.mindset-item .num{
  font-family:var(--font-mono);
  font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--signal); font-weight:600;
  margin-bottom:var(--s-4);
}
.mindset-item h3{
  font-family:var(--font-display); font-weight:500;
  font-size:1.05rem; letter-spacing:-.01em;
  margin-bottom:var(--s-3); line-height:1.2;
}
.mindset-item p{
  font-size:var(--t-small); color:var(--ink-muted); margin-bottom:0;
  line-height:1.55;
}

@media(max-width:900px){
  .mindset{grid-template-columns:repeat(2, 1fr)}
}
@media(max-width:560px){
  .mindset{grid-template-columns:1fr}
}

/* SERVICE BLOCKS (deeper view) -------------------------------- */
.service-blocks{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1px; background:var(--rule); border:1px solid var(--rule);
}
.service-block{
  background:var(--paper);
  padding:var(--s-6) var(--s-5);
  display:flex;flex-direction:column;
}
.service-block-num{
  font-family:var(--font-mono);
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint); margin-bottom:var(--s-3);
  display:flex;align-items:center;gap:8px;
}
.service-block-num::after{content:""; flex:1; height:1px; background:var(--rule)}
.service-block h3{
  font-family:var(--font-display); font-weight:500;
  font-size:1.2rem; letter-spacing:-.01em;
  margin-bottom:var(--s-4); line-height:1.2;
}
.service-block ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.service-block li{
  font-size:var(--t-small); color:var(--ink-soft);
  padding-left:18px; position:relative; line-height:1.55;
}
.service-block li::before{
  content:""; position:absolute; left:0; top:9px;
  width:8px; height:1px; background:var(--signal);
}

@media(max-width:900px){
  .service-blocks{grid-template-columns:1fr}
}

/* PROJECT TIMELINE (vertical hairline rail) -------------------- */
.projects{
  display:flex;flex-direction:column;
  border-top:1px solid var(--rule);
  position:relative;
}
.project{
  display:grid;
  grid-template-columns: 100px 180px 1fr;
  gap:var(--s-5);
  padding:var(--s-5) 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
  transition:background .2s var(--t-fast);
}
.project:hover{background:var(--paper-tint)}
.project-time{
  font-family:var(--font-mono);
  font-size:.78rem; letter-spacing:.08em; font-weight:600;
  color:var(--ink); padding-top:5px;
  font-feature-settings:"tnum";
}
.project-branch{
  font-family:var(--font-mono);
  font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-muted); padding-top:7px;
  display:block;
}
.project-role{
  display:none;
}
.project-content{}
.project-title{
  font-family:var(--font-display); font-weight:500;
  font-size:1.15rem; letter-spacing:-.01em;
  margin-bottom:6px; line-height:1.25;
}
.project-role-inline{
  font-family:var(--font-mono);
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--signal); font-weight:600; margin-bottom:8px;
  display:block;
}
.project-desc{font-size:var(--t-small); color:var(--ink-muted); line-height:1.6; margin-bottom:var(--s-3); max-width:60ch}
.project-tags{display:flex;flex-wrap:wrap;gap:6px}
.project-tags span{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.08em;
  padding:3px 8px; border:1px solid var(--rule);
  color:var(--ink-muted);
}

@media(max-width:1100px){
  .project{grid-template-columns: 90px 1fr;}
  .project-branch{grid-column:1/-1; padding-top:0; padding-left:0; margin-top:-8px; margin-bottom:8px}
}
@media(max-width:560px){
  .project{grid-template-columns:1fr; gap:8px}
}

/* BRANCH PILLS ------------------------------------------------- */
.branch-pills{
  display:flex;flex-wrap:wrap;gap:8px;
}
.branch-pills span{
  padding:8px 14px; border:1px solid var(--rule);
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft);
  transition:border-color .2s var(--t-fast), background .2s var(--t-fast);
}
.branch-pills span:hover{border-color:var(--ink); background:var(--paper-tint)}

/* TECH GRID --------------------------------------------------- */
.tech-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1px; background:var(--rule); border:1px solid var(--rule);
}
.tech-row{
  background:var(--paper);
  padding:var(--s-4) var(--s-4);
  display:grid; grid-template-columns: 180px 1fr 80px; gap:var(--s-4); align-items:center;
}
.tech-row strong{
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink); font-weight:600;
}
.tech-row > span{
  font-size:var(--t-small); color:var(--ink-muted); line-height:1.5;
}
.tech-row .level{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--font-mono); font-size:.7rem; color:var(--ink-muted);
  letter-spacing:.1em;
}
.tech-row .dots{display:inline-flex;gap:3px}
.tech-row .dots i{width:6px;height:6px;border:1px solid var(--ink);display:block}
.tech-row .dots i.on{background:var(--ink)}

@media(max-width:900px){
  .tech-grid{grid-template-columns:1fr}
  .tech-row{grid-template-columns: 1fr; gap:8px}
  .tech-row .level{grid-column:1/-1}
}

/* PULL-QUOTE BAND (between sections) -------------------------- */
.pullquote{
  padding-block: var(--s-9);
  background: var(--paper-tint);
  border-block:1px solid var(--rule);
}
.pullquote-inner{max-width:920px}
.pullquote-num{
  font-family:var(--font-mono);
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--signal); font-weight:600;
  margin-bottom:var(--s-4);
}
.pullquote q{
  font-family:var(--font-display);
  font-weight:300;
  font-size: clamp(1.5rem, 3.5vw, 2.6rem);
  letter-spacing:-.015em;
  line-height:1.2;
  color:var(--ink); display:block; quotes:none;
}
.pullquote q::before{content:open-quote}
.pullquote q::after{content:close-quote}
.pullquote .signal{color:var(--signal); font-style:italic}
.pullquote cite{
  font-family:var(--font-mono);
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-muted); font-style:normal;
  margin-top:var(--s-4);display:block;
}

/* CHOICE GRID (overview page) ---------------------------------- */
.choice-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px; background:var(--rule); border:1px solid var(--rule);
}
.choice-card{
  background:var(--paper);
  padding:var(--s-6) var(--s-5);
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  transition:background .25s var(--t-fast);
  position:relative;
}
.choice-card:hover{background:var(--paper-tint)}
.choice-num{
  font-family:var(--font-mono);
  font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--signal); font-weight:600;
  margin-bottom:var(--s-4);
}
.choice-portrait{
  width:96px;height:120px; margin-bottom:var(--s-4);
  background:var(--paper-tint); border:1px solid var(--rule);
  overflow:hidden; display:block;
}
.choice-portrait img{width:100%;height:100%;object-fit:cover;object-position:top;filter:contrast(1.05) saturate(.85)}
.choice-icon{
  width:96px;height:96px;
  margin-bottom:var(--s-4);
  border:1px solid var(--rule);
  display:flex;align-items:center;justify-content:center;
}
.choice-icon svg{width:48px;height:48px;color:var(--ink)}
.choice-card h3{font-family:var(--font-display);font-weight:500;font-size:1.4rem;letter-spacing:-.01em;margin-bottom:6px;line-height:1.1}
.choice-card .role{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-muted); margin-bottom:var(--s-4);
}
.choice-card p{font-size:var(--t-small);color:var(--ink-soft);flex:1;margin-bottom:var(--s-4);line-height:1.55}
.choice-card .cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink); font-weight:600;
  border-bottom:1px solid var(--ink); padding-bottom:2px; align-self:flex-start;
}
.choice-card:hover .cta{color:var(--signal); border-bottom-color:var(--signal)}

@media(max-width:900px){
  .choice-grid{grid-template-columns:1fr}
}
