:root{
  --cream:#f2e7cf; --paper:#faf4e3; --card:#fbf6e8;
  --red:#c8402e; --red-dark:#a5311f; --navy:#16222f; --ink:#1c1a17;
  --muted:#7a6f59; --line:#d8cba9; --gold:#c9a24a;
  --maxw:1280px;
  --shadow:0 2px 0 rgba(22,34,47,.10), 0 10px 30px rgba(22,34,47,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;background:var(--cream);color:var(--ink);max-width:100%;overflow-x:hidden;
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
.wrap,.toolbar .wrap,.site-head .wrap,.site-foot .wrap{width:100%}
img{max-width:100%;display:block}
a{color:var(--red-dark)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.head-serif{font-family:Georgia,"Times New Roman",serif}

/* ---------- header / nav ---------- */
.site-head{position:sticky;top:0;z-index:40;background:var(--navy);border-bottom:4px solid var(--red)}
.site-head .wrap{display:flex;align-items:center;gap:18px;height:62px}
.logo-link{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff}
.logo-link .mono{font-weight:900;letter-spacing:.16em;font-size:15px;border:2px solid var(--gold);color:var(--gold);
  padding:2px 7px;border-radius:5px}
.logo-link .word{font-weight:800;letter-spacing:.05em;font-size:15px;color:#fff}
.nav{margin-left:auto;display:flex;gap:6px}
.nav a{color:#e7dcc4;text-decoration:none;font-weight:700;font-size:14px;letter-spacing:.03em;
  padding:8px 14px;border-radius:20px}
.nav a:hover{background:rgba(255,255,255,.1);color:#fff}
.nav a.active{background:var(--red);color:#fff}
.nav-toggle{display:none;margin-left:auto;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:38px;padding:9px 10px;background:transparent;border:1.5px solid rgba(255,255,255,.4);
  border-radius:8px;cursor:pointer}
.nav-toggle span{display:block;height:2px;width:100%;background:#fff;border-radius:2px}

/* ---------- footer ---------- */
.site-foot{background:var(--navy);color:#cdbf9f;margin-top:70px;padding:34px 0}
.site-foot .wrap{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.site-foot .brand{font-weight:800;letter-spacing:.05em;color:#fff}
.site-foot .tag{font-size:13px;font-style:italic;color:var(--gold)}
.site-foot a{color:#e7dcc4}

/* ---------- hero (landing) ---------- */
.hero{background:radial-gradient(120% 120% at 50% -10%, #24384a 0%, var(--navy) 60%, #0f1a24 100%);
  color:#fff;text-align:center;padding:54px 22px 0;overflow:hidden}
.hero .kicker{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.hero-logo{max-width:min(500px,82vw);height:auto;margin:0 auto;display:block}
.tagline-text{max-width:960px;margin:0 auto;font-weight:900;line-height:1.06;letter-spacing:.005em;
  color:var(--navy);text-transform:uppercase;font-size:clamp(22px,4.6vw,46px)}
.tagline-text u{text-decoration-thickness:.07em;text-underline-offset:.1em;text-decoration-color:var(--red)}
.tagline-text .star{color:var(--red)}
.hero-cta{margin:30px 0 46px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;text-decoration:none;font-weight:800;letter-spacing:.03em;font-size:15px;
  padding:13px 26px;border-radius:8px;border:2px solid transparent;cursor:pointer}
.btn-red{background:var(--red);color:#fff;border-color:var(--red)}
.btn-red:hover{background:var(--red-dark);border-color:var(--red-dark)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.tagline-band{background:var(--cream);padding:34px 22px;text-align:center;border-bottom:1px solid var(--line)}
.tagline-band img{max-width:min(760px,90vw);margin:0 auto}

/* ---------- section headings ---------- */
.section{padding:56px 0}
.section-head{text-align:center;max-width:760px;margin:0 auto 34px}
.eyebrow{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--red);font-weight:800;margin-bottom:10px}
.section-head h2{font-size:clamp(26px,4vw,40px);line-height:1.08;margin:0 0 12px;font-weight:900;letter-spacing:-.01em;color:var(--navy)}
.section-head p{font-size:17px;color:#4a4335;margin:0}
.section.dark{background:var(--navy);color:#eadfc6}
.section.dark h2{color:#fff}
.section.dark p{color:#cdbf9f}

/* ---------- collection intro strip ---------- */
.collection-strip{background:var(--red);color:#fff;text-align:center;padding:16px 22px;
  font-weight:800;letter-spacing:.02em;font-size:clamp(15px,2.4vw,20px)}

/* ---------- poster grid ---------- */
.grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;
  cursor:pointer;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s;text-align:left}
.card:hover{transform:translateY(-4px);box-shadow:0 6px 0 rgba(22,34,47,.14),0 18px 36px rgba(22,34,47,.18)}
.card-thumb{position:relative;aspect-ratio:2481/3508;background:var(--cream);overflow:hidden}
.card-thumb img{width:100%;height:100%;object-fit:cover}
.card-body{padding:12px 13px 14px}
.card-title{font-weight:900;font-size:15px;line-height:1.18;color:var(--red-dark);margin:0 0 5px}
.card-head{font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--navy);opacity:.75;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{margin-top:9px;display:flex;gap:6px;flex-wrap:wrap}
.tag{font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:4px;
  background:var(--cream);color:var(--navy);border:1px solid var(--line)}
.tag.group{background:var(--navy);color:var(--paper);border-color:var(--navy)}
.ver-badge{position:absolute;bottom:8px;left:8px;background:var(--red);color:#fff;font-size:10px;font-weight:800;
  letter-spacing:.03em;text-transform:uppercase;padding:3px 8px;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.25)}

/* ---------- gallery toolbar ---------- */
.toolbar{position:sticky;top:62px;z-index:20;background:var(--paper);border-bottom:1px solid var(--line);padding:14px 0}
.toolbar .wrap{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.search{flex:1 1 220px;min-width:180px;max-width:380px;padding:10px 13px;border:2px solid var(--navy);border-radius:8px;background:#fff;font-size:14px}
.search:focus{outline:none;border-color:var(--red)}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{cursor:pointer;border:1.5px solid var(--navy);background:transparent;color:var(--navy);font-size:12.5px;
  font-weight:700;padding:6px 12px;border-radius:20px;white-space:nowrap}
.chip .n{opacity:.5;margin-left:4px}
.chip:hover{background:var(--cream)}
.chip.active{background:var(--red);border-color:var(--red);color:#fff}
.chip.active .n{opacity:.8}
.count-note{color:var(--muted);font-size:13px;margin-left:auto}

/* ---------- detail overlay ---------- */
.detail{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center}
.detail[hidden]{display:none}
.detail-backdrop{position:absolute;inset:0;background:rgba(16,24,33,.85)}
.detail-panel{position:relative;z-index:2;background:var(--paper);width:min(1180px,94vw);height:min(92vh,940px);
  border-radius:12px;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.55);border:1px solid var(--line)}
.detail-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);height:100%}
.detail-img{background:#0e1620;display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto}
.detail-img img{max-width:100%;max-height:100%;object-fit:contain;box-shadow:0 8px 34px rgba(0,0,0,.5)}
.detail-info{overflow-y:auto;padding:30px 32px 44px}
.detail-title{font-weight:900;font-size:clamp(22px,3vw,30px);line-height:1.1;color:var(--red-dark);margin:0 0 6px}
.detail-headline{font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--navy);font-weight:800}
.detail-sub{font-size:13px;color:var(--muted);margin-top:2px}
.ver-switch{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:16px 0 4px;padding:10px;background:var(--cream);border-radius:8px}
.ver-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:800}
.ver-btn{cursor:pointer;border:1.5px solid var(--navy);background:#fff;color:var(--navy);font-weight:700;font-size:12.5px;padding:5px 11px;border-radius:16px}
.ver-btn.active{background:var(--red);border-color:var(--red);color:#fff}
.chiprow{display:flex;gap:6px;flex-wrap:wrap;margin:14px 0}
.detail-section{margin-top:20px}
.detail-section h4{margin:0 0 7px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.desc{font-size:13.5px;color:#3a352c;background:var(--cream);border-left:3px solid var(--red);padding:11px 13px;border-radius:0 6px 6px 0}
.statement{font-family:Georgia,serif;font-size:15.5px;line-height:1.65;color:#241f18}
.statement p{margin:0 0 .85em}.statement strong{color:var(--red-dark)}
.detail-close{position:absolute;top:12px;right:14px;z-index:5;background:rgba(0,0,0,.5);color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:17px;cursor:pointer}
.detail-close:hover{background:var(--red)}
.detail-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(0,0,0,.45);color:#fff;border:none;width:44px;height:64px;font-size:30px;cursor:pointer}
.detail-nav:hover{background:var(--red)}
.detail-nav.prev{left:0;border-radius:0 8px 8px 0}.detail-nav.next{right:0;border-radius:8px 0 0 8px}
.fulllink{display:inline-block;margin-top:12px;font-size:12px;color:var(--navy)}

/* ---------- about / prose ---------- */
.prose-hero{background:var(--navy);color:#fff;text-align:center;padding:56px 22px 46px}
.prose-hero .eyebrow{color:var(--gold)}
.prose-hero h1{font-size:clamp(30px,5vw,52px);margin:6px 0 0;font-weight:900;letter-spacing:-.01em}
.prose{max-width:740px;margin:0 auto;padding:52px 22px}
.prose h2{font-size:26px;font-weight:900;color:var(--navy);margin:44px 0 12px;letter-spacing:-.01em}
.prose h2:first-child{margin-top:0}
.prose p{font-family:Georgia,serif;font-size:17.5px;line-height:1.72;color:#2b271f;margin:0 0 1.05em}
.prose .lede{font-size:20px;color:var(--red-dark);font-style:italic}
.prose blockquote{margin:26px 0;padding:14px 20px;border-left:4px solid var(--red);background:var(--paper);border-radius:0 8px 8px 0;font-style:italic;color:#3a352c}
.prose .sign{font-weight:800;font-style:normal;color:var(--navy);letter-spacing:.04em;font-family:inherit}
.portrait{float:right;width:min(44%,300px);margin:4px 0 18px 28px}
.portrait img{width:100%;border-radius:12px;border:1px solid var(--line);box-shadow:0 10px 28px rgba(22,34,47,.2)}
.portrait figcaption{margin-top:9px;text-align:center;font-family:-apple-system,system-ui,sans-serif;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media (max-width:620px){.portrait{float:none;width:100%;max-width:340px;margin:0 auto 22px}}
.prose hr{border:none;border-top:1px solid var(--line);margin:40px 0}
.callout{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:20px 22px;margin:26px 0}
.callout p{font-family:inherit;font-size:15.5px;margin:0}

@media (max-width:820px){
  .site-head .wrap{height:56px}
  .toolbar{top:56px}
  .detail-body{grid-template-columns:1fr;grid-template-rows:44vh 1fr}
  .detail-panel{height:94vh;width:96vw}
  .nav-toggle{display:flex}
  .nav{position:absolute;top:100%;left:0;right:0;margin:0;background:var(--navy);flex-direction:column;
    align-items:stretch;gap:2px;padding:8px 14px 14px;border-bottom:4px solid var(--red);
    box-shadow:0 14px 26px rgba(0,0,0,.35);display:none}
  .site-head.nav-open .nav{display:flex}
  .nav a{padding:13px 12px;font-size:15px;border-radius:8px}
}
