/*
Theme Name: Photograph Archive
Author: Vanessa Scheirer
Description: A bespoke archival theme presenting a photograph archive as a museum-label-style collection. Pairs with the Photograph Catalog plugin for content.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: photograph-archive
*/

:root{
	--paper:#EAEAE6;
	--surface:#F5F5F2;
	--ink:#191B1F;
	--muted:#6C6F74;
	--accent:#0E4D54;
	--line:#D5D5D0;
	--plate:#FFFFFF;
	--dark:#0D0E10;
	--serif:'IBM Plex Serif',Georgia,serif;
	--sans:'IBM Plex Sans',system-ui,-apple-system,sans-serif;
	--mono:'IBM Plex Mono',ui-monospace,monospace;
}

*{box-sizing:border-box}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:500}

.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.rec{font-family:var(--mono);font-size:10.5px;letter-spacing:.15em;color:var(--accent)}

.site-header{border-bottom:1px solid var(--line)}
.site-header-in{max-width:1140px;margin:0 auto;padding:15px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{font-family:var(--serif);font-size:19px;font-weight:500}
.site-nav-list{list-style:none;display:flex;gap:24px;margin:0;padding:0}
.site-nav-list a{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.site-nav-list a:hover{color:var(--ink)}

.site-main{max-width:1140px;margin:0 auto;padding:44px 28px 64px}

.collection-masthead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.collection-title{font-family:var(--serif);font-size:42px;line-height:1.04;letter-spacing:.005em}
.collection-count{margin-top:11px}
.collection-controls{display:flex;gap:10px;align-items:center}
.collection-controls input,.collection-controls select{font-family:var(--sans);font-size:14px;background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:9px 12px;color:var(--ink)}
.collection-controls input{width:210px}
.collection-controls input::placeholder{color:var(--muted)}
.collection-controls input:focus,.collection-controls select:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}

.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:44px 30px}
.cat-card{display:block;width:100%}
.cat-plate{position:relative;aspect-ratio:1/1;background:var(--plate);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden}
.cat-plate-img{max-height:100%;max-width:100%;object-fit:contain;transition:transform .55s ease}
.cat-card:hover .cat-plate-img{transform:scale(1.045)}
.cat-plate-empty{display:block;width:100%;height:100%}
.cat-card-label{padding-top:15px}
.cat-card-title{font-family:var(--serif);font-style:italic;font-size:18px;font-weight:500;margin:6px 0 2px;line-height:1.25}
.cat-card-by{font-size:13.5px;color:var(--muted)}
.cat-card-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.cat-card-medium{font-size:12.5px;color:var(--muted)}
.cat-card-val{font-family:var(--mono);font-size:13px;white-space:nowrap}
.cat-card:focus-visible{outline:2px solid var(--accent);outline-offset:5px}
.cat-noresults,.cat-empty{color:var(--muted);font-size:15px}

.object-back{font-family:var(--mono);font-size:12px;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);display:inline-flex;gap:9px;align-items:center;margin-bottom:30px}
.object-back:hover{color:var(--ink)}
.object{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:50px;align-items:start}
.object-plate{display:flex;align-items:center;justify-content:center;width:fit-content;max-width:100%;background:var(--plate);border:1px solid var(--line);padding:32px;cursor:zoom-in}
.object-plate img{display:block;width:auto;height:auto;max-width:100%;max-height:70vh}
.object-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.object-thumb{width:74px;height:74px;background:var(--plate);border:1px solid var(--line);padding:7px;display:flex;align-items:center;justify-content:center}
.object-thumb img{max-width:100%;max-height:100%;object-fit:contain}
.object-thumb[aria-current="true"]{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.object-thumb:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.object-rec{font-size:11px}
.object-title{font-family:var(--serif);font-style:italic;font-size:34px;font-weight:500;line-height:1.12;margin:12px 0 7px}
.object-by{font-size:16px;color:var(--muted);margin-bottom:20px}
.object-desc{font-size:15px;line-height:1.78;margin:0 0 24px;max-width:46ch}
.object-meta{width:100%;border-collapse:collapse}
.object-meta th{text-align:left;font-family:var(--mono);font-weight:400;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:12px 18px 12px 0;vertical-align:top;white-space:nowrap;width:1%}
.object-meta td{padding:12px 0;border-bottom:1px solid var(--line);font-size:15px}
.object-meta tr:first-child th,.object-meta tr:first-child td{border-top:1px solid var(--line)}

.page-narrow{max-width:720px}
.page-title{font-family:var(--serif);font-size:34px;line-height:1.1;margin:0 0 18px}
.post-summary{padding-bottom:28px;margin-bottom:28px;border-bottom:1px solid var(--line)}
.post-summary-title{font-family:var(--serif);font-size:24px;margin:0 0 6px}
.post-summary-meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.entry-content{font-size:16px;line-height:1.75}
.entry-content h2{font-family:var(--serif);font-size:26px;margin:1.6em 0 .5em}
.entry-content h3{font-family:var(--serif);font-size:21px;margin:1.4em 0 .5em}
.entry-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.entry-content img{margin:1.5em 0}
.pagination{margin-top:32px;font-family:var(--mono);font-size:13px}

.site-footer{border-top:1px solid var(--line);margin-top:48px}
.site-footer-in{max-width:1140px;margin:0 auto;padding:24px 28px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

.lightbox{position:fixed;inset:0;background:rgba(13,14,16,.93);display:none;align-items:center;justify-content:center;z-index:100000}
.lightbox.lightbox-open{display:flex}
.lightbox-img{max-width:90vw;max-height:84vh;object-fit:contain}
.lightbox-btn{position:absolute;background:rgba(255,255,255,.08);color:#fff;border:none;width:46px;height:46px;border-radius:50%;font-size:24px;line-height:1;cursor:pointer}
.lightbox-btn:hover{background:rgba(255,255,255,.18)}
.lightbox-btn:focus-visible{outline:2px solid #fff;outline-offset:2px}
.lightbox-close{top:22px;right:22px}
.lightbox-prev{left:22px;top:50%;transform:translateY(-50%)}
.lightbox-next{right:22px;top:50%;transform:translateY(-50%)}
.lightbox-counter{position:absolute;top:26px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:#cfcfcf}

@media (prefers-reduced-motion:reduce){.cat-plate-img{transition:none}}
@media (max-width:760px){.object{grid-template-columns:1fr;gap:30px}.collection-title{font-size:32px}.collection-controls input{width:150px}}
@media (max-width:600px){.lightbox-btn{width:42px;height:42px;font-size:20px}.lightbox-prev{left:8px}.lightbox-next{right:8px}.site-header-in{flex-wrap:wrap}}
