*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07050f;
  --bg2:#0d0a1a;
  --bg3:#111820;
  --surface:#1a1630;
  --border:rgba(180,120,255,0.12);
  --border2:rgba(180,120,255,0.28);
  --text:#ede8ff;
  --muted:#6b5f8a;
  --mid:#a090c0;
  --violet:#b478ff;
  --pink:#ff4faa;
  --gold:#ffd166;
  --green:#00e5a0;
  --white:#ffffff;
}
html{scroll-behavior:smooth}
body{font-family:'Space Mono',monospace;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none}

/* scanlines */
body::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.06) 2px,rgba(0,0,0,0.06) 4px);pointer-events:none;z-index:900}

/* cursor */
#cur{width:12px;height:12px;border:2px solid var(--violet);position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%) rotate(45deg);transition:all .2s;box-shadow:0 0 10px rgba(180,120,255,.4)}
#cur2{width:4px;height:4px;background:var(--pink);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);box-shadow:0 0 6px var(--pink)}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:600;padding:1.2rem 2.5rem;display:flex;justify-content:space-between;align-items:center;transition:background .3s,border-bottom .3s}
nav.scrolled{background:rgba(7,5,15,0.96);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.logo{font-family:'Unbounded',sans-serif;font-weight:900;font-size:.85rem;letter-spacing:.05em;color:var(--white);text-decoration:none}
.logo span{color:var(--violet)}
.nav-links{display:flex;gap:1.8rem;list-style:none}
.nav-links a{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--violet)}
.nav-badge{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;border:2px solid var(--pink);color:var(--pink);padding:.55rem 1.4rem;animation:blink 2.5s step-end infinite;text-decoration:none;transition:background .2s;font-weight:700}
.nav-badge:hover{background:var(--pink);color:var(--bg)}
@keyframes blink{50%{opacity:.4}}

/* HERO */
.hero{min-height:100vh;position:relative;overflow:hidden;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:7rem 3rem 4rem}
.hero-glow{position:absolute;width:700px;height:700px;background:radial-gradient(circle,rgba(180,120,255,.09) 0%,transparent 65%);top:-100px;right:-100px;pointer-events:none;animation:orb 7s ease-in-out infinite}
.hero-glow2{position:absolute;width:350px;height:350px;background:radial-gradient(circle,rgba(255,79,170,.06) 0%,transparent 65%);bottom:50px;left:50px;pointer-events:none;animation:orb 9s ease-in-out 2s infinite}
@keyframes orb{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}

.hero-inner{display:grid;grid-template-columns:1fr auto;gap:4rem;align-items:center;width:100%;position:relative;z-index:1}
.hero-pre{display:flex;align-items:center;gap:1rem;margin-bottom:1.8rem;opacity:0;animation:fadeUp .7s .1s forwards}
.pre-line{width:40px;height:1px;background:var(--violet)}
.pre-text{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--violet)}
.hero-name{font-family:'Unbounded',sans-serif;font-weight:900;font-size:clamp(2.8rem,6vw,5.5rem);line-height:.92;letter-spacing:-.02em;color:var(--white);opacity:0;animation:fadeUp .9s .25s forwards}
.hero-name .outline{-webkit-text-stroke:1.5px var(--violet);color:transparent;display:block}
.hero-title{margin-top:1.5rem;font-size:.78rem;letter-spacing:.1em;color:var(--mid);opacity:0;animation:fadeUp .9s .45s forwards;font-weight:700}
#typed-title{color:var(--pink);border-right:2px solid var(--pink);padding-right:4px;white-space:nowrap;font-size:1.1rem;font-weight:700}
.hero-desc{margin-top:1rem;max-width:44ch;font-size:.82rem;line-height:2.2;color:var(--muted);opacity:0;animation:fadeUp .9s .6s forwards}
.hero-btns{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .75s forwards}
.hero-meta-pills{margin-top:1.8rem;display:flex;flex-direction:column;gap:.5rem;opacity:0;animation:fadeUp .8s .9s forwards}
.meta-pill{font-size:.72rem;letter-spacing:.1em;color:var(--muted);display:flex;align-items:center;gap:.6rem}
.meta-pill::before{content:'';width:5px;height:5px;background:var(--violet);border-radius:50%;box-shadow:0 0 5px var(--violet);flex-shrink:0}

