:root{
  --bg:#f8f9fa;
  --surface:#ffffff;
  --surface-low:#f3f4f5;
  --surface-mid:#edeeef;
  --text:#191c1d;
  --muted:#5c6170;
  --accent:#3525cd;
  --accent-2:#4f46e5;
  --secondary:#b4136d;
  --primary-fixed:#e2dfff;
  --border:rgba(119,117,135,.16);
  --shadow:0 32px 64px -12px rgba(53,37,205,.08);
  --radius-xl:32px;
  --radius-lg:24px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Inter",sans-serif;
  line-height:1.6;
  overflow-x:hidden;
  position:relative;
  isolation:isolate;
  perspective:1100px;
}

body::before,
body::after{
  content:"";
  position:fixed;
  inset:auto;
  pointer-events:none;
  z-index:0;
  filter:blur(42px);
  opacity:.58;
  border-radius:999px;
  transform-style:preserve-3d;
  will-change:transform, opacity;
}

body.has-vanta::before,
body.has-vanta::after{
  display:none;
}

#vanta-bg{
  position:fixed;
  inset:0;
  z-index:0;
}

body::before{
  width:38vw;
  height:38vw;
  min-width:240px;
  min-height:240px;
  left:-10vw;
  top:12vh;
  background:radial-gradient(circle at 30% 30%, rgba(79,70,229,.55), rgba(79,70,229,0));
  animation:bgDriftA 18s ease-in-out infinite alternate, bgPulse 8s ease-in-out infinite;
}

body::after{
  width:34vw;
  height:34vw;
  min-width:220px;
  min-height:220px;
  right:-8vw;
  bottom:8vh;
  background:radial-gradient(circle at 60% 60%, rgba(180,19,109,.42), rgba(180,19,109,0));
  animation:bgDriftB 22s ease-in-out infinite alternate, bgPulse 10s ease-in-out infinite reverse;
}

.nav,
main,
footer{
  position:relative;
  z-index:1;
}

body.work-page::after{
  background:radial-gradient(circle at 60% 60%, rgba(53,37,205,.46), rgba(53,37,205,0));
}

body.skills-page::before{
  background:radial-gradient(circle at 30% 30%, rgba(53,37,205,.5), rgba(53,37,205,0));
}

body.contact-page::after{
  background:radial-gradient(circle at 60% 60%, rgba(79,70,229,.44), rgba(79,70,229,0));
}

body:not(.loaded) .nav-inner,
body:not(.loaded) .hero-copy,
body:not(.loaded) .hero-visual{
  opacity:0;
  transform:translateY(14px);
}

body.loaded .nav-inner,
body.loaded .hero-copy,
body.loaded .hero-visual{
  opacity:1;
  transform:none;
  transition:opacity .55s ease, transform .55s ease;
}

body.loaded .hero-copy{transition-delay:.06s}
body.loaded .hero-visual{transition-delay:.14s}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}

.container{
  width:min(1180px,calc(100% - 48px));
  margin:0 auto;
}

.nav{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(119,117,135,.08);
}

.nav-inner{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.brand,
.nav-links a,
.btn,
.hero-title,
.section-title,
.project-card h3,
.feature-card h3,
.info-card h3,
.footer-brand,
.skill-top b{
  font-family:"Plus Jakarta Sans",sans-serif;
}

.brand{
  color:var(--accent);
  font-weight:800;
  letter-spacing:-.04em;
  font-size:.98rem;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:22px;
}

.nav-links a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.84rem;
  font-weight:600;
  color:var(--muted);
  padding:6px 0;
  position:relative;
}

.nav-links a.active-link{
  color:var(--accent);
  border-bottom:none;
}

.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-2px;
  height:2px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .32s cubic-bezier(.22,.61,.36,1);
}

.nav-links a:hover::after{
  transform:scaleX(1);
}

.nav-links a.active-link::after{
  transform:scaleX(1);
}

.nav-actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:none;
  border-radius:14px;
  padding:12px 18px;
  background:var(--surface);
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.14);
  color:var(--text);
  font-size:.92rem;
  font-weight:700;
  cursor:pointer;
  transition:transform .35s cubic-bezier(.22,.61,.36,1), box-shadow .35s cubic-bezier(.22,.61,.36,1), opacity .22s ease;
}

.btn:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}

.btn.primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;
  box-shadow:none;
}

.btn.icon{
  display:none;
}

.btn-icon{
  font-size:.88em;
}

.hero{
  position:relative;
  overflow:hidden;
  padding:66px 0 96px;
}

.hero-orb{
  position:absolute;
  border-radius:999px;
  filter:blur(70px);
  opacity:.7;
  pointer-events:none;
}

.hero-orb-left{
  width:300px;
  height:300px;
  background:#dbe7ff;
  left:-120px;
  top:180px;
  animation:floatSlow 8s ease-in-out infinite;
}

