/*
Theme Name: Shahab Shahid — Engineering Portfolio
Theme URI: https://example.com/
Author: Shahab Shahid
Author URI: https://www.linkedin.com/in/shahab-shahid-khokhar/
Description: Single-page hardware / EMC engineering portfolio. Dark instrument-panel aesthetic with custom SVG technical illustrations, a responsive mobile menu, and social-share metadata. Content is baked into the templates (front-page.php / template-parts/portfolio.php).
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: shahab-portfolio
*/

:root{
  --ink:#13171C;--ink-2:#191E24;--ink-3:#212830;
  --line:rgba(236,234,227,.10);--line-2:rgba(236,234,227,.18);
  --paper:#ECEAE3;--dim:#98A2AD;--dim-2:#7C8690;
  --amber:#E9A23B;--amber-soft:rgba(233,162,59,.14);
  --cyan:#56C9D4;--cyan-soft:rgba(86,201,212,.12);
  --maxw:1180px;--pad:clamp(1.2rem,5vw,3rem);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--paper);font-family:"Hanken Grotesk",system-ui,-apple-system,sans-serif;font-size:clamp(1rem,1.04vw,1.0625rem);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:44px 44px;opacity:.35;mask-image:radial-gradient(120% 80% at 50% 0%,#000 0%,transparent 75%);-webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000 0%,transparent 75%)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--amber);color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);position:relative;z-index:1}
.mono{font-family:"JetBrains Mono",monospace}
.eyebrow{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--amber);opacity:.7}
.section{padding-top:clamp(4.5rem,10vw,8rem);padding-bottom:clamp(4.5rem,10vw,8rem);position:relative;z-index:1}
.section.tight{padding-top:clamp(2.5rem,6vw,4rem)}
.section-head{margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.section-head h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.04;font-size:clamp(1.9rem,4.4vw,3.1rem);margin-top:.9rem}
.section-head p{color:var(--dim);max-width:60ch;margin-top:1rem}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem var(--pad);background:rgba(19,23,28,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(19,23,28,.9)}
.brand{display:flex;align-items:center;gap:.7rem;font-family:"JetBrains Mono",monospace;font-size:.82rem;letter-spacing:.04em}
.brand .chip{width:34px;height:34px;border:1px solid var(--line-2);border-radius:7px;display:grid;place-items:center;font-weight:600;color:var(--amber);background:linear-gradient(160deg,var(--ink-3),var(--ink-2));font-size:.8rem}
.brand b{color:var(--paper);font-weight:600}
.nav-links{display:flex;gap:1.5rem;align-items:center}
.nav-links a{font-family:"JetBrains Mono",monospace;font-size:.76rem;letter-spacing:.08em;color:var(--dim);text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--paper)}
.nav-right{display:flex;gap:.6rem;align-items:center}
.nav-cta{font-family:"JetBrains Mono",monospace;font-size:.74rem;letter-spacing:.06em;border:1px solid var(--line-2);padding:.55rem .9rem;border-radius:7px;color:var(--paper);transition:border-color .2s,color .2s,background .2s;white-space:nowrap}
.nav-cta:hover{border-color:var(--amber);color:var(--amber)}
.nav-cta.solid{background:var(--amber);color:#1a1206;border-color:var(--amber);font-weight:600}
.nav-cta.solid:hover{color:#1a1206;filter:brightness(1.05)}
@media(max-width:980px){.nav-links{display:none}}
@media(max-width:520px){.nav-cta:not(.solid){display:none}}

/* HERO */
.hero{position:relative;padding-top:clamp(8rem,16vh,11rem);padding-bottom:clamp(3rem,8vw,5rem);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero-status{display:flex;align-items:center;gap:.6rem;margin-bottom:1.6rem}
.dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 0 rgba(86,201,212,.5);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(86,201,212,.45)}70%{box-shadow:0 0 0 9px rgba(86,201,212,0)}100%{box-shadow:0 0 0 0 rgba(86,201,212,0)}}
.hero-status span{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.14em;color:var(--dim);text-transform:uppercase}
.hero h1{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(3rem,9.2vw,6.6rem);line-height:.92;letter-spacing:-.035em}
.hero h1 .l2{display:block;color:transparent;-webkit-text-stroke:1.3px var(--paper)}
.hero-role{font-family:"JetBrains Mono",monospace;font-size:clamp(.78rem,1.2vw,.92rem);letter-spacing:.04em;color:var(--amber);margin-top:1.4rem;line-height:1.6}
.hero-tag{color:var(--dim);max-width:48ch;margin-top:1.3rem;font-size:1.06rem}
.hero-tag b{color:var(--paper);font-weight:600}
.hero-stats{display:flex;gap:clamp(1.2rem,3vw,2.4rem);margin-top:2.2rem;flex-wrap:wrap}
.stat .n{font-family:"Bricolage Grotesque",sans-serif;font-size:1.9rem;font-weight:700;line-height:1}
.stat .n em{color:var(--amber);font-style:normal}
.stat .k{font-family:"JetBrains Mono",monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim-2);margin-top:.4rem}
.hero-actions{display:flex;gap:.9rem;margin-top:2.2rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:"JetBrains Mono",monospace;font-size:.8rem;letter-spacing:.04em;padding:.85rem 1.3rem;border-radius:9px;transition:.2s;cursor:pointer}
.btn-primary{background:var(--amber);color:#1a1206;font-weight:600}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px -10px rgba(233,162,59,.6)}
.btn-ghost{border:1px solid var(--line-2);color:var(--paper)}
.btn-ghost:hover{border-color:var(--paper);transform:translateY(-2px)}
.pmp-chip{margin-top:1.3rem}
.pmp-chip span{font-family:"JetBrains Mono",monospace;font-size:.72rem;background:var(--amber-soft);color:var(--amber);padding:.4rem .85rem;border-radius:9999px;letter-spacing:.04em}

.portrait{position:relative}
.portrait-frame{position:relative;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;background:var(--ink-2);box-shadow:0 30px 80px -30px rgba(0,0,0,.7)}
.portrait-frame img{width:100%;height:auto;filter:saturate(1.04) contrast(1.03) brightness(1.02)}
.portrait-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,23,28,0) 45%,rgba(19,23,28,.5) 100%),linear-gradient(120deg,rgba(233,162,59,.1),rgba(86,201,212,.05));pointer-events:none}
.portrait .tick{position:absolute;width:14px;height:14px;border:1px solid var(--amber);z-index:3}
.portrait .t1{top:-1px;left:-1px;border-right:0;border-bottom:0}
.portrait .t2{top:-1px;right:-1px;border-left:0;border-bottom:0}
.portrait .t3{bottom:-1px;left:-1px;border-right:0;border-top:0}
.portrait .t4{bottom:-1px;right:-1px;border-left:0;border-top:0}
.portrait-tag{position:absolute;left:14px;bottom:14px;z-index:4;font-family:"JetBrains Mono",monospace;font-size:.66rem;letter-spacing:.1em;color:var(--paper);background:rgba(19,23,28,.6);backdrop-filter:blur(4px);padding:.4rem .65rem;border-radius:6px;border:1px solid var(--line)}
.portrait-tag em{color:var(--cyan);font-style:normal}

.scope{position:relative;height:74px;margin-top:1.8rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.scope svg{position:absolute;top:0;left:0;height:100%;width:200%}
.scope .trace{animation:sweep 9s linear infinite}
@keyframes sweep{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.scope-label{position:absolute;left:0;top:6px;font-family:"JetBrains Mono",monospace;font-size:.6rem;letter-spacing:.18em;color:var(--dim-2);z-index:2}

/* capability band */
.band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.7rem var(--pad);position:relative;z-index:1}
.band-inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}
.band-inner .lab{font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-right:.6rem}
.cap{font-family:"JetBrains Mono",monospace;font-size:.74rem;color:var(--dim);border:1px solid var(--line);padding:.4rem .7rem;border-radius:20px;transition:.2s}
.cap:hover{border-color:var(--line-2);color:var(--paper)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.about-photo{position:relative;border:1px solid var(--line-2);border-radius:14px;overflow:hidden;background:var(--ink-2)}
.about-photo img{width:100%;filter:grayscale(.12) contrast(1.03)}
.about-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(86,201,212,.06),rgba(233,162,59,.08))}
.lead{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:clamp(1.15rem,2vw,1.4rem);line-height:1.4;letter-spacing:-.01em;color:var(--paper);margin:1.1rem 0 1.4rem}
.lead em{color:var(--amber);font-style:normal}
.about-body p{color:var(--dim);margin-bottom:1.1rem}
.about-body p b{color:var(--paper);font-weight:600}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:1.8rem}
.fact{background:var(--ink-2);padding:1rem 1.1rem}
.fact .k{font-family:"JetBrains Mono",monospace;font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;color:var(--dim-2)}
.fact .v{margin-top:.3rem;font-weight:600;font-size:.96rem}
.fact .v em{color:var(--cyan);font-style:normal}