/* PROFILE PHOTO */
.hero-right{opacity:0;animation:fadeUp .9s .5s forwards}
.profile-frame{width:220px;height:270px;border:1px solid var(--border2);position:relative;overflow:hidden;background:var(--bg2);flex-shrink:0;}
.profile-frame::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--violet),var(--pink));z-index:2}
.profile-frame::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--pink),var(--violet));z-index:2}
.profile-img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;position:relative;z-index:1}
.profile-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;text-align:center;position:relative}
.profile-placeholder .ph-icon{font-size:2.5rem;opacity:.3}
.profile-placeholder .ph-text{font-size:.52rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);line-height:1.6}
.profile-placeholder .ph-btn{font-size:.5rem;letter-spacing:.15em;text-transform:uppercase;border:1px solid var(--border2);color:var(--violet);padding:.4rem .9rem;background:transparent;cursor:pointer;transition:all .2s;font-family:'Space Mono',monospace;margin-top:.5rem}
.profile-placeholder .ph-btn:hover{background:rgba(180,120,255,.1);border-color:var(--violet)}
#profileUpload{display:none}
.profile-corner{position:absolute;width:10px;height:10px;border-color:var(--violet);border-style:solid;opacity:.6;z-index:3}
.profile-corner.tl{top:8px;left:8px;border-width:1px 0 0 1px}
.profile-corner.tr{top:8px;right:8px;border-width:1px 1px 0 0}
.profile-corner.bl{bottom:8px;left:8px;border-width:0 0 1px 1px}
.profile-corner.br{bottom:8px;right:8px;border-width:0 1px 1px 0}
.profile-name-tag{margin-top:.8rem;text-align:center}
.profile-name-tag p{font-family:'Unbounded',sans-serif;font-weight:700;font-size:.65rem;color:var(--white);letter-spacing:.05em}
.profile-name-tag span{font-size:.52rem;letter-spacing:.12em;color:var(--violet)}

/* BUTTONS */
.btn{font-family:'Space Mono',monospace;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;padding:.85rem 1.6rem;text-decoration:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .25s}
.btn-v{background:var(--violet);color:var(--bg);font-weight:700}
.btn-v:hover{background:var(--pink);box-shadow:0 0 24px rgba(255,79,170,.4)}
.btn-o{border:1px solid var(--border2);color:var(--mid);background:transparent}
.btn-o:hover{border-color:var(--violet);color:var(--violet)}

