:root{--bg:#ffffff;--fg:#111111;--muted:#6b7280;--maxw:980px;--gap:18px;--font:'Inter','Helvetica Neue',Helvetica,Arial,ui-sans-serif,system-ui;--green:#63C7A5}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:var(--font);color:var(--fg);background:var(--bg);line-height:1.6}
a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}
.site-header{max-width:var(--maxw);margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:600}
.nav a{margin-left:16px}
.container{max-width:var(--maxw);margin:0 auto;padding:8px 16px}

/* Full-bleed hero video */
.hero{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;background:#000}
.hero .embed{position:relative;width:100%;padding-top:56.25%;background:#000}
.hero .embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Masonry columns */
.grid{column-count:3;column-gap:var(--gap)}
@media (max-width: 980px){.grid{column-count:2}}
@media (max-width: 640px){.grid{column-count:1}}
.tile{break-inside:avoid;margin:0 0 var(--gap);border-radius:6px;overflow:hidden;background:#f7f7f7}
.tile img,.tile video{width:100%;height:auto;display:block}
.tile video{background:#000}

/* Lightbox overlay with nav */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.94);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity .2s ease}
.lb.show{opacity:1}
.lb img{max-width:96vw;max-height:92vh}
.lb .zone{position:absolute;top:0;bottom:0;width:40%;cursor:pointer}
.lb .prev{left:0}
.lb .next{right:0}
.lb .close{position:absolute;top:14px;right:16px;font-size:28px;color:#fff;cursor:pointer;font-family:monospace}

/* Footer */
.site-footer{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:28px 16px;color:#555;border-top:1px solid #eee;margin-top:24px;text-align:center}
.site-footer a{color:inherit}

/* About page split */
.about-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:80vh}
.about-photo{width:100%;height:100%;object-fit:cover;display:block}
.about-panel{background:var(--green);color:#113;display:flex;align-items:center;justify-content:center;padding:32px}
.about-inner{max-width:520px;text-align:center}
.about-title{letter-spacing:0.3em;font-weight:800;color:#fff;margin:0 0 16px 0}
.about-text{font-size:1rem;line-height:1.8;color:#0f2830}
@media (max-width: 900px){.about-wrap{grid-template-columns:1fr} .about-panel{order:2} .about-photo{order:1;height:50vh}}