/* IMPACT metrics */
.impact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.impact-cell{background:var(--ink-2);padding:1.7rem 1.5rem;transition:background .25s}
.impact-cell:hover{background:var(--ink-3)}
.impact-cell .n{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700;line-height:1;color:var(--amber)}
.impact-cell .k{font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.08em;color:var(--dim);margin-top:.55rem;text-transform:uppercase;line-height:1.5}
.impact-cell.ph .n{color:var(--dim-2);font-size:1.2rem}
.impact-cell.ph{border:1px dashed var(--line-2)}

/* edit placeholder marker */
.edit-tag{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:.55rem;letter-spacing:.12em;color:var(--cyan);border:1px solid var(--cyan-soft);padding:1px 5px;border-radius:4px;text-transform:uppercase;vertical-align:middle;margin-left:.4rem}

/* EXPERIENCE */
.timeline{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.exp{background:var(--ink-2);padding:clamp(1.4rem,3vw,2.1rem);display:grid;grid-template-columns:200px 1fr;gap:1.6rem;transition:background .25s}
.exp:hover{background:var(--ink-3)}
.exp .when{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.05em;color:var(--amber)}
.exp .where{color:var(--dim);font-size:.82rem;margin-top:.5rem}
.exp h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:1.25rem;letter-spacing:-.01em}
.exp .co{color:var(--cyan);font-family:"JetBrains Mono",monospace;font-size:.78rem;margin-top:.25rem;margin-bottom:.9rem}
.exp ul{list-style:none;display:grid;gap:.55rem}
.exp li{position:relative;padding-left:1.3rem;color:var(--dim);font-size:.95rem}
.exp li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;background:var(--amber);border-radius:1px;transform:rotate(45deg)}
.exp li.metric-ph{color:var(--dim-2);font-style:italic}
.exp li.metric-ph::before{background:var(--cyan)}
@media(max-width:680px){.exp{grid-template-columns:1fr;gap:.8rem}}

/* SKILLS */
.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.skill{background:var(--ink-2);padding:1.5rem 1.6rem;transition:background .25s}
.skill:hover{background:var(--ink-3)}
.skill .h{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem}
.skill .num{font-family:"JetBrains Mono",monospace;font-size:.66rem;color:var(--amber);letter-spacing:.1em}
.skill .h h3{font-family:"Bricolage Grotesque",sans-serif;font-size:1.08rem;font-weight:600}
.tags{display:flex;flex-wrap:wrap;gap:.5rem}
.tag{font-family:"JetBrains Mono",monospace;font-size:.72rem;color:var(--dim);background:var(--ink);border:1px solid var(--line);padding:.35rem .62rem;border-radius:6px;transition:.2s}
.skill:hover .tag{border-color:var(--line-2)}
.tag.key{color:var(--amber);border-color:var(--amber-soft)}
.sub-head{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);margin:2.6rem 0 1.2rem}
@media(max-width:680px){.skills-grid{grid-template-columns:1fr}}