.hero-orb-right{
  width:260px;
  height:260px;
  background:#efe1ff;
  right:-100px;
  top:40px;
  animation:floatSlow 9s ease-in-out infinite reverse;
}

.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:64px;
  align-items:center;
  min-height:calc(100vh - 148px);
}

.eyebrow-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  border-radius:999px;
  background:var(--primary-fixed);
  color:var(--accent);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.eyebrow-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
}

.hero-kicker{
  margin:18px 0 10px;
  color:#f97316;
  font-size:.9rem;
  font-weight:700;
}

.hero-title{
  margin:0;
  font-size:clamp(3.6rem,7vw,5.6rem);
  line-height:.88;
  letter-spacing:-.07em;
  font-weight:800;
  max-width:520px;
}

.hero-line{
  display:block;
}

.hero-line-dark{
  color:var(--text);
}

.hero-line-mixed{
  display:flex;
  align-items:baseline;
  gap:8px;
}

.hero-line-mixed em{
  color:var(--accent-2);
  font-style:italic;
}

.hero-line-mixed span{
  color:var(--text);
}

.hero-lead{
  max-width:360px;
  margin:16px 0 0;
  color:var(--muted);
  font-size:1rem;
  line-height:1.65;
}

.hero-location{
  margin:8px 0 0;
  color:var(--accent);
  font-size:.84rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin:30px 0 18px;
}

.hero-social{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  margin-top:2px;
}

.hero-social-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--muted);
  font-size:.82rem;
  font-weight:600;
}

.hero-social-link i{
  color:var(--accent);
}

.hero-social-link:hover{
  color:var(--accent);
}

.hero-visual{
  position:relative;
  transition:transform .45s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}

.portrait-card{
  width:min(100%,510px);
  margin-left:auto;
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#222;
}

.portrait-card img{
  width:100%;
  height:520px;
  object-fit:cover;
  filter:grayscale(1);
}

.floating-badge{
  position:absolute;
  right:-8px;
  bottom:22px;
  display:flex;
  align-items:center;
  gap:12px;
  background:rgba(255,255,255,.95);
  border-radius:18px;
  padding:10px 12px;
  box-shadow:var(--shadow);
  animation:badgeBob 3.2s ease-in-out infinite;
  will-change:transform;
}

.badge-icon{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
}

.badge-icon img{
  width:24px;
  height:24px;
  object-fit:contain;
}

.floating-badge small{
  display:block;
  color:var(--muted);
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.floating-badge strong{
  display:block;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:.92rem;
}

.section{
  padding:74px 0;
}

.section-soft{
  background:var(--surface-low);
}

.section-row{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:24px;
  margin-bottom:18px;
}

.home-work-preview .section-title{
  position:relative;
  display:inline-block;
}

.home-work-preview .section-title::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:100%;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2),transparent);
  transform:scaleX(0);
  transform-origin:left;
  animation:titleLineIn .9s cubic-bezier(.22,.61,.36,1) .3s forwards;
}

.section-label{
  margin:0 0 8px;
  color:var(--accent);
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.section-title{
  margin:0;
  font-size:clamp(2rem,4vw,3.4rem);
  letter-spacing:-.06em;
  line-height:1.02;
  font-weight:800;
}

.section-title.big{
  max-width:340px;
}

.section-title.small{
  font-size:1.75rem;
}

.section-copy{
  max-width:420px;
  margin:12px 0 0;
  color:var(--muted);
  font-size:.94rem;
}

.section-more{
  color:var(--accent);
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:700;
  font-size:.92rem;
  transition:transform .3s cubic-bezier(.22,.61,.36,1);
}

.section-more:hover{
  transform:translateX(4px);
}

.filter{
  display:flex;
  justify-content:center;
  margin:16px 0 28px;
}

.seg{
  display:inline-flex;
  gap:6px;
  padding:6px;
  border-radius:999px;
  background:var(--surface-low);
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.12);
}

.seg button{
  border:none;
  background:transparent;
  padding:9px 14px;
  border-radius:999px;
  font-weight:700;
  color:var(--muted);
  cursor:pointer;
}

.seg button.active{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;
}

.projects-bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:18px;
}

.card{
  background:var(--surface);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 8px 28px rgba(25,28,29,.05);
  transition:transform .45s cubic-bezier(.22,.61,.36,1), box-shadow .45s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
  position:relative;
}

.projects-bento .card::after{
  content:"";
  position:absolute;
  top:0;
  left:-130%;
  width:70%;
  height:100%;
  background:linear-gradient(105deg, transparent, rgba(255,255,255,.38), transparent);
  transform:skewX(-20deg);
  transition:left .6s cubic-bezier(.22,.61,.36,1);
  pointer-events:none;
}

.projects-bento .card:hover::after{
  left:150%;
}

.home-work-preview .projects-bento .card{
  animation:featuredFloat 5.6s ease-in-out infinite;
}

