/* James Nix — Light v5 */
:root{--bg:#fff;--text:#111;--muted:#444;--line:#eaeaea;--ink:#000;--fade:.5s}
:root.dark{--bg:#111;--text:#eee;--muted:#bdbdbd;--line:#2a2a2a;--ink:#fff}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}
a{color:var(--ink);text-decoration:none}a:hover{opacity:.9;text-decoration:none}
img{display:block;max-width:100%}
.container{width:min(1200px,92%);margin:0 auto}

/* Header */
.site-header{position:sticky;top:0;z-index:40;background:color-mix(in srgb, var(--bg) 92%, transparent);backdrop-filter:saturate(1.1) blur(6px);border-bottom:1px solid var(--line)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{font-family:'Playfair Display',serif;font-weight:600;letter-spacing:.3px}
.nav a{margin-left:20px;opacity:.85}.nav a.active,.nav a:hover{opacity:1}

/* Theme toggle */
.theme-toggle{margin-left:12px;border:1px solid var(--line);background:transparent;color:var(--text);
  width:34px;height:34px;border-radius:999px;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, background var(--fade)}
.theme-toggle:hover{transform:scale(1.04);box-shadow:0 0 0 4px color-mix(in srgb, var(--ink) 10%, transparent)}
:root,:root *{transition: background var(--fade), color var(--fade), border-color var(--fade)}

/* Split homepage */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;padding:28px 0 40px}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.split-left { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 4/5; background: transparent; box-shadow: none; }
.hero-frames{position:relative;height:100%}
.hero-frame{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.hero-frame:first-child{opacity:1}
.split-left img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; background: transparent; }
.title{font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,44px);line-height:1.15;margin:0 0 10px}
.lead{color:var(--muted);margin:0 0 18px;max-width:52ch}
.cta{display:flex;gap:12px}
.btn{display:inline-block;padding:10px 16px;border-radius:999px;border:1px solid var(--ink);color:var(--ink)}
.btn.primary{background:var(--ink);color:var(--bg)}

/* Pages */
.page-title{margin:40px 0 8px;font-size:clamp(28px,4vw,44px)}
.page-intro{margin:0 0 22px;color:var(--muted)}
.narrow{width:min(820px,92%)}

/* Forms */
.contact-form{display:grid;gap:14px;margin:14px 0 24px}
.contact-form label{display:grid;gap:6px;font-size:14px}
.contact-form input,.contact-form textarea{padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--text)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:color-mix(in srgb, var(--ink) 30%, var(--line))}
.contact-alt{color:var(--muted)}

/* Footer */
.site-footer{border-top:1px solid var(--line);margin-top:40px}
.site-footer .container{padding:24px 0;display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}

:root{--fade-duration:450ms}


/* --- E-Polish Enhancements v1 --- */
section{padding:0;margin:0;}
@media(max-width:600px){
 section{padding:0;margin:0;}
 body{padding:1rem;}
}
.nav a{transition:opacity .35s ease;}
.fade{opacity:0;transition:opacity .45s ease;}
.fade.show{opacity:1;}


/* --- MOBILE POLISH (Version A – no hamburger) --- */
@media(max-width: 700px){

  .container { width: 92%; padding: 0 4%; }

  .page-title { font-size: 30px; margin-top: 25px; }

  .nav a { font-size: 14px; margin-left: 10px; }

  .brand { font-size: 20px; }

  .site-header .container { padding-top: 10px; padding-bottom: 10px; }

  /* Forms */
  input, textarea { font-size: 16px; }

  .contact-form { gap: 12px; }

  /* Footer */
  .site-footer .container {
      flex-direction: column !important;
      text-align: center;
      gap: 6px;
  }
}

/* KEEP NAVIGATION IN ONE LINE */
.nav {
  white-space: nowrap;
  flex-wrap: nowrap;
}

.nav a {
  display: inline-block;
  white-space: nowrap;
}

/* Optional tighter spacing on small screens */
@media(max-width: 700px){
  .nav a {
    margin-left: 8px;
    font-size: 13px;
  }
}


/* Desktop: keep footer at bottom */
@media (min-width: 701px) {
  html, body { height: 100%; }
  body { display: flex; flex-direction: column; min-height: 100vh; }
  main { flex: 1 0 auto; }
  .site-footer { margin-top: auto; }
}


/* uniform 14px everywhere */




/* === Unified 14px spacing layout (stable) === */
:root{ --gap:14px; }


.top-row img, .second-row img{ width:100%; height:auto; display:block; }





/* === Final unified 14px layout === */
:root{ --gap:14px; }

.top-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--gap);
  margin:var(--gap) 0;
}
.top-row img{ width:100%; height:auto; display:block; }

/* Masonry: rows 2–end */







/* === Final strict 3-col grid with exact 14px spacing === */
:root{ --gap:14px; }

.top-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--gap);
  margin:var(--gap) 0;
}
.top-row picture, .top-row img{ display:block; width:100%; height:auto; }




.grid-item { margin-bottom: 14px; }

.portfolio-grid picture,
.portfolio-grid img {
  display: block;
  width: 100%;
  height: auto;
}

/* Tablet */
@media (max-width: 1024px) {
  
}

/* Mobile */
@media (max-width: 768px) {
  
}
@media (max-width: 1024px) {
  
}

@media (max-width: 768px) {
  
}
@media (max-width: 768px) {
  
}

.lightbox{
  display:none;
  position:fixed;
  top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,0.8);
  justify-content:center;align-items:center;
  z-index:9999;
}
.lightbox-content{
  max-width:90%; max-height:90%;
}
.lightbox .close{
  position:absolute;top:20px;right:30px;
  color:white;font-size:40px;cursor:pointer;
}


@media (max-width: 768px) {
  
}


/* Portfolio grid – correct responsive layout */
/* === FIXED PORTFOLIO GRID === */
:root {
  --gap: 14px;
}
.portfolio-grid {
  display: grid;
  grid-auto-rows: 8px;
  grid-auto-flow: dense;
  gap: var(--gap);
  margin: var(--gap) 0;
  opacity: 0;
  transition: opacity .25s ease;
}
.grid-item { margin: 0; }
.portfolio-grid picture,
.portfolio-grid img { display:block; width:100%; height:auto; }
@media (min-width: 1025px){ .portfolio-grid{ grid-template-columns:repeat(3,1fr);} }
@media (min-width: 601px) and (max-width:1024px){ .portfolio-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .portfolio-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:400px){ .portfolio-grid{ grid-template-columns:1fr;} }

/* Column-based masonry removed: using CSS Grid masonry instead */