/* TOOLS */
.tools{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.tool-group{background:var(--ink-2);padding:1.4rem 1.5rem;transition:background .25s}
.tool-group:hover{background:var(--ink-3)}
.tool-group h4{font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:.9rem}
.tool-note{font-family:"JetBrains Mono",monospace;font-size:.68rem;color:var(--dim-2);margin-top:1rem}

/* FEATURED PROJECTS (case studies) */
.feat{display:grid;gap:1.6rem}
.feat-card{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1fr 1.25fr}
.feat-card:nth-child(even){grid-template-columns:1.25fr 1fr}
.feat-card:nth-child(even) .feat-img{order:2}
.feat-img{position:relative;min-height:280px;background:var(--ink-3);border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;text-align:center;padding:1.4rem;overflow:hidden}
.feat-card:nth-child(even) .feat-img{border-right:0;border-left:1px solid var(--line)}
.feat-img.slot{background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(236,234,227,.02) 10px,rgba(236,234,227,.02) 20px)}
.feat-img .icn{opacity:.5}
.feat-img .slot-lab{font-family:"JetBrains Mono",monospace;font-size:.74rem;color:var(--paper)}
.feat-img .slot-hint{font-family:"JetBrains Mono",monospace;font-size:.66rem;color:var(--dim-2);max-width:24ch}
.feat-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feat-body{padding:clamp(1.6rem,3vw,2.2rem)}
.feat-body .cat{font-family:"JetBrains Mono",monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan)}
.feat-body h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:clamp(1.3rem,2.6vw,1.7rem);letter-spacing:-.01em;margin:.5rem 0 1.1rem}
.cs-row{display:grid;grid-template-columns:96px 1fr;gap:1rem;padding:.75rem 0;border-top:1px solid var(--line);align-items:start}
.cs-row .lab{font-family:"JetBrains Mono",monospace;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);padding-top:.15rem}
.cs-row .val{color:var(--dim);font-size:.93rem}
.cs-row .val b{color:var(--paper);font-weight:600}
.cs-row.result .val{color:var(--paper)}
.cs-row .val .ph-text{color:var(--dim-2);font-style:italic}
@media(max-width:760px){.feat-card,.feat-card:nth-child(even){grid-template-columns:1fr}.feat-card:nth-child(even) .feat-img{order:0;border-left:0;border-bottom:1px solid var(--line)}.feat-img{border-right:0;border-bottom:1px solid var(--line);min-height:200px}}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gslot{aspect-ratio:4/3;border:1px dashed var(--line-2);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;text-align:center;padding:1rem;background:var(--ink-2);position:relative;overflow:hidden;transition:.2s}
.gslot:hover{border-color:var(--amber);background:var(--ink-3)}
.gslot .icn{opacity:.45}
.gslot .lab{font-family:"JetBrains Mono",monospace;font-size:.74rem;color:var(--paper);letter-spacing:.04em}
.gslot .hint{font-family:"JetBrains Mono",monospace;font-size:.62rem;color:var(--dim-2)}
.gslot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:760px){.gallery{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.gallery{grid-template-columns:1fr}}

/* PATENT / RESEARCH */
.pr-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.card{background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:1.8rem;position:relative;overflow:hidden}
.card .badge{font-family:"JetBrains Mono",monospace;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);margin-bottom:1rem;display:inline-block}
.card .badge.live{color:var(--amber)}
.card h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:1.45rem;letter-spacing:-.01em;margin-bottom:.7rem}
.card p{color:var(--dim);font-size:.96rem}
.card .meta{display:flex;gap:1.4rem;margin-top:1.3rem;flex-wrap:wrap}
.card .meta div .k{font-family:"JetBrains Mono",monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim-2)}
.card .meta div .v{font-family:"JetBrains Mono",monospace;color:var(--amber);font-size:.9rem;margin-top:.25rem}
.card.patent::after{content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;border:1px solid var(--amber-soft);border-radius:50%}
@media(max-width:680px){.pr-grid{grid-template-columns:1fr}}

/* PUBLICATIONS */
.pubs{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.pub{background:var(--ink-2);padding:1.4rem 1.6rem;display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;align-items:center;transition:background .25s}
.pub:hover{background:var(--ink-3)}
.pub .yr{font-family:"JetBrains Mono",monospace;color:var(--amber);font-size:.86rem}
.pub .t{font-weight:500;line-height:1.4}
.pub .t small{display:block;color:var(--dim-2);font-family:"JetBrains Mono",monospace;font-size:.72rem;margin-top:.35rem;font-weight:400}
.pub .v{font-family:"JetBrains Mono",monospace;font-size:.66rem;letter-spacing:.1em;color:var(--cyan);text-transform:uppercase;white-space:nowrap}
@media(max-width:680px){.pub{grid-template-columns:auto 1fr;gap:.7rem 1rem}.pub .v{grid-column:2}}

/* PROJECTS GRID */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.proj{background:var(--ink-2);border:1px solid var(--line);border-radius:13px;padding:1.5rem;position:relative;transition:transform .25s,border-color .25s;overflow:hidden}
.proj:hover{transform:translateY(-4px);border-color:var(--line-2)}
.proj .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}
.proj .yr{font-family:"JetBrains Mono",monospace;font-size:.68rem;color:var(--dim-2)}
.proj .cat{font-family:"JetBrains Mono",monospace;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan)}
.proj h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:1.15rem;line-height:1.15;margin-bottom:.6rem;letter-spacing:-.01em}
.proj p{color:var(--dim);font-size:.88rem;line-height:1.55}
.proj .metric{margin-top:1rem;font-family:"JetBrains Mono",monospace;font-size:.72rem;color:var(--amber);border-top:1px dashed var(--line-2);padding-top:.8rem}
.proj-more{margin-top:1.4rem;color:var(--dim-2);font-family:"JetBrains Mono",monospace;font-size:.78rem}
@media(max-width:900px){.proj-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.proj-grid{grid-template-columns:1fr}}

/* TESTIMONIALS */
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.quote{background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:1.9rem;position:relative}
.quote.ph{border:1px dashed var(--line-2)}
.quote .mark{font-family:"Bricolage Grotesque",sans-serif;font-size:2.6rem;line-height:.6;color:var(--amber);opacity:.6}
.quote p{color:var(--paper);font-size:1rem;margin:.6rem 0 1.3rem;line-height:1.6}
.quote.ph p{color:var(--dim-2);font-style:italic}
.quote .by{font-family:"JetBrains Mono",monospace;font-size:.74rem;color:var(--cyan)}
.quote .by span{display:block;color:var(--dim-2);margin-top:.2rem}
@media(max-width:680px){.quotes{grid-template-columns:1fr}}