/* STRIP */
.strip{overflow:hidden;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:.65rem 0}
.strip-track{display:flex;gap:2.5rem;white-space:nowrap;animation:strip 18s linear infinite}
.strip-track span{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.strip-track .d{color:var(--violet)}
@keyframes strip{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION */
.s{padding:6rem 3rem;border-bottom:1px solid var(--border);position:relative;z-index:1}
.sh{display:flex;align-items:center;gap:1.2rem;margin-bottom:3.5rem}
.sh-num{font-family:'Unbounded',sans-serif;font-size:.75rem;font-weight:900;color:var(--violet);letter-spacing:.1em}
.sh-title{font-family:'Unbounded',sans-serif;font-weight:700;font-size:clamp(1.3rem,3vw,2rem);color:var(--white)}
.sh-line{flex:1;height:1px;background:var(--border)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:start}
.about-big{font-family:'Unbounded',sans-serif;font-weight:700;font-size:clamp(.95rem,2vw,1.35rem);line-height:1.5;color:var(--white);margin-bottom:1.5rem}
.about-big em{color:var(--pink);font-style:normal}
.about-body p{font-size:.82rem;line-height:2.2;color:var(--muted);margin-bottom:.8rem}
.info-table{border:1px solid var(--border)}
.info-r{display:grid;grid-template-columns:1fr 1.2fr;border-bottom:1px solid var(--border)}
.info-r:last-child{border-bottom:none}
.info-k{padding:.85rem 1rem;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border-right:1px solid var(--border);background:var(--bg2)}
.info-v{padding:.85rem 1rem;font-size:.78rem;color:var(--text)}
.info-v a{color:var(--violet);text-decoration:none}
.badge-open{display:inline-block;font-size:.48rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(255,79,170,.1);border:1px solid rgba(255,79,170,.35);color:var(--pink);padding:.15rem .5rem}

/* SKILLS */
.sk-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1px;background:var(--border);border:1px solid var(--border)}
.sk-card{background:var(--bg2);padding:1.8rem;transition:background .2s;position:relative;overflow:hidden}
.sk-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--violet),var(--pink));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.sk-card:hover{background:var(--surface)}
.sk-card:hover::after{transform:scaleX(1)}
.sk-cat{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.sk-cat::before{content:'▸';color:var(--violet)}
.sk-tags{display:flex;flex-wrap:wrap;gap:.45rem}
.sk-tag{font-size:.72rem;border:1px solid var(--border2);color:var(--mid);padding:.3rem .7rem;transition:all .2s}
.sk-tag:hover{border-color:var(--violet);color:var(--violet);background:rgba(180,120,255,.07)}

/* PROJECTS */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.proj-card{background:var(--bg2);display:flex;flex-direction:column;transition:background .3s;position:relative;overflow:hidden}
.proj-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--violet),var(--pink));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.proj-card:hover{background:var(--surface)}
.proj-card:hover::before{transform:scaleX(1)}
.proj-head{padding:2rem 2rem 1.2rem;border-bottom:1px solid var(--border)}
.proj-top-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.7rem}
.proj-num{font-size:.65rem;letter-spacing:.2em;color:var(--muted)}
.proj-ico{font-size:1.4rem}
.proj-name{font-family:'Unbounded',sans-serif;font-weight:700;font-size:.82rem;color:var(--white);line-height:1.3;margin-bottom:.7rem}
.proj-pills{display:flex;flex-wrap:wrap;gap:.4rem}
.pill{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(180,120,255,.1);border:1px solid rgba(180,120,255,.25);color:var(--violet);padding:.18rem .5rem}
.proj-body{padding:1.5rem 2rem;flex:1;display:flex;flex-direction:column;gap:.9rem}
.proj-desc{font-size:.78rem;line-height:2;color:var(--muted)}
.proj-impact{font-size:.72rem;line-height:1.9;background:rgba(255,209,102,.05);border-left:2px solid var(--gold);padding:.7rem .9rem;color:var(--gold);margin-top:auto}
.proj-role-tag{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:1.2rem 2rem;border-top:1px solid var(--border)}
.proj-role-tag span{color:var(--pink)}

/* EDUCATION */
.edu-card{border:1px solid var(--border);display:grid;grid-template-columns:auto 1fr auto;overflow:hidden;transition:border-color .3s;margin-bottom:1px}
.edu-card:hover{border-color:var(--border2)}
.edu-accent{width:4px;background:linear-gradient(180deg,var(--violet),var(--pink))}
.edu-main{padding:3rem}
.edu-eyebrow{font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;color:var(--violet);margin-bottom:.8rem;display:flex;align-items:center;gap:.8rem}
.edu-eyebrow::before{content:'';width:25px;height:1px;background:var(--violet)}
.edu-deg{font-family:'Unbounded',sans-serif;font-weight:700;font-size:clamp(1rem,2.5vw,1.5rem);color:var(--white);margin-bottom:.4rem}
.edu-school{font-size:.82rem;letter-spacing:.1em;color:var(--violet);margin-bottom:.3rem}
.edu-detail{font-size:.75rem;color:var(--muted)}
.edu-yr{padding:3rem 3.5rem;border-left:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'Unbounded',sans-serif;font-weight:900;font-size:3rem;-webkit-text-stroke:1px rgba(180,120,255,.25);color:transparent}

