/* okurairi.net */
* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: #f5f2eb; color: #1a1a1a; font-family: 'Lora', serif; font-weight: 400; line-height: 1.6; }
.masthead { text-align: center; padding: 2rem 2rem 0; }
.paper-name { font-family: 'Playfair Display', serif; font-weight: 900; font-size: clamp(1.8rem, 5vw, 3rem); letter-spacing: 0.02em; color: #111111; }
.dateline { font-family: 'Inter', sans-serif; font-size: 0.6rem; color: #666666; margin-top: 0.3rem; letter-spacing: 0.05em; }
.double-rule { border-top: 1px solid #333333; padding-top: 3px; border-bottom: 1px solid #333333; height: 0; margin: 1rem auto; max-width: 560px; }
.front-page { max-width: 560px; margin: 0 auto; padding: 1.5rem 2rem; }
.headline { font-family: 'Playfair Display', serif; font-weight: 900; font-size: clamp(1.2rem, 3vw, 1.8rem); line-height: 1.3; margin-bottom: 1.5rem; color: #111111; }
.columns { column-count: 2; column-gap: 30px; column-rule: 1px solid #333333; }
.body-text { font-size: 0.8rem; margin-bottom: 0.8rem; text-align: justify; }
.drop-cap { font-family: 'Playfair Display', serif; font-weight: 900; font-size: 3.2em; float: left; line-height: 0.8; margin-right: 8px; margin-top: 4px; color: #111111; }
.continued { font-family: 'Inter', sans-serif; font-size: 0.5rem; font-style: italic; color: #666666; }
.feature { max-width: 560px; margin: 0 auto; padding: 2rem 2rem; }
.pull-quote { padding: 2rem 0; text-align: center; }
.quote-text { font-family: 'Playfair Display', serif; font-weight: 700; font-style: italic; font-size: clamp(1.1rem, 2.5vw, 1.5rem); color: #8b0000; }
.feature-body { max-width: 400px; margin: 0 auto; }
.editors-pick { max-width: 560px; margin: 0 auto; padding: 1.5rem 2rem; }
.pick-badge { font-family: 'Inter', sans-serif; font-size: 0.5rem; text-transform: uppercase; letter-spacing: 0.15em; color: #666666; border: 1px solid #999999; padding: 2px 8px; display: inline-block; margin-bottom: 0.75rem; }
.pick-headline { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 1.1rem; margin-bottom: 0.5rem; }
.classifieds { max-width: 560px; margin: 0 auto; padding: 1.5rem 2rem 3rem; }
.classifieds-body { background: #eee8d5; padding: 1.25rem; column-count: 2; column-gap: 20px; column-rule: 1px solid #999999; }
.classified-entry { font-size: 0.65rem; margin-bottom: 0.5rem; color: #333333; }
.dot-separator { text-align: center; font-size: 0.5rem; color: #999999; margin: 0.3rem 0; }
.end-mark { text-align: center; font-family: 'Inter', sans-serif; font-size: 0.55rem; color: #666666; margin-top: 1.5rem; font-style: italic; }
.fade-in { opacity: 0; transform: translateY(12px); transition: opacity 0.5s ease, transform 0.5s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }
