*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: #F9F8F4; color: #1A1A1A; font-family: 'Roboto Mono', monospace; font-size: 15px; overflow-x: hidden; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }
::selection { background: #1A1A1A; color: #F9F8F4; }

@keyframes lpFloat { 0%,100% { transform: translateY(0) rotate(-4deg); } 50% { transform: translateY(-16px) rotate(-1deg); } }
@keyframes lpFade { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

/* NAV */
.lp-nav {
  position: sticky; top: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  padding: 16px clamp(20px, 5vw, 56px);
  background: rgba(249, 248, 244, 0.82);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(26, 26, 26, 0.12);
}
.lp-nav-logo { display: flex; align-items: center; height: 24px; }
.lp-logo-img { height: 17px; width: auto; display: block; }
.lp-nav-links { display: flex; align-items: center; gap: clamp(14px, 2.4vw, 30px); }
.lp-nav-btn {
  position: relative; font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase; padding: 6px 0; font-weight: 500;
}
.lp-nav-indicator {
  position: absolute; left: 0; right: 0; bottom: -1px;
  height: 2px; background: #1A1A1A; display: none;
}
.lp-nav-btn.active .lp-nav-indicator { display: block; }
.lp-lang-switch {
  display: flex; align-items: center; gap: 7px;
  padding-left: clamp(6px, 1.4vw, 16px);
  border-left: 1px solid rgba(26, 26, 26, 0.16);
}
.lp-lang-btn { font-size: 11px; letter-spacing: .1em; font-weight: 400; opacity: .4; }
.lp-lang-btn.active { font-weight: 700; opacity: 1; }
.lp-lang-sep { opacity: .3; font-size: 11px; }

/* HERO */
.lp-hero {
  position: relative; min-height: calc(100vh - 58px);
  display: flex; align-items: center;
  padding: clamp(28px, 5vw, 60px) clamp(20px, 5vw, 56px); overflow: hidden;
}
.lp-hero-circle {
  position: absolute; right: clamp(-60px, 2vw, 40px); top: 50%; transform: translateY(-50%);
  width: clamp(280px, 42vw, 560px); height: clamp(280px, 42vw, 560px);
  border-radius: 50%; background: #BFD3D7; z-index: 0;
}
.lp-hero-doodle {
  position: absolute; right: clamp(40px, 12vw, 170px); top: 50%; transform: translateY(-52%); z-index: 1;
}
.lp-hero-doodle-img { width: clamp(200px, 28vw, 360px); height: auto; animation: lpFloat 8s ease-in-out infinite; }
.lp-hero-text { position: relative; z-index: 2; max-width: 60%; }
.lp-hero-greet { font-size: 12px; letter-spacing: .18em; text-transform: uppercase; opacity: .6; margin-bottom: 18px; }
.lp-hero-name {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 700;
  font-size: clamp(46px, 9vw, 140px); line-height: .94; letter-spacing: -.02em;
}
.lp-hero-blurb { max-width: 38ch; margin-top: 24px; font-size: 14px; line-height: 1.75; opacity: .8; }
.lp-hero-cta {
  margin-top: 30px; display: inline-flex; align-items: center; gap: 10px;
  background: #1A1A1A; color: #F9F8F4; padding: 14px 24px; border-radius: 40px;
  font-size: 12px; letter-spacing: .12em; text-transform: uppercase;
  transition: background .2s;
}
.lp-hero-cta:hover { background: #333; }

/* SHARED */
.lp-section-pad { padding: clamp(40px, 7vw, 90px) clamp(20px, 5vw, 56px) clamp(50px, 8vw, 100px); }
.lp-label-sm { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; opacity: .55; }
.lp-link-sm {
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 8px; transition: opacity .2s;
}
.lp-link-sm:hover { opacity: .6; }
.lp-page-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 700;
  font-size: clamp(44px, 8vw, 110px); line-height: .94; letter-spacing: -.02em;
}

/* SELECTED WORK STRIP */
.lp-strip-header {
  display: flex; justify-content: space-between; align-items: baseline; gap: 20px;
  border-bottom: 1px solid rgba(26, 26, 26, 0.16); padding-bottom: 16px; margin-bottom: 8px;
}
.lp-wrow {
  display: grid; grid-template-columns: 56px 1fr auto; align-items: center;
  gap: clamp(14px, 3vw, 40px); width: 100%; text-align: left;
  padding: clamp(20px, 3vw, 30px) 0; border-bottom: 1px solid rgba(26, 26, 26, 0.12);
  transition: padding-left .2s;
}
.lp-wrow:hover { padding-left: 14px; }
.lp-wrow-num { font-family: 'Roboto Mono'; font-size: 12px; opacity: .4; }
.lp-wrow-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 600;
  font-size: clamp(22px, 3.4vw, 40px); line-height: 1.02; letter-spacing: -.01em;
}
.lp-wrow-sub { font-size: 12px; opacity: .6; max-width: 54ch; line-height: 1.5; }
.lp-wrow-right { display: flex; align-items: center; gap: clamp(12px, 2vw, 28px); }
.lp-wtag {
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  border: 1px solid rgba(26, 26, 26, .25); border-radius: 30px; padding: 6px 12px; white-space: nowrap;
}

/* RECENT READS */
.lp-reads-section { padding: clamp(8px, 2vw, 24px) 0 clamp(50px, 8vw, 100px); }
.lp-reads-header {
  display: flex; justify-content: space-between; align-items: baseline; gap: 20px;
  border-bottom: 1px solid rgba(26, 26, 26, 0.16);
  padding: 0 clamp(20px, 5vw, 56px) 16px; margin-bottom: clamp(26px, 3vw, 40px);
}
.lp-reads-nav { display: flex; align-items: center; gap: 10px; }
.lp-reads-arrow {
  width: 38px; height: 38px; border-radius: 50%; border: 1px solid rgba(26, 26, 26, 0.28);
  display: flex; align-items: center; justify-content: center; font-size: 15px; transition: all .2s;
}
.lp-reads-arrow:hover { background: #1A1A1A; color: #F9F8F4; }
.lp-carousel {
  display: flex; gap: clamp(16px, 2vw, 26px); overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 4px clamp(20px, 5vw, 56px) 8px; -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.lp-carousel::-webkit-scrollbar { display: none; }
.lp-book-card { flex: 0 0 auto; width: clamp(170px, 22vw, 210px); scroll-snap-align: start; display: flex; flex-direction: column; gap: 14px; }
.lp-book-cover {
  aspect-ratio: 2/3; width: 100%;
  background: repeating-linear-gradient(45deg, #ECEAE2, #ECEAE2 9px, #F4F2EC 9px, #F4F2EC 18px);
  border: 1px solid rgba(26, 26, 26, 0.16); border-radius: 2px;
  display: flex; align-items: flex-end; padding: 14px;
}
.lp-book-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 700;
  font-size: clamp(15px, 1.6vw, 19px); line-height: 1.1; letter-spacing: -.01em;
}
.lp-book-author { font-size: 12px; letter-spacing: .04em; opacity: .7; }

/* WORK GRID */
.lp-work-header {
  display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap;
  border-bottom: 1px solid rgba(26, 26, 26, 0.16); padding-bottom: clamp(20px, 3vw, 34px);
}
.lp-work-intro { max-width: 42ch; font-size: 13px; line-height: 1.7; opacity: .78; }
.lp-work-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(min(420px, 100%), 1fr));
  gap: clamp(20px, 2.4vw, 32px); margin-top: clamp(28px, 4vw, 48px);
}
.lp-work-card { text-align: left; display: flex; flex-direction: column; gap: 18px; background: transparent; transition: transform .25s; }
.lp-work-card:hover { transform: translateY(-4px); }
.lp-work-cover {
  position: relative; aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center;
  overflow: hidden; border-radius: 2px;
}
.lp-work-cover-num {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 800;
  font-size: clamp(70px, 12vw, 150px); line-height: 1; opacity: .16;
}
.lp-work-cover-tag { position: absolute; left: 22px; bottom: 20px; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; }
.lp-work-cover-year { position: absolute; right: 20px; top: 18px; font-size: 11px; letter-spacing: .1em; }
.lp-work-cover-view {
  position: absolute; right: 20px; bottom: 18px; font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; display: inline-flex; align-items: center; gap: 7px;
  opacity: 0; transition: opacity .25s;
}
.lp-work-card:hover .lp-work-cover-view { opacity: 1; }
.lp-work-card-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 600;
  font-size: clamp(22px, 2.6vw, 30px); line-height: 1.05; letter-spacing: -.01em;
}
.lp-work-card-sub { font-size: 12.5px; line-height: 1.6; opacity: .65; max-width: 48ch; }