/* RESUME & CERTIFICATES */
.docs-section{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.doc-card{background:var(--bg2);padding:2.5rem;display:flex;flex-direction:column;gap:1.5rem;transition:background .2s;position:relative;overflow:hidden}
.doc-card:hover{background:var(--surface)}
.doc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--violet),var(--pink));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.doc-card:hover::before{transform:scaleX(1)}
.doc-label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);display:flex;align-items:center;gap:.5rem}
.doc-label::before{content:'▸';color:var(--violet)}
.doc-title{font-family:'Unbounded',sans-serif;font-weight:700;font-size:.85rem;color:var(--white);line-height:1.3}
.doc-sub{font-size:.75rem;line-height:1.8;color:var(--muted)}
.doc-preview{width:100%;aspect-ratio:2/3;border:1px solid var(--border);background:var(--bg3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;overflow:hidden;position:relative;transition:border-color .2s}
.doc-preview:hover{border-color:var(--border2)}
.doc-preview img{width:100%;height:100%;object-fit:contain;display:none}
.doc-preview img.visible{display:block}
.dp-placeholder{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.dp-icon{font-size:2rem;opacity:.25}
.dp-text{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.6}
.doc-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.doc-btn{font-family:'Space Mono',monospace;font-size:.52rem;letter-spacing:.15em;text-transform:uppercase;padding:.65rem 1.2rem;border:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem}
.doc-btn-upload{background:transparent;border:1px solid var(--border2);color:var(--violet)}
.doc-btn-upload:hover{background:rgba(180,120,255,.1);border-color:var(--violet)}
.doc-btn-dl{background:var(--violet);color:var(--bg);font-weight:700;text-decoration:none}
.doc-btn-dl:hover{background:var(--pink);box-shadow:0 0 16px rgba(255,79,170,.35)}
input[type=file].hidden{display:none}

/* STRENGTHS */
.str-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.str-card{background:var(--bg2);padding:2.2rem 1.8rem;display:flex;flex-direction:column;gap:1rem;transition:background .2s}
.str-card:hover{background:var(--surface)}
.str-ico{font-size:1.6rem}
.str-name{font-family:'Unbounded',sans-serif;font-weight:700;font-size:.78rem;color:var(--white);line-height:1.3}
.str-desc{font-size:.75rem;line-height:1.9;color:var(--muted)}

/* CONTACT */
.ct-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--border)}
.ct-left{padding:4rem;border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.ct-left::after{content:'';position:absolute;bottom:-80px;right:-80px;width:320px;height:320px;background:radial-gradient(circle,rgba(180,120,255,.07) 0%,transparent 65%);pointer-events:none}
.ct-h{font-family:'Unbounded',sans-serif;font-weight:900;font-size:clamp(1.8rem,4vw,3.2rem);line-height:.95;color:var(--white);margin-bottom:1.2rem}
.ct-h em{-webkit-text-stroke:1px var(--pink);color:transparent;font-style:normal;display:block}
.ct-sub{font-size:.8rem;line-height:2;color:var(--muted);margin-bottom:2.5rem}
.ct-links{display:flex;flex-direction:column}
.ct-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);font-size:.8rem;transition:padding-left .2s,color .2s}
.ct-row:hover{padding-left:.6rem;color:var(--violet)}
.ct-row-in{display:flex;flex-direction:column;gap:.15rem}
.ct-type{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.ct-row:hover .ct-type{color:var(--violet)}
.ct-right{padding:4rem;background:var(--bg2);display:flex;flex-direction:column;justify-content:space-between}
.obj-lbl{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--violet);margin-bottom:1rem;display:flex;align-items:center;gap:1rem}
.obj-lbl::after{content:'';flex:1;height:1px;background:var(--border)}
.obj-text{font-size:.8rem;line-height:2.2;color:var(--muted)}
.final-note{font-size:.75rem;line-height:2;color:var(--muted);border-top:1px solid var(--border);padding-top:1.5rem;font-style:italic}
.final-note strong{color:var(--pink);font-style:normal}

/* FOOTER */
footer{padding:1.8rem 3rem;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}
footer p{font-size:.72rem;letter-spacing:.12em;color:var(--muted)}
.fdot{color:var(--violet)}