.home-work-preview .projects-bento .card:nth-child(2){animation-delay:.25s}
.home-work-preview .projects-bento .card:nth-child(3){animation-delay:.5s}
.home-work-preview .projects-bento .card:nth-child(4){animation-delay:.75s}
.home-work-preview .projects-bento .card:nth-child(5){animation-delay:1s}

.home-work-preview .projects-bento:hover .card{
  animation-play-state:paused;
}

.card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
}

.projects-bento .reveal:nth-child(1),
.work-grid .reveal:nth-child(1){transition-delay:.03s}
.projects-bento .reveal:nth-child(2),
.work-grid .reveal:nth-child(2){transition-delay:.08s}
.projects-bento .reveal:nth-child(3),
.work-grid .reveal:nth-child(3){transition-delay:.13s}
.projects-bento .reveal:nth-child(4),
.work-grid .reveal:nth-child(4){transition-delay:.18s}
.projects-bento .reveal:nth-child(5),
.work-grid .reveal:nth-child(5){transition-delay:.23s}

.feature-card{
  grid-column:span 8;
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:340px;
}

.feature-copy{
  padding:28px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.feature-card h3,
.project-card h3,
.info-card h3{
  margin:12px 0 10px;
  font-size:1.4rem;
  letter-spacing:-.04em;
}

.feature-card p,
.project-card p,
.info-card p{
  margin:0;
  color:var(--muted);
  font-size:.94rem;
}

.feature-image{
  width:100%;
  height:100%;
  object-fit:cover;
}

.project-card{
  grid-column:span 4;
}

.project-image{
  width:100%;
  height:220px;
  object-fit:cover;
}

.card-pad{
  padding:20px;
}

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

.tag{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  background:var(--primary-fixed);
  color:var(--accent);
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.linkbtn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:16px;
  color:var(--accent);
  font-size:.88rem;
  font-weight:700;
  transition:transform .3s cubic-bezier(.22,.61,.36,1), opacity .3s ease;
}

.linkbtn::after{
  content:"->";
  transition:transform .3s cubic-bezier(.22,.61,.36,1);
}

.linkbtn:hover{
  transform:translateX(2px);
}

.linkbtn:hover::after{
  transform:translateX(2px);
}

.split-section{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:24px;
  align-items:start;
}

.skill-icons{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  margin-top:26px;
  max-width:330px;
}

.mini-tile{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  padding:18px 16px;
  background:var(--surface);
  border-radius:18px;
  box-shadow:0 8px 24px rgba(25,28,29,.04);
}

.mini-emoji{
  font-size:1.3rem;
  line-height:1;
}

.mini-tile h3{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1rem;
  letter-spacing:-.02em;
}

.mini-tile p{
  margin:0;
  color:var(--muted);
  font-size:.86rem;
  line-height:1.5;
}

.skills-card{
  background:var(--surface);
  border-radius:var(--radius-xl);
  padding:26px;
  box-shadow:0 8px 24px rgba(25,28,29,.04);
}

.skills-columns{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px 26px;
}

.skill-row{
  margin-bottom:18px;
}

.skill-top{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}

.skill-top span{
  color:var(--accent);
  font-size:.82rem;
  font-weight:700;
}

.bar{
  height:7px;
  background:#e2e5f1;
  border-radius:999px;
  overflow:hidden;
}

.fill{
  height:100%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:999px;
}

.fill.accent-two{
  background:linear-gradient(90deg,var(--secondary),#ff7cb8);
}

.chip-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
  padding-top:14px;
  border-top:1px solid rgba(119,117,135,.14);
}

.dual-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
}

.info-heading{
  margin-bottom:14px;
}

.info-card{
  padding:22px;
}

.info-meta{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:var(--accent);
  font-size:.75rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.card-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:16px;
}

.doi{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:var(--primary-fixed);
  color:var(--accent);
  font-size:.76rem;
  font-weight:700;
}

.cta-panel{
  background:#241b73;
  color:#fff;
  border-radius:28px;
  padding:44px;
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:24px;
}

.cta-panel h2{
  margin:0;
  max-width:420px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1;
  letter-spacing:-.05em;
}

.cta-panel p{
  margin:14px 0 0;
  max-width:520px;
  color:#d7d8ff;
}

.cta-btn{
  background:#fff;
  color:#241b73;
  box-shadow:none;
}

.footer{
  padding:46px 0 46px;
}

.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
}

.footer-brand{
  font-weight:800;
  color:var(--accent);
  margin-bottom:6px;
  font-size:1rem;
}

.footer small{
  color:var(--muted);
  display:block;
  max-width:230px;
  line-height:1.5;
}

.footer-links{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}

.footer-links a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--muted);
  font-size:.88rem;
}

.modal-backdrop{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(25,28,29,.48);
  z-index:80;
}

.modal-backdrop.show{display:flex}

.modal{
  width:min(900px,100%);
  background:var(--surface);
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-bottom:1px solid rgba(119,117,135,.12);
}

.modal-body{
  padding:18px;
}

.modal-body iframe{
  width:100%;
  height:70vh;
  border:none;
  border-radius:18px;
}

