:root{
  --ink:#1c2733;
  --muted:#5b6b7a;
  --line:#dbe4ec;
  --sky1:#eaf2fb;
  --sky2:#f6fafe;
  --accent:#2f6db3;
  --accent-soft:#eaf1f9;
  --bg:#e8eef5;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);}
img{max-width:100%;display:block;}
.skip{position:absolute;left:-9999px;}
.skip:focus{left:12px;top:12px;background:#fff;padding:8px 12px;border-radius:8px;z-index:10;}

/* ---- header ---- */
.site-head{
  background:linear-gradient(160deg,var(--sky1),var(--sky2));
  border-bottom:1px solid var(--line);
}
.head-inner{
  max-width:1180px;margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink);}
.brand-mark{font-size:30px;line-height:1;color:var(--accent);}
.brand-name{display:block;font-size:20px;font-weight:750;letter-spacing:-.01em;}
.brand-sub{display:block;font-size:12px;color:var(--muted);margin-top:1px;max-width:52ch;line-height:1.35;}
@media(max-width:760px){.brand-sub{display:none;}}
.site-nav{display:flex;gap:4px;flex-wrap:wrap;}
.site-nav a{
  text-decoration:none;color:var(--muted);font-size:13.5px;font-weight:600;
  padding:7px 13px;border-radius:8px;letter-spacing:.01em;
}
.site-nav a:hover{color:var(--accent);background:var(--accent-soft);}
.site-nav a.on{color:var(--accent);background:var(--accent-soft);}

/* ---- reading shell (content pages) ---- */
body.reading main{
  max-width:820px;margin:28px auto;background:#fff;
  border:1px solid var(--line);border-radius:14px;
  box-shadow:0 10px 40px rgba(28,39,51,.10);overflow:hidden;
  padding:38px 48px 30px;
}
body.reading main h1{font-size:29px;letter-spacing:-.01em;margin:0 0 6px;font-weight:750;}
.lead{color:var(--muted);font-size:16px;margin:0 0 26px;}
.kicker{
  text-transform:uppercase;letter-spacing:.18em;font-size:11px;font-weight:700;
  color:var(--accent);margin:0 0 10px;
}

/* ---- gallery (homepage / category) ---- */
body.wide main{max-width:1180px;margin:0 auto;padding:30px 28px 50px;}
.gallery-head{margin:8px 0 22px;}
.gallery-head h1{font-size:26px;margin:0 0 4px;letter-spacing:-.01em;}
.gallery-head p{color:var(--muted);margin:0;font-size:14.5px;}
.cat-bar{display:flex;flex-wrap:wrap;gap:7px;margin:16px 0 4px;}
.cat-bar a{
  text-decoration:none;font-size:13px;font-weight:600;color:var(--muted);
  padding:6px 12px;border:1px solid var(--line);border-radius:999px;background:#fff;
}
.cat-bar a:hover,.cat-bar a.on{color:#fff;background:var(--accent);border-color:var(--accent);}

/* Grid masonry: fixed-width columns + per-tile row spans (set inline by the
   generator) give true masonry packing with a stable column count and no JS. */
.masonry{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;align-items:start;}
.masonry.js-masonry{grid-auto-rows:8px;row-gap:0;}   /* masonry.js sets per-tile spans */
@media(max-width:520px){.masonry{grid-template-columns:1fr;}}
.tile{
  position:relative;display:block;text-decoration:none;
  background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;
  box-shadow:0 2px 10px rgba(28,39,51,.05);transition:transform .12s ease,box-shadow .12s ease;
}
.tile:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(28,39,51,.13);}
.tile img{width:100%;height:auto;background:var(--sky1);display:block;}
.tile.pano img{aspect-ratio:2/1;object-fit:cover;object-position:center;} /* center-crop very wide panoramas so the thumbnail isn't too short */
.tile.tall img{aspect-ratio:1/1;object-fit:cover;object-position:center;} /* center-crop tall portraits so the thumbnail isn't too tall */
.tile .cap{display:block;padding:9px 14px 11px;}
.tile .cap .meta{display:block;font-size:11.5px;color:var(--muted);letter-spacing:.02em;}
/* photo-count badge over the thumbnail, for multi-image series posts */
.tile .badge{position:absolute;top:8px;right:8px;z-index:1;display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:999px;background:rgba(20,28,38,.72);color:#fff;
  font-size:11.5px;font-weight:650;line-height:1;backdrop-filter:blur(2px);box-shadow:0 1px 4px rgba(0,0,0,.25);}
.tile .badge svg{display:block;}

/* ---- single post ---- */
.post-wrap{max-width:1006px;margin:0 auto;padding:26px 28px 50px;} /* content = 1006-56 = 950px, matching the native width of the display images so they never upscale */
.post-top{margin:4px 0 16px;}
.post-top .crumb{font-size:12.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;}
.post-top .crumb a{color:var(--accent);text-decoration:none;}
.post-top h1{font-size:25px;margin:8px 0 4px;letter-spacing:-.01em;}
.post-top .when{color:var(--muted);font-size:13.5px;}
.cc-figure{margin:0;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 6px 26px rgba(28,39,51,.10);}
.cc-figure + .cc-figure{margin-top:20px;} /* spacing between stacked photos in multi-image "series" posts */
.cc-figure img{width:100%;height:auto;background:var(--sky1);}
.cc-note{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:11px 16px;font-size:12.5px;color:var(--muted);border-top:1px solid var(--line);background:var(--sky2);
}
.cc-note a{color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:5px;}
/* per-photo title on multi-image posts: own line above the CC license row */
.cc-title{flex-basis:100%;font-size:13.5px;font-weight:600;color:var(--ink);}
.cc-glyph{vertical-align:middle;}
.post-nav{display:flex;justify-content:space-between;gap:12px;margin-top:22px;font-size:13.5px;}
.post-nav a{
  text-decoration:none;color:var(--accent);background:#fff;border:1px solid var(--line);
  padding:9px 15px;border-radius:9px;max-width:46%;
}
.post-nav a:hover{background:var(--accent-soft);}
.post-nav .spacer{flex:1;}

/* ---- credits / content blocks ---- */
h2.section{
  font-size:13px;text-transform:uppercase;letter-spacing:.13em;color:var(--accent);
  border-bottom:2px solid var(--accent-soft);padding-bottom:7px;margin:30px 0 18px;
}
.credit{display:grid;grid-template-columns:150px 1fr;gap:20px;padding:18px 0;border-bottom:1px solid var(--line);}
.credit:last-child{border-bottom:none;}
.credit .who{font-weight:700;font-size:14.5px;line-height:1.35;}
.credit .who span{display:block;font-weight:500;font-size:12px;color:var(--muted);margin-top:3px;}
.credit .what{font-size:14.5px;color:#33424f;margin:0;}
.credit .what em{color:var(--muted);font-style:italic;}
.credit.pending{opacity:.55;}
.badge{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);background:var(--accent-soft);padding:2px 8px;border-radius:999px;margin-left:6px;vertical-align:middle;}
blockquote{
  margin:12px 0 0;padding:10px 16px;background:var(--accent-soft);
  border-left:3px solid var(--accent);border-radius:0 8px 8px 0;font-size:13.5px;color:#33424f;
}
.panel{margin:26px 0 6px;padding:20px 22px;background:var(--sky2);border:1px solid var(--line);border-radius:10px;}
.panel p{margin:0 0 8px;font-size:14px;color:#33424f;}
.panel p:last-child{margin:0;}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0 4px;}
.compare figure{margin:0;}
.compare img{border:1px solid var(--line);border-radius:10px;}
.compare figcaption{font-size:11.5px;color:var(--muted);margin-top:6px;text-align:center;}

/* ---- contact form ---- */
.contact-form label{font-size:13.5px;font-weight:600;color:var(--ink);}
.contact-form input,.contact-form textarea{
  width:100%;margin-top:5px;padding:10px 12px;font:inherit;font-size:14.5px;
  border:1px solid var(--line);border-radius:9px;background:var(--sky2);color:var(--ink);
}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);}
.contact-form button{
  font:inherit;font-weight:650;font-size:14.5px;color:#fff;background:var(--accent);
  border:none;border-radius:9px;padding:11px 22px;cursor:pointer;
}
.contact-form button:hover{background:#27598f;}
.contact-form button:disabled{opacity:.6;cursor:progress;}
.pow-nojs{font-size:13px;color:#8a4b2f;background:#fdf3f0;border:1px solid #e7c3b4;border-radius:8px;padding:9px 12px;margin:4px 0;}

/* ---- lightbox (progressive enhancement) ---- */
.lb-overlay{position:fixed;inset:0;background:rgba(12,20,28,.93);display:none;
  align-items:center;justify-content:center;z-index:1000;padding:28px;}
.lb-overlay.on{display:flex;}
.lb-fig{margin:0;max-width:96vw;max-height:92vh;display:flex;flex-direction:column;align-items:center;}
.lb-fig img{max-width:96vw;max-height:84vh;width:auto;height:auto;border-radius:8px;
  box-shadow:0 12px 60px rgba(0,0,0,.55);background:#0c141c;}
.lb-cap{color:#cdd8e2;font-size:12.5px;margin-top:14px;text-align:center;}
.lb-cap a{color:#7fb3e6;text-decoration:none;}
.lb-cap a:hover{text-decoration:underline;}
.lb-close{position:fixed;top:14px;right:20px;background:none;border:none;color:#fff;
  font-size:38px;line-height:1;cursor:pointer;opacity:.85;padding:4px 10px;}
.lb-close:hover{opacity:1;}
.js-zoom{cursor:zoom-in;}

/* ---- footer ---- */
.site-foot{border-top:1px solid var(--line);background:#fff;margin-top:10px;}
.foot-inner{max-width:1180px;margin:0 auto;padding:22px 28px 34px;font-size:12.5px;color:var(--muted);}
.foot-cc{margin:0 0 5px;}
.foot-inner a{color:var(--accent);text-decoration:none;}
.foot-meta{margin:0;}

@media(max-width:620px){
  body.reading main{padding:26px 22px;margin:16px 12px;}
  .credit{grid-template-columns:1fr;gap:6px;}
  .compare{grid-template-columns:1fr;}
  .head-inner{padding:14px 18px;}
  .post-wrap{padding:18px 0 40px;} /* zero side padding: photo aligns to the same width as the homepage gallery tiles (28px main padding) */
}

/* Hide the persistent CookieYes floating "revisit" badge (the corner cookie circle).
   Re-opening preferences is still available via the footer "Cookie settings" link
   (a.cky-banner-element). Can also be toggled off in the CookieYes dashboard. */
.cky-btn-revisit-wrapper,
.cky-revisit-bottom-left,
.cky-revisit-bottom-right{display:none !important;}
