:root{
  --bg:#f6f0e1;
  --paper:#fbf7ec;
  --paper-2:#f1ead8;
  --ink:#1a2238;
  --ink-soft:#2c3650;
  --muted:#6a5f54;
  --muted-2:#867a6c;
  --accent:#1f3b2d;       /* deep forest */
  --accent-2:#8c2b1e;     /* aged garnet */
  --gold:#b8893b;
  --line:#d8cdb8;
  --line-soft:#e7dec9;
  --serif:'Playfair Display','EB Garamond','Cormorant Garamond',Georgia,serif;
  --serif-body:'EB Garamond',Georgia,serif;
  --sans:'Inter','Helvetica Neue',Arial,sans-serif;
  --max:1240px;
  --shadow:0 8px 28px rgba(20,14,8,.07);
  --shadow-lg:0 18px 60px rgba(20,14,8,.12);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--serif-body);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(at 20% 0%,rgba(184,137,59,.06),transparent 50%),radial-gradient(at 80% 100%,rgba(31,59,45,.05),transparent 60%);
}
a{color:var(--accent-2);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s,color .15s}
a:hover{border-color:currentColor}
img,svg{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}
hr{border:0;border-top:1px solid var(--line);margin:48px 0}

/* Header */
.site-header{border-bottom:1px solid var(--line);background:rgba(251,247,236,.92);position:sticky;top:0;z-index:30;backdrop-filter:blur(8px)}
.site-header .row{display:flex;align-items:center;gap:24px;padding:16px 0}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-weight:700;font-size:24px;color:var(--ink);border:none;line-height:1}
.brand .logo{width:42px;height:42px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:var(--paper);font-style:italic;font-size:24px;font-family:var(--serif);box-shadow:inset 0 -2px 0 rgba(0,0,0,.12)}
.brand small{display:block;font-size:10px;color:var(--muted);font-weight:500;letter-spacing:.22em;text-transform:uppercase;margin-top:4px;font-family:var(--sans)}
.nav{display:flex;gap:24px;align-items:center;margin-left:auto}
.nav a{color:var(--ink);font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:6px 0;border-bottom:1px solid transparent}
.nav a:hover{color:var(--accent-2);border-bottom-color:var(--accent-2)}
.search{margin-left:8px}
.search input{font-family:var(--sans);font-size:14px;padding:9px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;width:220px}
.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,59,45,.1)}