/* PROJECT DETAIL */
.lp-back-btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase; opacity: .65; transition: opacity .2s;
}
.lp-back-btn:hover { opacity: 1; }
.lp-project-header { padding: clamp(26px, 4vw, 48px) clamp(20px, 5vw, 56px) clamp(28px, 4vw, 44px); }
.lp-project-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 700;
  font-size: clamp(40px, 7.5vw, 104px); line-height: .96; letter-spacing: -.02em; max-width: 16ch;
}
.lp-project-subtitle { margin-top: 22px; font-size: clamp(15px, 1.8vw, 21px); line-height: 1.5; max-width: 54ch; opacity: .82; }
.lp-project-hero {
  position: relative; height: clamp(200px, 34vw, 460px);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.lp-project-hero-num {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 800;
  font-size: clamp(120px, 26vw, 360px); line-height: 1; opacity: .14;
}
.lp-project-meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 24px;
  padding: clamp(28px, 4vw, 48px) clamp(20px, 5vw, 56px);
  border-bottom: 1px solid rgba(26, 26, 26, 0.14);
}
.lp-meta-label { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; opacity: .45; margin-bottom: 9px; }
.lp-meta-val { font-size: 14px; }
.lp-meta-link { font-size: 14px; border-bottom: 1px solid #1A1A1A; display: inline-flex; align-items: center; gap: 6px; }
.lp-project-body {
  display: grid; grid-template-columns: 1fr; gap: clamp(36px, 5vw, 70px);
  padding: clamp(40px, 6vw, 80px) clamp(20px, 5vw, 56px); max-width: 1100px;
}
.lp-2col { display: grid; grid-template-columns: 140px 1fr; gap: clamp(16px, 3vw, 44px); }
.lp-body-label { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; opacity: .45; }
.lp-body-text { font-size: clamp(16px, 1.9vw, 22px); line-height: 1.6; }
.lp-project-img-placeholder {
  aspect-ratio: 16/9; width: 100%;
  background: repeating-linear-gradient(45deg, #ECEAE2, #ECEAE2 12px, #F4F2EC 12px, #F4F2EC 24px);
  border: 1px solid rgba(26, 26, 26, 0.14); display: flex; align-items: center; justify-content: center;
  border-radius: 2px;
}
.lp-bullet {
  display: flex; align-items: baseline; gap: 14px; padding: 15px 0;
  border-top: 1px solid rgba(26, 26, 26, 0.14); font-size: 16px;
}
.lp-bullet-dot { color: #9aa; font-size: 13px; }
.lp-next-project {
  display: block; width: 100%; text-align: left;
  background: #1A1A1A; color: #F9F8F4;
  padding: clamp(34px, 5vw, 64px) clamp(20px, 5vw, 56px); transition: background .2s;
}
.lp-next-project:hover { background: #262626; }
.lp-next-label { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; opacity: .6; }
.lp-next-row {
  display: flex; align-items: center; justify-content: space-between; gap: 24px; margin-top: 14px;
}
.lp-next-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 600;
  font-size: clamp(28px, 5vw, 64px); line-height: 1; letter-spacing: -.01em;
}
.lp-next-arrow { font-size: clamp(28px, 5vw, 56px); }

/* ABOUT */
.lp-about-top { align-items: start; border-bottom: 1px solid rgba(26, 26, 26, 0.16); padding-bottom: clamp(36px, 5vw, 64px); }
.lp-about-top.lp-2col { grid-template-columns: 1.15fr .85fr; gap: clamp(28px, 5vw, 64px); }
.lp-about-lead {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 700;
  font-size: clamp(34px, 5vw, 68px); line-height: 1.02; letter-spacing: -.015em;
}
.lp-about-body { margin-top: 26px; font-size: 14px; line-height: 1.8; max-width: 52ch; opacity: .82; }
.lp-about-portrait-wrap { position: relative; }
.lp-about-portrait {
  aspect-ratio: 4/5; width: 100%;
  background: repeating-linear-gradient(45deg, #ECEAE2, #ECEAE2 11px, #F4F2EC 11px, #F4F2EC 22px);
  border: 1px solid rgba(26, 26, 26, 0.16);
  display: flex; align-items: flex-end; justify-content: center; padding-bottom: 18px;
}
.lp-about-doodle { position: absolute; right: -14px; bottom: -22px; height: 96px; width: auto; transform: rotate(6deg); }
.lp-cv-section { margin-top: clamp(40px, 6vw, 72px); }
.lp-cv-section.lp-2col { grid-template-columns: 160px 1fr; gap: clamp(18px, 3vw, 48px); }
.lp-exp-item {
  display: grid; grid-template-columns: 130px 1fr; gap: clamp(14px, 2.4vw, 36px);
  padding: clamp(20px, 3vw, 30px) 0; border-top: 1px solid rgba(26, 26, 26, 0.16);
}
.lp-exp-period { font-size: 12px; letter-spacing: .06em; opacity: .55; white-space: nowrap; }
.lp-exp-role {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 600;
  font-size: clamp(20px, 2.4vw, 28px); line-height: 1.1;
}
.lp-exp-org { font-size: 12px; letter-spacing: .04em; opacity: .6; margin: 6px 0 12px; }
.lp-exp-desc { font-size: 13px; line-height: 1.7; max-width: 60ch; opacity: .82; }
.lp-edu-item {
  display: grid; grid-template-columns: 130px 1fr; gap: clamp(14px, 2.4vw, 36px);
  padding: 18px 0; border-top: 1px solid rgba(26, 26, 26, 0.16);
}
.lp-edu-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 600;
  font-size: clamp(18px, 2vw, 24px);
}
.lp-edu-org { font-size: 12px; opacity: .6; margin-top: 5px; }
.lp-tags { display: flex; flex-wrap: wrap; gap: 10px; align-content: flex-start; }
.lp-tag { font-size: 13px; border: 1px solid rgba(26, 26, 26, 0.22); border-radius: 30px; padding: 9px 16px; }
.lp-cert {
  position: relative; font-size: 13px; border: 1px solid rgba(26, 26, 26, 0.22);
  border-radius: 30px; padding: 9px 16px; cursor: default; transition: background .2s, color .2s;
}
.lp-cert:hover { background: #1A1A1A; color: #F9F8F4; }
.lp-cert-tip {
  position: absolute; left: 50%; bottom: calc(100% + 9px); transform: translateX(-50%);
  white-space: nowrap; background: #1A1A1A; color: #F9F8F4;
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  padding: 6px 11px; border-radius: 30px; opacity: 0; pointer-events: none; transition: opacity .2s; z-index: 5;
}
.lp-cert:hover .lp-cert-tip { opacity: 1; }
.lp-lang-item { padding: 14px 0; border-top: 1px solid rgba(26, 26, 26, 0.16); font-size: 15px; }

/* CONTACT */
.lp-contact-section {
  position: relative; min-height: calc(100vh - 58px);
  padding: clamp(36px, 6vw, 80px) clamp(20px, 5vw, 56px) clamp(40px, 6vw, 70px);
  display: flex; flex-direction: column; justify-content: space-between;
}
.lp-contact-title {
  font-family: 'Roboto Condensed', sans-serif; font-weight: 600;
  font-size: clamp(40px, 6vw, 84px); line-height: 1; letter-spacing: -.02em;
}
.lp-contact-lead { margin-top: 18px; font-size: 13px; letter-spacing: .02em; line-height: 1.6; max-width: 44ch; opacity: .6; }
.lp-contact-bottom {
  display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: end;
  margin-top: clamp(36px, 5vw, 56px);
}
.lp-contact-links { display: flex; flex-direction: column; max-width: 640px; width: 100%; }
.lp-clink {
  display: grid; grid-template-columns: 70px 1fr auto; gap: 16px; align-items: center;
  padding: 16px 0; border-top: 1px solid rgba(26, 26, 26, 0.18);
  font-size: clamp(13px, 1.5vw, 16px); transition: padding-left .2s;
}
.lp-clink:hover { padding-left: 10px; }
.lp-clink-last { border-bottom: 1px solid rgba(26, 26, 26, 0.18); }
.lp-clink-label { opacity: .45; letter-spacing: .1em; }
.lp-contact-doodle { height: clamp(120px, 16vw, 200px); width: auto; animation: lpFloat 7s ease-in-out infinite; }

/* FOOTER */
.lp-footer {
  display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap;
  padding: 18px clamp(20px, 5vw, 56px);
  border-top: 1px solid rgba(26, 26, 26, 0.14);
  font-size: 10px; letter-spacing: .16em; text-transform: uppercase; opacity: .7;
}
.lp-footer-top { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; transition: opacity .2s; }
.lp-footer-top:hover { opacity: .5; }

/* RESPONSIVE */
@media (max-width: 760px) {
  .lp-2col { grid-template-columns: 1fr !important; }
  .lp-exp-item { grid-template-columns: 1fr !important; gap: 8px !important; }
  .lp-edu-item { grid-template-columns: 1fr !important; gap: 8px !important; }
  .lp-about-top.lp-2col { grid-template-columns: 1fr !important; }
  .lp-cv-section.lp-2col { grid-template-columns: 1fr !important; }
  .lp-contact-bottom { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .lp-hero { min-height: auto !important; align-items: flex-start !important; padding-top: 96px !important; padding-bottom: 56px !important; }
  .lp-hero-circle { width: 240px !important; height: 240px !important; top: 70px !important; right: -80px !important; transform: none !important; }
  .lp-hero-doodle { top: 104px !important; right: 6px !important; transform: none !important; }
  .lp-hero-doodle-img { width: 130px !important; }
  .lp-hero-text { max-width: 100% !important; margin-top: 150px !important; }
  .lp-wrow { grid-template-columns: 32px 1fr auto !important; gap: 14px !important; }
  .lp-wtag { display: none !important; }
  .lp-clink { grid-template-columns: 46px 1fr auto !important; gap: 10px !important; }
  .lp-clink span:nth-child(2) { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
}
