
:root{--bg:#ffffff;--muted:#6b7280;--text:#0b1220;--accent:#111827;--frame:#f5f5f7;--maxw:1200px}
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.wrap{max-width:var(--maxw);margin:0 auto;padding:48px 28px}
header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:40px}
.brand{display:flex;gap:18px;align-items:center;text-decoration:none;color:inherit}
.logo{width:56px;height:56px;border-radius:6px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}
.identity h1{margin:0;font-family:'Playfair Display',serif;font-weight:700;letter-spacing:-0.02em;font-size:28px}
.identity p{margin:4px 0 0 0;color:var(--muted);font-size:14px}
.hero{display:flex;gap:32px;align-items:center;margin-bottom:56px;flex-wrap:wrap}
.hero .portrait{flex:0 0 140px;max-width:140px;border-radius:8px;overflow:hidden;box-shadow:0 14px 30px rgba(10,12,20,0.06);border:1px solid rgba(0,0,0,0.04);background:var(--frame)}
.hero .portrait img{width:100%;height:auto;display:block;object-fit:cover}
.hero .lead{max-width:66ch;color:var(--muted);font-size:16px;line-height:1.6}
.gallery{margin-top:26px}
.grid{display:grid;grid-template-columns: repeat(3, 1fr);gap:32px}
.frame{background:var(--frame);padding:18px;border-radius:8px;border:1px solid #efefef;box-shadow:0 8px 20px rgba(12,14,20,0.04);transition:transform .28s ease,box-shadow .28s}
.frame:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(12,14,20,0.08)}
.frame img{width:100%;height:420px;object-fit:cover;display:block;border-radius:4px;background:#ddd}
.caption{margin-top:12px;display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:14px}
@media (max-width:1000px){.grid{grid-template-columns:repeat(2,1fr)}.frame img{height:360px}}
@media (max-width:640px){.grid{grid-template-columns:1fr}.frame img{height:260px} .hero .portrait{max-width:120px}}
.lb{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(10,10,12,0.85);z-index:60;padding:20px}
.lb img{max-width:calc(100% - 120px);max-height:calc(100% - 120px);border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,0.6)}
.lb .close{position:absolute;right:26px;top:26px;color:#fff;font-size:22px;cursor:pointer}
.lb .attribution{font-size:12px;color:rgba(255,255,255,0.7);position:absolute;left:26px;bottom:26px}
.footer{text-align:center;padding:24px;margin-top:40px;color:var(--muted);border-top:1px solid #eee}


/* Fixed gallery image sizing for consistent alignment */
.frame img, .photo-card img { height: 340px; object-fit: cover; display: block; width: 100%; }
@media (max-width:1000px){ .frame img, .photo-card img { height: 300px; } }
@media (max-width:640px){ .frame img, .photo-card img { height: 220px; } }
