:root{
  --bg: #ffffff;
  --text: #0b0b0b;
  --muted: #6b6b6b;
  --accent: #111111;
  --max-width: 1200px;
  --gap: 18px;
  --radius: 8px;
  --shadow: 0 8px 30px rgba(12,12,12,0.06);
  --transition: 260ms cubic-bezier(.2,.9,.3,1);
  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  --font-serif: "Playfair Display", serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  font-weight:400;
  font-size:16px;
}

.container{
  width:calc(100% - 32px);
  max-width:var(--max-width);
  margin:0 auto;
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,1);
  border-bottom:1px solid rgba(10,10,10,0.04);
}
.header-inner{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
}
.logo{
  font-family:var(--font-serif);
  font-size:20px;
  color:var(--accent);
  text-decoration:none;
  font-weight:700;
  letter-spacing:0.4px;
}
.nav a{
  color:var(--muted);
  text-decoration:none;
  margin-left:18px;
  font-weight:600;
}
.nav a:hover{color:var(--accent)}

/* Hero */
.hero{
  padding:64px 0;
  text-align:center;
}
.hero-inner{max-width:900px;margin:0 auto}
.hero-title{
  font-family:var(--font-serif);
  font-weight:700;
  font-size:54px;
  margin:0 0 8px;
  letter-spacing:0.4px;
}
.hero-sub{color:var(--muted); margin:0 0 20px; font-size:18px}
.btn{
  display:inline-block;
  background:var(--accent);
  color:white;
  padding:10px 18px;
  border-radius:999px;
  text-decoration:none;
  transition:transform var(--transition), box-shadow var(--transition);
  font-weight:600;
}
.btn:hover{transform:translateY(-3px); box-shadow:var(--shadow)}
.btn.ghost{background:transparent;color:var(--accent);border:1px solid rgba(10,10,10,0.06)}

/* Sections */
.section-title{font-family:var(--font-serif); font-size:28px; margin:28px 0 6px}
.section-sub{color:var(--muted); margin:0 0 18px}

/* Masonry gallery using CSS columns */
.masonry{
  column-count:3;
  column-gap:var(--gap);
  width:100%;
}
.masonry-item{
  display:inline-block;
  width:100%;
  margin:0 0 var(--gap);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:0 6px 20px rgba(10,10,10,0.03);
  transition: transform var(--transition);
}
.masonry-item img{
  display:block;
  width:100%;
  height:auto;
  /* vertical-align: middle; */
}
.masonry-item figcaption{
  font-size:13px;
  color:var(--muted);
  padding:10px 12px;
}

/* Hover/focus on images */
.masonry-item:hover{transform:translateY(-6px)}
.masonry-item:focus-within{outline:3px solid rgba(0,0,0,0.06)}

/* About */
.about-section{padding:36px 0}
.about-grid{
  display:block;
  grid-template-columns: 1fr min(320px,35%);
  gap:18px;
  align-items:start;
  align-content:start;
}
.about-text p{margin:0 0 12px;color:var(--muted);max-width:65ch}
/* simplified skills removed for minimal layout */
.about-photo img{display:block;width:60%;height:auto;max-width:80%;object-fit:cover;border-radius:8px}

/* Contact */
.contact-section{padding:36px 0}
.contact-form{max-width:720px}
.form-row{display:flex;flex-direction:column;margin-bottom:12px}
.form-row label{font-size:13px;color:var(--muted);margin-bottom:6px}
.form-row input,.form-row textarea{
  padding:12px;border-radius:8px;border:1px solid rgba(10,10,10,0.06);font-size:15px;
}
.form-actions{display:flex;gap:12px;align-items:center;margin-top:8px}
.form-msg{color:green;margin-top:10px}

/* Footer */
.site-footer{padding:18px 0;border-top:1px solid rgba(10,10,10,0.04);margin-top:30px}
.footer-inner{display:flex;justify-content:space-between;align-items:center}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,0.85);opacity:0;pointer-events:none;transition:opacity var(--transition);
}
.lightbox[aria-hidden="false"]{opacity:1;pointer-events:auto}
.lightbox-content{max-width:92vw;max-height:86vh;outline:none}
.lightbox-img{max-width:100%;max-height:80vh;display:block;margin:0 auto;border-radius:6px;box-shadow:var(--shadow)}
.lightbox-caption{color:#ddd;text-align:center;margin-top:12px;font-size:15px}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:fixed;background:transparent;border:0;color:#fff;font-size:28px;cursor:pointer;padding:10px;
}
.lightbox-close{right:18px;top:18px}
.lightbox-prev{left:16px;top:50%;transform:translateY(-50%)}
.lightbox-next{right:16px;top:50%;transform:translateY(-50%)}

/* Responsive */
@media (max-width:1000px){
  .masonry{column-count:2}
  .about-grid{grid-template-columns:1fr}
}
@media (max-width:600px){
  .hero-title{font-size:34px}
  .masonry{column-count:1}
  .header-inner{padding:10px 0}
  .nav a{margin-left:10px}
  .footer-inner{flex-direction:column;gap:10px}
}


.socials {
  gap: 18px;
}