/* EDUCATION + AWARDS */
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.edu{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.edu-item{background:var(--ink-2);padding:1.4rem 1.5rem;transition:background .25s}
.edu-item:hover{background:var(--ink-3)}
.edu-item .deg{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:1.12rem}
.edu-item .sch{color:var(--cyan);font-family:"JetBrains Mono",monospace;font-size:.78rem;margin-top:.3rem}
.edu-item .yr{color:var(--dim-2);font-family:"JetBrains Mono",monospace;font-size:.72rem;margin-top:.5rem}
.edu-item .desc{color:var(--dim);font-size:.9rem;margin-top:.55rem}
.awards{list-style:none;display:grid;gap:.85rem}
.awards li{display:grid;grid-template-columns:auto 1fr;gap:.9rem;color:var(--dim);font-size:.93rem;align-items:start}
.awards li .y{font-family:"JetBrains Mono",monospace;color:var(--amber);font-size:.76rem;padding-top:.1rem}
.awards li b{color:var(--paper);font-weight:600}
@media(max-width:780px){.two-col{grid-template-columns:1fr}}

/* CONTACT */
.contact{position:relative;border-top:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.contact h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:clamp(2.2rem,5.5vw,4rem);letter-spacing:-.025em;line-height:1}
.contact h2 em{color:var(--amber);font-style:normal}
.contact p{color:var(--dim);margin-top:1.2rem;max-width:44ch}
.contact p strong{color:var(--paper)}
.contact-list{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.cl{background:var(--ink-2);padding:1.1rem 1.3rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .25s}
.cl:hover{background:var(--ink-3)}
.cl .k{font-family:"JetBrains Mono",monospace;font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--dim-2)}
.cl .v{font-weight:600;font-size:.95rem}
.cl:hover .v{color:var(--amber)}
.cl.ph .v{color:var(--dim-2);font-style:italic;font-weight:400}
@media(max-width:680px){.contact-grid{grid-template-columns:1fr}.cl{flex-direction:column;align-items:flex-start;gap:.3rem}}

footer{border-top:1px solid var(--line);padding:2rem var(--pad);position:relative;z-index:1}
.foot-inner{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-inner span{font-family:"JetBrains Mono",monospace;font-size:.72rem;color:var(--dim-2);letter-spacing:.06em}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:880px){.hero-grid{grid-template-columns:1fr}.portrait{max-width:360px;margin-top:1rem}.about-grid{grid-template-columns:1fr}.about-photo{max-width:360px}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}

/* custom slot artwork */
.feat-img .artwork,.gslot .artwork{position:absolute;inset:0;width:100%;height:100%;display:block}
.feat-img.has-art{padding:0}
.gslot.has-art{border-style:solid;border-color:var(--line);padding:0}
.art-tag{position:absolute;left:12px;bottom:12px;z-index:3;font-family:"JetBrains Mono",monospace;font-size:.6rem;letter-spacing:.12em;color:var(--paper);background:rgba(19,23,28,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:.32rem .55rem;border-radius:5px;border:1px solid var(--line);text-transform:uppercase}
.art-tag em{color:var(--cyan);font-style:normal}
/* mobile nav */
.nav-toggle{display:none;background:none;border:1px solid var(--line-2);border-radius:7px;width:40px;height:38px;cursor:pointer;align-items:center;justify-content:center;padding:0}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";width:18px;height:2px;background:var(--paper);display:block;transition:.25s}
.nav-toggle span{position:relative}
.nav-toggle span::before,.nav-toggle span::after{position:absolute;left:0}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
.nav.open .nav-toggle span{background:transparent}
.nav.open .nav-toggle span::before{top:0;transform:rotate(45deg)}
.nav.open .nav-toggle span::after{top:0;transform:rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;z-index:45;background:rgba(19,23,28,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:4.7rem var(--pad) 1.6rem;flex-direction:column;gap:0;transform:translateY(-10px);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.mobile-menu.open{display:flex;opacity:1;transform:none;pointer-events:auto}
.mobile-menu a{font-family:"JetBrains Mono",monospace;font-size:.88rem;letter-spacing:.06em;color:var(--paper);text-transform:uppercase;padding:.85rem .2rem;border-bottom:1px solid var(--line)}
.mobile-menu a:last-child{border-bottom:0;color:var(--amber)}
@media(max-width:980px){.nav-toggle{display:inline-flex}}