.modal-placeholder p{
  margin:0;
  color:var(--muted);
}

.reveal{
  opacity:0;
  transform:translateY(32px) scale(.985);
  filter:blur(3px);
  transition:opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1), filter .8s cubic-bezier(.22,.61,.36,1);
}

.reveal.show{
  opacity:1;
  transform:none;
  filter:blur(0);
}

@keyframes floatSlow{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}

@keyframes badgeBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-5px)}
}

@keyframes bgDriftA{
  0%{transform:translate3d(0,0,0) translateZ(0) rotateX(0deg) rotateY(0deg) scale(1)}
  25%{transform:translate3d(2vw,-1.5vh,0) translateZ(24px) rotateX(5deg) rotateY(-6deg) scale(1.04)}
  50%{transform:translate3d(4vw,-2vh,0) translateZ(38px) rotateX(8deg) rotateY(-10deg) scale(1.08)}
  75%{transform:translate3d(6vw,1vh,0) translateZ(18px) rotateX(4deg) rotateY(-5deg) scale(1.04)}
  100%{transform:translate3d(8vw,2vh,0) translateZ(0) rotateX(0deg) rotateY(0deg) scale(1)}
}

@keyframes bgDriftB{
  0%{transform:translate3d(0,0,0) translateZ(0) rotateX(0deg) rotateY(0deg) scale(1)}
  25%{transform:translate3d(-2vw,2vh,0) translateZ(18px) rotateX(-4deg) rotateY(5deg) scale(1.03)}
  50%{transform:translate3d(-5vw,3vh,0) translateZ(34px) rotateX(-7deg) rotateY(9deg) scale(1.06)}
  75%{transform:translate3d(-7vw,0vh,0) translateZ(14px) rotateX(-3deg) rotateY(4deg) scale(1.03)}
  100%{transform:translate3d(-9vw,-2vh,0) translateZ(0) rotateX(0deg) rotateY(0deg) scale(1)}
}

@keyframes bgPulse{
  0%,100%{opacity:.54}
  50%{opacity:.7}
}

@keyframes titleLineIn{
  from{transform:scaleX(0)}
  to{transform:scaleX(1)}
}

@keyframes featuredFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
}

.contact-page{
  background:#fbfbfd;
}

.contact-main{
  min-height:calc(100vh - 76px);
}

.contact-hero{
  padding:56px 0 48px;
}

.contact-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 16px;
  border-radius:999px;
  background:rgba(79,70,229,.14);
  color:var(--accent);
  font-size:.86rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.contact-title{
  margin:30px 0 18px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(3.6rem,8vw,6.6rem);
  line-height:.92;
  letter-spacing:-.08em;
  font-weight:800;
}

.contact-title span{
  color:#3a32e6;
  font-style:italic;
}

.contact-intro{
  max-width:760px;
  margin:0;
  color:#35384a;
  font-size:1.1rem;
  line-height:1.65;
}

.contact-layout-section{
  padding:28px 0 96px;
}

.contact-layout{
  display:grid;
  grid-template-columns:360px minmax(0,1fr);
  gap:56px;
  align-items:start;
}

.sidebar-title{
  margin:0 0 18px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.1rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.contact-links{
  display:grid;
  gap:18px;
}

.contact-link-card{
  display:grid;
  grid-template-columns:52px 1fr 22px;
  align-items:center;
  gap:16px;
  padding:20px 18px;
  background:#fff;
  border-radius:18px;
  box-shadow:0 10px 34px rgba(23,24,39,.05);
}

.contact-link-icon{
  width:44px;
  height:44px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1rem;
  font-weight:800;
}

.contact-link-icon i{
  font-size:1rem;
}

.contact-link-icon.lavender{
  background:#dcd8ff;
  color:#3d33df;
}

.contact-link-icon.pink{
  background:#ffd9e4;
  color:#c41f72;
}

.contact-link-icon.slate{
  background:#dae3f7;
  color:#445164;
}

.contact-link-copy strong{
  display:block;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.05rem;
}

.contact-link-copy span{
  display:block;
  color:var(--muted);
  font-size:.95rem;
}

.contact-link-arrow{
  color:#b8bad1;
  font-size:1.45rem;
  line-height:1;
}

.location-card{
  margin-top:52px;
  padding:28px;
  background:#f4f4f7;
  border-radius:20px;
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.06);
}

.location-card h3{
  margin:0 0 12px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.7rem;
  letter-spacing:-.04em;
}

.location-card p{
  margin:0 0 24px;
  color:#35384a;
  font-size:1rem;
}