/* Hero */
.hero{padding:80px 0 64px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--paper) 0%,transparent 80%);pointer-events:none}
.hero .grid{display:grid;grid-template-columns:1.25fr 1fr;gap:64px;align-items:center;position:relative}
.hero .eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;font-weight:600}
.hero h1{font-family:var(--serif);font-weight:800;font-size:64px;line-height:1.04;margin:0 0 22px;letter-spacing:-.02em;color:var(--ink)}
.hero h1 em{font-style:italic;font-weight:400;color:var(--accent-2)}
.hero p.lede{font-size:21px;color:var(--ink-soft);margin:0 0 28px;max-width:50ch;line-height:1.55}
.hero-search{margin:0 0 26px;max-width:560px;position:relative}
.hero-search input{width:100%;font-family:var(--serif-body);font-size:18px;padding:18px 56px 18px 24px;border:1px solid var(--line);border-radius:999px;background:#fff;box-shadow:var(--shadow)}
.hero-search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(31,59,45,.12)}
.hero-search button{position:absolute;right:6px;top:6px;bottom:6px;width:46px;border:none;border-radius:50%;background:var(--accent);color:#fff;cursor:pointer;display:grid;place-items:center}
.hero-search button:hover{background:var(--ink)}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;padding:13px 26px;border-radius:6px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border:1px solid transparent;cursor:pointer;transition:all .15s}
.btn.primary{background:var(--accent);color:var(--paper)}
.btn.primary:hover{background:var(--ink);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.hero .stats{display:flex;gap:40px;margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.hero .stat strong{display:block;font-size:32px;font-family:var(--serif);font-weight:700;color:var(--accent)}
.hero .stat span{font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500}
.hero-art{aspect-ratio:1/1.05;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(160deg,#23304a,#0e1726);box-shadow:var(--shadow-lg);position:relative}
.hero-art svg{width:100%;height:100%}

/* Section */
.section{padding:64px 0}
.section h2{font-family:var(--serif);font-size:38px;margin:0 0 8px;font-weight:700;letter-spacing:-.015em;color:var(--ink)}
.section .sub{color:var(--muted);font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:34px;font-weight:500}
.section.tinted{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:34px}
.section-head .titles h2{margin-bottom:6px}
.section-head .more{font-family:var(--sans);font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:600;border:none;padding-bottom:2px;border-bottom:1px solid var(--accent)}

/* Index page header (key, decade, form, etc) */
.index-head{padding:48px 0 24px;border-bottom:1px solid var(--line-soft);margin-bottom:32px}
.index-head .eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:0 0 14px}
.index-head h1{font-family:var(--serif);font-size:52px;font-weight:800;line-height:1.05;margin:0 0 18px;letter-spacing:-.02em}
.index-head .lede{font-size:20px;color:var(--ink-soft);margin:0;max-width:68ch;line-height:1.55}
.crumbs{font-family:var(--sans);font-size:12px;color:var(--muted);padding:24px 0 8px;letter-spacing:.04em;text-transform:uppercase}
.crumbs a{color:var(--muted);border-bottom:1px solid transparent}
.crumbs a:hover{color:var(--ink)}

/* Card prose blocks */
.card-prose{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:36px 44px;margin:0 0 32px;max-width:none;box-shadow:var(--shadow)}
.card-prose h2{font-family:var(--serif);font-size:28px;margin:0 0 14px;font-weight:700}
.card-prose p{font-size:18px;line-height:1.7;color:var(--ink-soft);margin:0 0 14px;max-width:72ch}

/* Grid of pieces */
.grid-pieces{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:28px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease,border-color .18s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.card a.cover{display:block;aspect-ratio:3/4;background:#222;border:none}
.card .body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column;gap:6px}
.card .title{font-family:var(--serif);font-size:19px;line-height:1.25;margin:0;font-weight:700;letter-spacing:-.005em}
.card .title a{color:var(--ink);border-bottom:none}
.card .title a:hover{color:var(--accent-2)}
.card .meta{font-family:var(--sans);font-size:12px;color:var(--muted);letter-spacing:.04em}
.card .tags{margin-top:auto;padding-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.tag{font-family:var(--sans);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:3px 9px;border-radius:999px;background:#fff;font-weight:600}
.tag a{color:inherit;border:none}
.tag.era{color:var(--accent)}
.tag.diff{color:var(--accent-2)}

/* Composer/era cards */
.grid-composers{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.comp-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:22px 24px;transition:all .18s;position:relative;overflow:hidden}
.comp-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);opacity:0;transition:opacity .18s}
.comp-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--accent)}
.comp-card:hover::before{opacity:1}
.comp-card h3{margin:0 0 4px;font-size:23px;font-family:var(--serif);font-weight:700;letter-spacing:-.01em}
.comp-card h3 a{color:var(--ink);border:none}
.comp-card h3 a:hover{color:var(--accent-2)}
.comp-card .dates{font-family:var(--sans);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-weight:500;margin-bottom:12px}
.comp-card p{font-size:15px;color:var(--ink-soft);margin:0 0 12px;line-height:1.5}
.comp-card .count{font-family:var(--sans);font-size:11px;text-transform:uppercase;color:var(--accent);letter-spacing:.12em;font-weight:600}

/* Key chips */
.key-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.key-chip{display:flex;align-items:center;justify-content:space-between;background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:14px 18px;font-family:var(--serif);font-size:17px;color:var(--ink);transition:all .15s;border-bottom:1px solid var(--line)}
.key-chip em{font-family:var(--sans);font-size:11px;color:var(--muted);font-style:normal;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.key-chip:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:translateY(-1px)}
.key-chip:hover em{color:var(--paper-2);opacity:.8}
.key-chip.large{padding:20px 24px;font-size:20px}

/* Piece detail */
.piece-detail{display:grid;grid-template-columns:340px 1fr;gap:56px;padding:32px 0 56px}
.piece-cover{aspect-ratio:3/4;border-radius:10px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.piece-detail .eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:0 0 12px}
.piece-detail h1{font-family:var(--serif);font-size:46px;font-weight:800;line-height:1.05;margin:0 0 8px;letter-spacing:-.02em}
.piece-detail .by{font-family:var(--serif);font-size:22px;color:var(--muted);margin:0 0 28px;font-style:italic}
.piece-detail .by a{color:var(--accent-2)}
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 32px;margin:0 0 28px;padding:24px 28px;background:var(--paper);border:1px solid var(--line);border-radius:8px}
.facts dt{font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0;font-weight:600}
.facts dd{margin:4px 0 0;font-family:var(--serif);font-size:18px;font-weight:500}
.download-row{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 32px}
.prose{max-width:68ch;font-size:18px;line-height:1.75;color:var(--ink-soft)}
.prose h3{font-family:var(--serif);font-size:26px;margin:36px 0 10px;font-weight:700;color:var(--ink)}
.prose p{margin:0 0 18px}

/* About / static */
.static-page{padding:56px 0;max-width:780px;margin:0 auto}
.static-page h1{font-family:var(--serif);font-size:48px;margin:0 0 28px;font-weight:800;letter-spacing:-.02em}
.static-page h2{font-family:var(--serif);font-size:28px;margin:36px 0 10px;font-weight:700}
.static-page p, .static-page li{font-size:18px;line-height:1.75;color:var(--ink-soft)}

/* Pager */
.pager{display:flex;gap:6px;justify-content:center;margin:48px 0 0;font-family:var(--sans);flex-wrap:wrap}
.pager a, .pager span{padding:9px 14px;border-radius:6px;color:var(--ink);font-size:13px;border:1px solid var(--line);background:var(--paper);font-weight:500}
.pager a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pager .current{background:var(--accent);border-color:var(--accent);color:var(--paper)}
.pager .dots{border:none;background:transparent}

/* AdSense slots */
.adslot{margin:24px 0;padding:18px 24px;text-align:center;color:var(--muted);font-family:var(--sans);font-size:10px;letter-spacing:.18em;text-transform:uppercase;border:1px dashed var(--line);border-radius:4px;background:rgba(255,255,255,.4);font-weight:600}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:var(--paper);margin-top:80px;padding:56px 0 32px;position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--gold),var(--accent-2))}
.site-footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.site-footer h4{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin:0 0 16px;font-weight:700}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.site-footer a{color:var(--ink);font-size:15px}
.site-footer a:hover{color:var(--accent-2)}
.site-footer .legal{margin-top:36px;padding-top:22px;border-top:1px solid var(--line);font-family:var(--sans);font-size:12px;color:var(--muted);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* Mobile menu toggle */
.menu-toggle{display:none;background:none;border:1px solid var(--line);border-radius:6px;padding:8px 10px;color:var(--ink);cursor:pointer;font-size:20px;line-height:1}

/* Responsive */
@media (max-width:1024px){
  .hero h1{font-size:50px}
  .hero .grid{gap:40px}
  .piece-detail{grid-template-columns:280px 1fr;gap:36px}
}
@media (max-width:820px){
  .container{padding:0 20px}
  .hero{padding:48px 0 40px}
  .hero .grid{grid-template-columns:1fr;gap:32px}
  .hero h1{font-size:40px}
  .hero p.lede{font-size:18px}
  .hero .stats{gap:24px;flex-wrap:wrap}
  .hero .stat strong{font-size:26px}
  .hero-art{order:-1;max-width:340px;margin:0 auto}
  .piece-detail{grid-template-columns:1fr;gap:28px;padding:24px 0}
  .piece-detail h1{font-size:34px}
  .piece-detail .piece-cover{max-width:280px;margin:0 auto}
  .site-footer .cols{grid-template-columns:1fr 1fr;gap:28px}
  .nav{display:none}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--line);flex-direction:column;padding:16px 20px;gap:12px;align-items:flex-start}
  .menu-toggle{display:block;margin-left:auto}
  .search{display:none}
  .section{padding:44px 0}
  .section h2, .index-head h1, .static-page h1{font-size:32px}
  .index-head h1{font-size:36px}
  .card-prose{padding:24px 22px}
  .facts{grid-template-columns:1fr;gap:12px 0;padding:18px 20px}
  .grid-pieces{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:18px}
  .card .title{font-size:16px}
}
@media (max-width:480px){
  .site-footer .cols{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .index-head h1{font-size:30px}
  .grid-pieces{grid-template-columns:1fr 1fr}
}