/* 3D SCROLL ANIMATIONS */
.reveal{
  opacity:0;
  transform:perspective(1200px) rotateX(30deg) translateY(80px) scale(0.95);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1);
  transform-origin:top center;
}
.reveal.visible{
  opacity:1;
  transform:perspective(1200px) rotateX(0deg) translateY(0) scale(1);
}
.reveal-left{
  opacity:0;
  transform:perspective(1200px) rotateY(40deg) translateX(-100px) scale(0.92);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1);
  transform-origin:left center;
}
.reveal-left.visible{
  opacity:1;
  transform:perspective(1200px) rotateY(0deg) translateX(0) scale(1);
}
.reveal-right{
  opacity:0;
  transform:perspective(1200px) rotateY(-40deg) translateX(100px) scale(0.92);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1);
  transform-origin:right center;
}
.reveal-right.visible{
  opacity:1;
  transform:perspective(1200px) rotateY(0deg) translateX(0) scale(1);
}
.reveal-scale{
  opacity:0;
  transform:perspective(1200px) scale(0.75) rotateX(20deg) rotateZ(-3deg);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1);
}
.reveal-scale.visible{
  opacity:1;
  transform:perspective(1200px) scale(1) rotateX(0deg) rotateZ(0deg);
}

/* stagger 3D flip-in */
.stagger>*{
  opacity:0;
  transform:perspective(900px) rotateX(35deg) rotateZ(-4deg) translateY(60px) scale(0.9);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);
  transform-origin:top center;
}
.stagger.visible>*:nth-child(1){opacity:1;transform:perspective(900px) rotateX(0) rotateZ(0) translateY(0) scale(1);transition-delay:.05s}
.stagger.visible>*:nth-child(2){opacity:1;transform:perspective(900px) rotateX(0) rotateZ(0) translateY(0) scale(1);transition-delay:.18s}
.stagger.visible>*:nth-child(3){opacity:1;transform:perspective(900px) rotateX(0) rotateZ(0) translateY(0) scale(1);transition-delay:.31s}
.stagger.visible>*:nth-child(4){opacity:1;transform:perspective(900px) rotateX(0) rotateZ(0) translateY(0) scale(1);transition-delay:.44s}
.stagger.visible>*:nth-child(5){opacity:1;transform:perspective(900px) rotateX(0) rotateZ(0) translateY(0) scale(1);transition-delay:.57s}
.stagger.visible>*:nth-child(6){opacity:1;transform:perspective(900px) rotateX(0) rotateZ(0) translateY(0) scale(1);transition-delay:.70s}

/* section hover tilt */
.sk-card,.proj-card,.str-card,.doc-card,.edu-card{
  transition:transform .4s cubic-bezier(.16,1,.3,1),background .2s,border-color .3s;
  transform-style:preserve-3d;
}
.sk-card:hover{transform:perspective(800px) rotateX(-6deg) rotateY(4deg) translateY(-6px) scale(1.02)}
.proj-card:hover{transform:perspective(800px) rotateX(-5deg) rotateY(3deg) translateY(-8px) scale(1.02)}
.str-card:hover{transform:perspective(800px) rotateX(-6deg) rotateY(4deg) translateY(-6px) scale(1.02)}
.doc-card:hover{transform:perspective(800px) rotateX(-4deg) rotateY(3deg) translateY(-5px) scale(1.01)}
.edu-card:hover{transform:perspective(800px) rotateX(-3deg) translateY(-4px) scale(1.01)}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* RESPONSIVE */
@media(max-width:1024px){
  .docs-section{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr 1fr}
  .str-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  nav{padding:1rem 1.5rem}
  .nav-links{display:none}
  .hero{padding:7rem 1.5rem 4rem}
  .hero-inner{grid-template-columns:1fr}
  .hero-right{order:-1;display:flex;flex-direction:column;align-items:center}
  .profile-frame{width:140px;height:175px}
  .about-grid{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:1fr}
  .docs-section{grid-template-columns:1fr}
  .str-grid{grid-template-columns:1fr 1fr}
  .ct-wrap{grid-template-columns:1fr}
  .ct-left{border-right:none;border-bottom:1px solid var(--border)}
  .edu-yr{padding:2rem;font-size:2rem}
  .s{padding:4rem 1.5rem}
  footer{flex-direction:column;gap:.5rem;text-align:center}
}
@media(max-width:480px){
  .str-grid{grid-template-columns:1fr}
  .hero-name{font-size:2.5rem}
}