.map-placeholder{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:10px;
  height:210px;
  padding:14px;
  border-radius:18px;
  color:#fff;
  text-decoration:none;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.26) 0 2px, transparent 2px 100%),
    repeating-radial-gradient(circle at center, rgba(255,255,255,.45) 0 2px, transparent 2px 24px),
    linear-gradient(115deg, transparent 0 18%, rgba(255,255,255,.58) 18% 19%, transparent 19% 38%, rgba(255,255,255,.5) 38% 39%, transparent 39% 58%, rgba(255,255,255,.54) 58% 59%, transparent 59% 100%),
    linear-gradient(145deg,#8f8fa2,#b7b7c3);
  background-color:#a7a7b4;
  overflow:hidden;
  transition:transform .3s cubic-bezier(.22,.61,.36,1), box-shadow .3s cubic-bezier(.22,.61,.36,1);
}

.map-placeholder::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(34,37,47,.06), rgba(34,37,47,.35));
}

.map-pin,
.map-cta{
  position:relative;
  z-index:1;
}

.map-pin{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:fit-content;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(53,37,205,.9);
  font-size:.82rem;
  font-weight:700;
}

.map-cta{
  display:inline-flex;
  width:fit-content;
  padding:8px 12px;
  border-radius:10px;
  background:rgba(255,255,255,.9);
  color:#2c3242;
  font-size:.78rem;
  font-weight:700;
}

.map-placeholder:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 34px rgba(23,24,39,.16);
}

.contact-form-shell{
  background:#fff;
  border-radius:22px;
  box-shadow:0 18px 48px rgba(23,24,39,.08);
  padding:44px 52px 50px;
}

.contact-form{
  display:grid;
  gap:28px;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px 34px;
}

.field{
  display:grid;
  gap:12px;
}

.field label{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:.92rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.field input,
.field textarea{
  width:100%;
  border:none;
  border-radius:18px;
  background:#f3f3f6;
  color:var(--text);
  padding:18px 22px;
  font-size:1rem;
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.06);
  outline:none;
  transition:box-shadow .22s ease, background .22s ease;
}

.field input::placeholder,
.field textarea::placeholder{
  color:#b6b7cb;
}

.field input:focus,
.field textarea:focus{
  background:#f7f7fb;
  box-shadow:0 0 0 2px rgba(58,50,230,.16);
}

.field textarea{
  resize:none;
  min-height:194px;
}

.project-type-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.choice-chip input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.choice-chip span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:142px;
  padding:13px 22px;
  border-radius:999px;
  background:#fff;
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.18);
  color:#252839;
  transition:all .2s ease;
}

.choice-chip input:checked + span{
  background:rgba(79,70,229,.08);
  color:#3429df;
  box-shadow:inset 0 0 0 1.5px #3a32e6;
}

.contact-form-actions{
  padding-top:8px;
}

.contact-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  min-width:286px;
  border:none;
  border-radius:14px;
  padding:22px 30px;
  background:linear-gradient(90deg,#3429df,#5445e8);
  color:#fff;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1rem;
  font-weight:800;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease;
}

.contact-submit:hover{
  transform:translateY(-1px);
  box-shadow:0 20px 44px rgba(58,50,230,.25);
}

.notice{
  display:none;
  padding:14px 16px;
  border-radius:14px;
  background:#eef3ff;
  color:#2d399a;
  font-weight:600;
}

.notice.show{
  display:block;
}

.contact-footer{
  padding-top:56px;
  border-top:none;
}

.insights-page{
  background:#fbfbfd;
}

.insights-main{
  min-height:calc(100vh - 76px);
}

.insights-hero{
  padding:54px 0 34px;
}

.insights-kicker{
  margin:0 0 16px;
  color:var(--accent);
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.insights-title{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(3.3rem,7vw,5.5rem);
  line-height:.94;
  letter-spacing:-.08em;
  font-weight:800;
  max-width:520px;
}

.insights-title span{
  color:#4a41ec;
}

.insights-intro{
  max-width:640px;
  margin:22px 0 0;
  color:#35384a;
  font-size:1.08rem;
  line-height:1.7;
}

.insights-feature-section{
  padding:26px 0 64px;
}

.insights-feature-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) 306px;
  gap:20px;
  align-items:center;
}

.feature-article{
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 12px 34px rgba(23,24,39,.05);
}

.feature-article img{
  width:100%;
  height:246px;
  object-fit:cover;
}

.feature-article-body{
  padding:28px 30px 32px;
}

.feature-meta{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  color:#666b7f;
  font-size:.82rem;
}

.feature-article h2{
  margin:18px 0 14px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:2rem;
  line-height:1.05;
  letter-spacing:-.05em;
}

.feature-article p{
  max-width:520px;
  margin:0;
  color:#4c5063;
  font-size:1rem;
  line-height:1.7;
}

.feature-link{
  display:inline-flex;
  margin-top:28px;
  color:#3a32e6;
  font-weight:700;
  font-size:.95rem;
}

.platform-card{
  background:#f4f4f7;
  border-radius:16px;
  padding:26px 22px 20px;
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.06);
}

.platform-card h3{
  margin:0 0 12px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.5rem;
  letter-spacing:-.04em;
}

.platform-card p{
  margin:0 0 20px;
  color:#676c80;
  font-size:.94rem;
  line-height:1.65;
}

