
:root{
  --bg:#f5f2eb;
  --text:#171717;
  --muted:rgba(23,23,23,.58);
  --line:rgba(23,23,23,.10);
  --chip:rgba(23,23,23,.03);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg);
  color:var(--text);
}
body.lightbox-open{overflow:hidden}
.site-shell{max-width:1500px;margin:0 auto;padding:18px 18px 28px}
.top-section{display:flex;flex-direction:column;gap:18px;margin-bottom:48px}
.identity h1{margin:0;font-size:clamp(2.65rem, 5vw, 4.25rem);line-height:.98;letter-spacing:-0.055em;font-weight:700}
.identity p{margin:10px 0 0;text-transform:uppercase;letter-spacing:.22em;color:var(--muted);font-size:clamp(.78rem, 1.4vw, 1.02rem)}
.contact-links{display:flex;justify-content:flex-end;gap:12px}
.contact-links a{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:999px;background:var(--chip);color:rgba(23,23,23,.8);text-decoration:none;transition:transform .2s ease, background .2s ease, color .2s ease}
.contact-links a:hover{transform:translateY(-1px);background:rgba(23,23,23,.06);color:var(--text)}
.contact-links svg{width:17px;height:17px}
.portfolio-row{margin-bottom:34px}
.portfolio-row h2{margin:0 0 14px;font-size:1.08rem;font-weight:600;letter-spacing:.11em;color:rgba(23,23,23,.72)}
.carousel{overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:pan-x;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-bottom:10px}
.carousel.is-dragging{cursor:grabbing}
.track{display:flex;gap:16px;min-width:max-content}
.tile{flex:0 0 calc(50vw - 28px);max-width:calc(50vw - 28px);aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line);border-radius:22px;background:var(--chip);cursor:zoom-in}
.tile img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .28s ease;pointer-events:none}
.tile:hover img{transform:scale(1.03)}

.lightbox{position:fixed;inset:0;display:none;background:rgba(0,0,0,.88);z-index:999}
.lightbox.is-open{display:block}
.lightbox-viewport{width:100%;height:100%;overflow:hidden}
.lightbox-track{display:flex;height:100%;will-change:transform}
.lightbox-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:16px 12px}
.lightbox-slide img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.35);user-select:none;-webkit-user-drag:none}
.lightbox-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border:none;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;font-size:32px;line-height:1;cursor:pointer;z-index:20}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border:none;border-radius:999px;background:rgba(0,0,0,.44);color:#fff;font-size:40px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:20;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.24)}
.lightbox-nav:hover{background:rgba(255,255,255,.18)}
.lightbox-nav.prev{left:18px}
.lightbox-nav.next{right:18px}
.lightbox-swipe-hint{display:none;position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:20;border-radius:999px;background:rgba(0,0,0,.35);color:rgba(255,255,255,.85);padding:7px 12px;font-size:11px;letter-spacing:.18em;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}

@media (min-width:700px){
  .site-shell{padding:22px 30px 34px}
  .top-section{flex-direction:row;align-items:center;justify-content:space-between;gap:24px}
  .tile{flex-basis:calc(33.333vw - 34px);max-width:calc(33.333vw - 34px)}
}
@media (min-width:1024px){
  .site-shell{padding:24px 44px 42px}
  .tile{flex-basis:calc(25vw - 52px);max-width:calc(25vw - 52px)}
}
@media (min-width:1340px){
  .tile{flex-basis:calc((100vw - 88px - (100vw - min(1500px, 100vw))) / 5 - 13px);max-width:calc((100vw - 88px - (100vw - min(1500px, 100vw))) / 5 - 13px)}
}
@media (hover:none) and (pointer:coarse){
  .carousel{cursor:auto}
  .lightbox-nav{display:none}
  .lightbox-swipe-hint{display:block}
}