.platform-list{
  display:grid;
  gap:10px;
}

.platform-list a{
  display:block;
  background:#fff;
  border-radius:10px;
  padding:12px 14px;
  color:#202433;
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.08);
}

.recent-writing-section{
  padding:10px 0 72px;
}

.recent-writing-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  margin-bottom:26px;
}

.recent-writing-head h2{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:2.2rem;
  letter-spacing:-.06em;
}

.recent-writing-head a{
  color:#202433;
  font-size:.92rem;
}

.writing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.writing-card{
  background:#fff;
  border-radius:16px;
  padding:20px 20px 18px;
  min-height:212px;
  box-shadow:0 12px 34px rgba(23,24,39,.04);
}

.writing-card h3{
  margin:18px 0 12px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.25rem;
  line-height:1.18;
  letter-spacing:-.04em;
}

.writing-card p{
  margin:0;
  color:#585d71;
  font-size:.94rem;
  line-height:1.6;
}

.writing-foot{
  margin-top:34px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  color:#2a2f44;
}

.writing-foot small{
  color:#555a6e;
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.writing-foot span{
  color:#3a32e6;
  font-weight:800;
}

.newsletter-section{
  padding:8px 0 60px;
}

.newsletter-panel{
  background:linear-gradient(90deg,#3729df,#4a38ea);
  color:#fff;
  border-radius:10px;
  padding:48px 34px;
  text-align:center;
}

.newsletter-panel h2{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(2rem,4vw,3rem);
  letter-spacing:-.05em;
}

.newsletter-panel p{
  max-width:560px;
  margin:16px auto 0;
  color:#e6e3ff;
  line-height:1.7;
}

.newsletter-form{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:28px;
}

.newsletter-form input{
  width:min(100%, 300px);
  border:none;
  border-radius:10px;
  background:rgba(255,255,255,.12);
  color:#fff;
  padding:16px 16px;
  outline:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);
}

.newsletter-form input::placeholder{
  color:#d0cbff;
}

.newsletter-form button{
  border:none;
  border-radius:10px;
  background:#fff;
  color:#2f2be3;
  padding:16px 22px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:700;
  cursor:pointer;
}

.insights-footer{
  border-top:1px solid rgba(119,117,135,.1);
  padding-top:34px;
}

.home-main,
.work-main,
.skills-main{
  min-height:calc(100vh - 76px);
}

.work-hero,
.skills-hero{
  padding:56px 0 34px;
}

.work-hero-title,
.skills-hero-title{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(3rem,7vw,5.4rem);
  line-height:.95;
  letter-spacing:-.08em;
  font-weight:800;
}

.work-hero-copy{
  max-width:700px;
  margin:20px 0 0;
  color:#4f5366;
  font-size:1.05rem;
  line-height:1.7;
}

.work-grid-section{
  padding:18px 0 64px;
}

.work-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:20px;
}

.work-card{
  grid-column:span 4;
  background:#fff;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 12px 34px rgba(23,24,39,.05);
}

.work-card img{
  width:100%;
  height:240px;
  object-fit:cover;
}

.work-card-copy{
  padding:22px;
}

.work-card-copy h2,
.work-card-copy h3{
  margin:14px 0 10px;
  font-family:"Plus Jakarta Sans",sans-serif;
  letter-spacing:-.05em;
}

.work-card-copy h2{
  font-size:2rem;
}

.work-card-copy h3{
  font-size:1.3rem;
}

.work-card-copy p{
  margin:0;
  color:#53586c;
}

.work-card-large{
  grid-column:span 8;
  display:grid;
  grid-template-columns:1fr 1fr;
}

.work-card-large img{
  height:100%;
  min-height:320px;
}

.work-summary-section{
  padding:0 0 72px;
}

.work-summary-panel{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:34px;
  background:#f4f4f7;
  border-radius:22px;
}

.work-summary-panel h2{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:2rem;
  letter-spacing:-.05em;
}

.work-summary-panel p{
  max-width:620px;
  margin:12px 0 0;
  color:#565b70;
}

.skills-hero-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
}

.skills-badge-circle{
  width:78px;
  height:78px;
  border-radius:999px;
  display:grid;
  place-items:center;
  color:var(--accent);
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.8rem;
  font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(119,117,135,.18);
}

.skills-divider{
  height:1px;
  margin-top:24px;
  background:linear-gradient(90deg, rgba(53,37,205,.18), rgba(53,37,205,.5), transparent);
}

.skills-body-section{
  padding:20px 0 70px;
}

.skills-body-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) 360px;
  gap:28px;
  align-items:start;
}

.skills-panel-head{
  margin-bottom:20px;
}

.skills-panel-head h2{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:2rem;
  letter-spacing:-.05em;
}

.skills-bento-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}

.skill-card-large{
  background:#fff;
  border-radius:18px;
  padding:22px;
  box-shadow:0 12px 34px rgba(23,24,39,.04);
}

.skill-card-top{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
}

.skill-card-top span,
.skill-card-top b{
  font-family:"Plus Jakarta Sans",sans-serif;
}

.skill-card-top b{
  color:#575b70;
  font-size:.86rem;
}

.skill-card-large p{
  margin:14px 0 16px;
  color:#575b70;
  font-size:.94rem;
}

.skills-mini-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:18px;
}

.skills-mini-card{
  background:#f2f3f7;
  border-radius:14px;
  padding:18px 14px;
  text-align:center;
}

.skills-mini-card strong{
  display:block;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:.9rem;
}

.skills-mini-card span{
  display:block;
  margin-top:6px;
  color:#64697e;
  font-size:.82rem;
}

.skills-mini-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.soft-skill-list{
  display:grid;
  gap:14px;
}

.soft-skill-card{
  background:#f4f4f7;
  border-radius:16px;
  padding:18px;
}

.soft-skill-card h3{
  margin:0 0 8px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.1rem;
}

.soft-skill-card p{
  margin:0;
  color:#5d6277;
  font-size:.92rem;
}

.version-control-card{
  margin-top:18px;
  background:linear-gradient(135deg,#3525cd,#5e4af1);
  color:#fff;
  border-radius:20px;
  padding:24px;
}

.version-control-card h3{
  margin:0 0 10px;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.4rem;
}

.version-control-card p{
  margin:0;
  color:#e4e1ff;
}

.version-control-tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:16px;
}

.version-control-tags span{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.toolchain-section{
  padding:0 0 72px;
}

.toolchain-panel{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:28px;
  align-items:center;
  padding:36px;
  background:#f1f2f6;
  border-radius:28px;
}

.toolchain-copy h2{
  margin:0;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:2.4rem;
  line-height:1;
  letter-spacing:-.06em;
}

.toolchain-copy p{
  margin:18px 0 0;
  color:#575c70;
}

.toolchain-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.tool-logo-tile{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  aspect-ratio:1/1;
  border-radius:18px;
  background:#fff;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1rem;
  font-weight:700;
  box-shadow:0 10px 30px rgba(23,24,39,.05);
}

.tool-logo-tile img{
  width:44px;
  height:44px;
  object-fit:contain;
}

@media (max-width:980px){
  .hero-grid,
  .split-section,
  .dual-grid,
  .skills-columns,
  .feature-card{
    grid-template-columns:1fr;
  }

  .projects-bento{
    grid-template-columns:repeat(2,1fr);
  }

  .feature-card,
  .project-card{
    grid-column:span 2;
  }

  .section-row,
  .cta-panel,
  .footer-inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .contact-layout{
    grid-template-columns:1fr;
    gap:30px;
  }

  .insights-feature-grid,
  .writing-grid{
    grid-template-columns:1fr;
  }

  .work-grid,
  .skills-body-grid,
  .toolchain-panel{
    grid-template-columns:1fr;
  }

  .work-card,
  .work-card-large{
    grid-column:span 12;
  }

  .work-card-large{
    grid-template-columns:1fr;
  }

  .skills-bento-grid,
  .skills-mini-strip{
    grid-template-columns:1fr 1fr;
  }

  .location-card{
    margin-top:28px;
  }

  .contact-form-shell{
    padding:30px 24px;
  }

  .form-grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  .portrait-card{
    margin:0;
  }

  .work-card-copy h2{
    font-size:1.55rem;
  }

  .work-card-copy h3{
    font-size:1.2rem;
  }
}

@media (max-width:760px){
  .container{
    width:min(100% - 24px,1180px);
  }

  .nav-links{
    display:none;
    position:absolute;
    left:12px;
    right:12px;
    top:calc(100% + 10px);
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:10px;
    background:rgba(255,255,255,.96);
    border-radius:20px;
    box-shadow:var(--shadow);
  }

  .nav-links a{
    padding:10px 12px;
    border-radius:10px;
  }

  .nav-links a.active-link{
    border-bottom:none;
  }

  .nav-links.mobile{
    display:flex;
  }

  .btn.icon{
    display:inline-flex;
  }

  .nav-actions .btn.primary{
    display:none;
  }

  .hero{
    padding-top:26px;
  }

  .hero-grid{
    gap:28px;
    min-height:auto;
  }

  .work-hero-title,
  .skills-hero-title{
    font-size:clamp(2.3rem,10vw,3.5rem);
  }

  .work-hero-copy{
    font-size:.95rem;
  }

  .contact-title{
    font-size:clamp(2.8rem,14vw,4.8rem);
  }

  .contact-intro{
    font-size:1rem;
  }

  .contact-badge{
    font-size:.74rem;
  }

  .contact-link-card{
    grid-template-columns:44px 1fr 18px;
    padding:16px;
  }

  .insights-title{
    max-width:420px;
  }

  .feature-article img{
    height:210px;
  }

  .skills-hero-row,
  .work-summary-panel{
    flex-direction:column;
    align-items:flex-start;
  }

  .recent-writing-head{
    flex-direction:column;
    align-items:flex-start;
  }

  .contact-link-icon{
    width:38px;
    height:38px;
    font-size:.92rem;
  }

  .contact-submit{
    min-width:0;
    width:100%;
  }

  .project-type-row{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }

  .choice-chip span{
    min-width:0;
    width:100%;
  }

  .skills-mini-strip,
  .toolchain-grid{
    grid-template-columns:1fr 1fr;
  }

  .skills-mini-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .work-card img{
    height:220px;
  }

  .skills-body-section{
    padding:14px 0 52px;
  }

  .skills-panel-head h2{
    font-size:1.55rem;
  }

  .skill-card-large{
    padding:16px;
  }

  .skill-card-top{
    align-items:flex-start;
  }

  .skill-card-top span{
    max-width:74%;
    line-height:1.2;
    font-size:.94rem;
  }

  .skill-card-top b{
    font-size:.8rem;
    white-space:nowrap;
  }

  .skill-card-large p{
    font-size:.88rem;
    line-height:1.5;
  }

  .skills-mini-card{
    padding:14px 10px;
  }

  .version-control-card{
    padding:18px;
  }

  .toolchain-panel{
    padding:22px;
  }

  .tool-logo-tile{
    aspect-ratio:auto;
    min-height:112px;
  }

  .work-card-copy{
    padding:18px;
  }

  .tag{
    font-size:.62rem;
    padding:6px 9px;
  }

  .skills-chip-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }

  .skills-chip-grid .tag{
    width:100%;
    text-align:center;
  }

  .portrait-card img{
    height:380px;
  }

  .floating-badge{
    right:12px;
    bottom:12px;
  }

  .projects-bento{
    grid-template-columns:1fr;
  }

  .feature-card,
  .project-card{
    grid-column:span 1;
  }

  .skill-icons{
    max-width:none;
  }

  .cta-panel{
    padding:28px;
  }

  .footer-inner{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:10px;
  }

  .footer-brand{
    display:none;
  }

  .footer-inner > div{
    display:flex;
    flex-direction:column;
    align-items:center;
  }

  .footer small{
    max-width:none;
    text-align:center;
    margin:0;
  }

}

@media (max-width:560px){
  body::before,
  body::after{
    opacity:.42;
    filter:blur(36px);
  }

  .hero-title{
    font-size:clamp(2.4rem,14vw,3.5rem);
    line-height:.94;
  }

  .section-title{
    font-size:clamp(1.6rem,9vw,2.3rem);
  }

  .hero-lead{
    max-width:none;
    font-size:.95rem;
  }

  .hero-actions{
    width:100%;
    max-width:360px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin:24px 0 14px;
  }

  .hero-actions .btn{
    width:100%;
    min-width:0;
    padding:11px 12px;
    border-radius:12px;
    font-size:.84rem;
  }

  .hero-actions .btn .btn-icon{
    display:none;
  }

  .work-card-copy h2{
    font-size:1.28rem;
  }

  .work-card-copy h3{
    font-size:1.05rem;
  }

  .work-card-copy p{
    font-size:.88rem;
    line-height:1.5;
  }

  .work-card img{
    height:205px;
  }

  .skills-bento-grid{
    grid-template-columns:1fr;
  }

  .skills-main .skills-mini-strip{
    grid-template-columns:1fr 1fr;
  }

  .toolchain-copy h2{
    font-size:clamp(1.6rem,9vw,2rem);
  }

  .contact-layout-section{
    padding:20px 0 64px;
  }

  .floating-badge{
    right:10px;
    bottom:10px;
    padding:8px 10px;
    gap:10px;
  }

  .projects-bento,
  .skills-mini-strip,
  .toolchain-grid{
    grid-template-columns:1fr;
  }

  .contact-form-shell{
    padding:22px 16px;
  }

  .contact-link-card{
    grid-template-columns:38px 1fr 14px;
    gap:12px;
    padding:14px;
  }

  .footer-links{
    gap:10px;
  }
}

@media (max-width:400px){
  .container{
    width:min(100% - 16px,1180px);
  }

  .nav-inner{
    min-height:66px;
  }

  .btn{
    padding:10px 14px;
    font-size:.86rem;
  }

  .hero-location{
    font-size:.74rem;
    letter-spacing:.04em;
  }

  .contact-title{
    font-size:clamp(2.2rem,13vw,3.3rem);
  }

  .contact-badge{
    letter-spacing:.08em;
    font-size:.68rem;
    padding:7px 12px;
  }

  .portrait-card img{
    height:320px;
  }

  .work-card-copy{
    padding:15px;
  }

  .skills-main .skills-mini-strip{
    grid-template-columns:1fr;
  }

  .tag{
    font-size:.6rem;
    padding:5px 8px;
  }

  .hero-actions{
    grid-template-columns:1fr;
    max-width:none;
  }
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}
