/* didovski.net — editorial design system
   Used by index.html and all subpages. Edit here, propagates everywhere. */

:root{
  --paper:#F5F1E8;
  --paper-2:#EEE9DC;
  --ink:#1A1814;
  --ink-soft:#3A352C;
  --ink-mute:#7A7264;
  --ink-faint:#B9B0A1;
  --accent:#7A2820;
  --rule:#C9C0AE;
  --rule-strong:#5A5145;

  --hebrew:"Frank Ruhl Libre","David Libre","Times New Roman",serif;
  --hebrew-light:"David Libre","Frank Ruhl Libre",serif;
  --latin:"Cormorant Garamond","Times New Roman",serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;

  --grid-max:1320px;
  --gutter:32px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  overflow-x:hidden;
  /* Lock the document to viewport width — critical on mobile Safari/Chrome
     where a wide child can still create a scrollable zone if the html is
     allowed to grow with it. */
  max-width:100vw;
  position:relative;
}
body{
  background:var(--paper);
  background-image:
    radial-gradient(circle at 20% 10%, transparent 0%, transparent 60%, rgba(122,40,32,0.015) 100%),
    repeating-linear-gradient(0deg, transparent 0px, transparent 2px, rgba(26,24,20,0.008) 2px, rgba(26,24,20,0.008) 3px);
  color:var(--ink);
  font-family:var(--hebrew);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
  width:100%;
  max-width:100vw;
  position:relative;
}

/* Hard guarantee: nothing should be wider than the viewport. */
img, video, iframe, svg, canvas { max-width: 100%; height: auto; }

/* Common containers — cap so a wide child can't push the parent's width. */
section, header, footer, article, aside, nav, .container, .container-narrow, .container-medium {
  max-width: 100vw;
}

/* Make sure Hebrew lines and long URLs wrap on mobile instead of expanding their box. */
.hero-poem-body, .poem .body, .story-body, .about-grid .body, .about-grid .lead,
.catalog-body, .story-card, .award-row .desc, .book-intro p, .book-intro blockquote {
  word-wrap: break-word;
  overflow-wrap: anywhere;
  min-width: 0;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s}
a:hover{color:var(--accent)}

.container{max-width:var(--grid-max);margin:0 auto;padding:0 var(--gutter)}
.container-narrow{max-width:780px;margin:0 auto;padding:0 var(--gutter)}
.container-medium{max-width:980px;margin:0 auto;padding:0 var(--gutter)}

/* Utilities */
.eyebrow{font-family:var(--sans);font-weight:400;font-size:11px;text-transform:uppercase;letter-spacing:.28em;color:var(--ink-mute)}
.numeral{font-family:var(--latin);font-style:italic;font-weight:400;color:var(--accent);font-size:14px;letter-spacing:.04em}
.rule-line{height:1px;background:var(--rule);width:100%}
.rule-thick{height:1px;background:var(--rule-strong);width:100%}
.diamond{display:inline-block;color:var(--accent);font-size:11px;vertical-align:middle;line-height:1}

/* Masthead */
.masthead{border-bottom:1px solid var(--rule-strong);padding:18px 0 16px}
.masthead-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px}
.colophon{font-family:var(--sans);font-weight:400;font-size:10.5px;text-transform:uppercase;letter-spacing:.22em;color:var(--ink-mute)}
.colophon strong{font-weight:500;color:var(--ink-soft)}
.monogram{font-family:var(--latin);font-style:italic;font-weight:500;font-size:22px;color:var(--ink);letter-spacing:-0.01em;border-right:1px solid var(--rule-strong);padding-right:32px}
.monogram .he{font-family:var(--hebrew);font-style:normal;font-weight:700;font-size:24px}
.monogram a{color:inherit}
.masthead nav{display:flex;justify-content:center;gap:36px}
.masthead nav a{font-family:var(--sans);font-weight:400;font-size:12.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);padding:4px 0;border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.masthead nav a:hover,.masthead nav a.active{border-bottom-color:var(--accent);color:var(--accent)}
@media (max-width:880px){
  .masthead-inner{grid-template-columns:1fr;gap:12px;text-align:center}
  .monogram{border:0;padding:0}
  .masthead nav{flex-wrap:wrap;gap:18px}
}

/* Hero (homepage only) */
.hero{padding:90px 0 80px;border-bottom:1px solid var(--rule);background:radial-gradient(ellipse at 90% 10%, rgba(122,40,32,0.04), transparent 50%),radial-gradient(ellipse at 10% 90%, rgba(122,40,32,0.03), transparent 50%)}
.hero-grid{display:grid;grid-template-columns:1fr 5fr 4fr 1fr;gap:48px;align-items:start}
.hero-side{padding-top:14px}
.hero-side .vol{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--sans);font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-mute);white-space:nowrap}
.hero-poem-frame{position:relative;padding:0 14px}
.hero-poem-frame::before{content:"I";position:absolute;top:-12px;right:-8px;font-family:var(--latin);font-style:italic;font-weight:400;color:var(--accent);font-size:42px;line-height:1;opacity:.85}
.hero-meta-top{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--rule)}
.hero-meta-top .tag{font-family:var(--sans);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute)}
.hero-meta-top .from{font-family:var(--latin);font-style:italic;font-size:13px;color:var(--ink-soft)}
.hero-meta-top .from b{font-style:normal;font-weight:500}
.hero-poem-title{font-family:var(--hebrew);font-weight:500;font-size:18px;color:var(--ink-soft);margin-bottom:36px;line-height:1.4;letter-spacing:.02em}
.hero-poem-body{font-family:var(--hebrew-light);font-weight:400;font-size:clamp(28px,3.4vw,44px);line-height:1.55;letter-spacing:-0.005em;color:var(--ink);white-space:pre-line}
.hero-aside{padding-top:38px;border-right:1px solid var(--rule);padding-right:36px}
.author-block{margin-bottom:40px}
.author-block .name{font-family:var(--hebrew);font-weight:900;font-size:38px;line-height:1;letter-spacing:-0.02em;margin-bottom:6px}
.author-block .name-en{font-family:var(--latin);font-style:italic;font-weight:400;font-size:18px;color:var(--ink-mute);letter-spacing:.01em;margin-bottom:24px}
.author-block .role{font-family:var(--sans);font-size:10.5px;text-transform:uppercase;letter-spacing:.28em;color:var(--accent);margin-bottom:16px}
.author-block p{font-family:var(--hebrew);font-size:15.5px;line-height:1.75;color:var(--ink-soft);margin-bottom:14px}
.portrait-frame{position:relative;width:240px;margin-bottom:16px;padding:8px;background:var(--paper);border:1px solid var(--rule-strong)}
.portrait-frame::after{content:"";position:absolute;inset:3px;border:1px solid var(--rule);pointer-events:none}
.portrait-frame img{width:100%;height:300px;object-fit:cover;object-position:center 18%;filter:grayscale(100%) contrast(1.08) sepia(.22) brightness(.95)}
.portrait-caption{font-family:var(--latin);font-style:italic;font-size:12px;color:var(--ink-mute);text-align:center;width:240px}
@media (max-width:1080px){.hero-grid{grid-template-columns:5fr 4fr;gap:48px}.hero-side{display:none}}
@media (max-width:880px){.hero{padding:48px 0 40px}.hero-grid{grid-template-columns:1fr;gap:48px}.hero-aside{border:0;padding:0;border-top:1px solid var(--rule);padding-top:36px}.portrait-frame{margin:0 auto 16px}.portrait-caption{margin:0 auto}.author-block{text-align:center}}

/* Section template */
.section{padding:96px 0;border-bottom:1px solid var(--rule)}
.section-head{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:baseline;margin-bottom:64px;padding-bottom:20px;border-bottom:1px solid var(--rule)}
.section-head .num{font-family:var(--latin);font-style:italic;font-weight:400;color:var(--accent);font-size:18px;letter-spacing:.06em;white-space:nowrap}
.section-head .titles{display:flex;align-items:baseline;gap:24px;flex-wrap:wrap}
.section-head h2{font-family:var(--hebrew);font-weight:700;font-size:clamp(34px,4vw,48px);letter-spacing:-0.025em;line-height:1.05}
.section-head .sub{font-family:var(--latin);font-style:italic;font-size:18px;color:var(--ink-mute);border-right:1px solid var(--rule-strong);padding-right:24px}
@media (max-width:720px){.section{padding:64px 0}.section-head{grid-template-columns:1fr;gap:8px;margin-bottom:36px}.section-head .sub{border:0;padding:0}}

/* Books catalog (homepage) */
.catalog{display:grid;grid-template-columns:1fr;gap:0}
.catalog-row{display:grid;grid-template-columns:120px 200px 1fr auto;gap:48px;padding:40px 0;border-bottom:1px solid var(--rule);align-items:start}
.catalog-row:last-child{border-bottom:0}
.catalog-num{font-family:var(--latin);font-style:italic;font-weight:400;font-size:54px;color:var(--accent);line-height:0.9}
.catalog-num small{display:block;font-family:var(--sans);font-style:normal;font-size:10.5px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.22em;margin-top:6px}
.catalog-cover{align-self:center}
.catalog-cover img{width:160px;height:auto;filter:drop-shadow(0 12px 24px rgba(26,24,20,0.25));transition:transform .35s ease}
.catalog-cover.placeholder{width:160px;height:240px;background:linear-gradient(170deg,#4A2018,#2A1410);display:flex;align-items:center;justify-content:center;color:var(--paper);font-family:var(--hebrew);font-weight:700;font-size:24px;line-height:1.2;text-align:center;padding:18px;border:1px solid #2A1410;filter:drop-shadow(0 12px 24px rgba(26,24,20,0.25))}
.catalog-row:hover .catalog-cover img{transform:translateY(-4px)}
.catalog-body h3{font-family:var(--hebrew);font-weight:700;font-size:32px;letter-spacing:-0.02em;line-height:1.1;margin-bottom:8px}
.catalog-body h3 a:hover{color:var(--accent)}
.catalog-meta{font-family:var(--latin);font-style:italic;font-size:15px;color:var(--ink-mute);margin-bottom:18px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.catalog-meta .dot{color:var(--ink-faint);font-size:10px}
.catalog-body blockquote{font-family:var(--hebrew);font-size:17px;line-height:1.7;color:var(--ink-soft);font-style:italic;border-right:2px solid var(--accent);padding-right:18px;margin-bottom:18px;max-width:560px}
.catalog-body cite{font-family:var(--latin);font-style:italic;font-size:13px;color:var(--ink-mute)}
.catalog-action{align-self:center;text-align:left;min-width:120px}
.catalog-action a{font-family:var(--sans);font-size:11.5px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);padding-bottom:3px;border-bottom:1px solid var(--ink);white-space:nowrap}
.catalog-action a:hover{color:var(--accent);border-bottom-color:var(--accent)}
@media (max-width:980px){.catalog-row{grid-template-columns:80px 1fr;gap:24px}.catalog-cover,.catalog-body,.catalog-action{grid-column:2}.catalog-cover img,.catalog-cover.placeholder{width:140px;height:auto}.catalog-cover.placeholder{height:210px}}

/* Stories grid */
.stories-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
.story-card{border-top:1px solid var(--rule-strong);padding-top:24px}
.story-card.s1{grid-column:span 7}
.story-card.s2{grid-column:span 5}
.story-card.s3{grid-column:span 5}
.story-card.s4{grid-column:span 7}
@media (max-width:880px){.story-card.s1,.story-card.s2,.story-card.s3,.story-card.s4{grid-column:span 12}}
.story-meta-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.story-meta-row .kind{font-family:var(--sans);font-size:10.5px;text-transform:uppercase;letter-spacing:.22em;color:var(--ink-mute)}
.story-meta-row .award{font-family:var(--latin);font-style:italic;font-size:13px;color:var(--accent)}
.story-card h3{font-family:var(--hebrew);font-weight:500;font-size:30px;letter-spacing:-0.015em;line-height:1.1;margin-bottom:14px}
.story-card h3 a:hover{color:var(--accent)}
.story-card p{font-family:var(--hebrew);font-size:16.5px;line-height:1.75;color:var(--ink-soft)}
.story-card .read{display:inline-block;margin-top:16px;font-family:var(--sans);font-size:11.5px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);padding-bottom:3px;border-bottom:1px solid var(--rule-strong)}
.story-card .read:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* Awards ledger */
.awards-ledger{border-top:1px solid var(--rule-strong)}
.award-row{display:grid;grid-template-columns:120px 1fr 2.2fr;gap:40px;padding:32px 0;border-bottom:1px solid var(--rule);align-items:baseline}
.award-row .yr{font-family:var(--latin);font-style:italic;font-weight:500;font-size:42px;color:var(--accent);line-height:1}
.award-row .title{font-family:var(--hebrew);font-weight:700;font-size:22px;letter-spacing:-0.01em;line-height:1.25}
.award-row .title .en{font-family:var(--latin);font-style:italic;font-weight:400;font-size:13.5px;color:var(--ink-mute);display:block;margin-top:4px}
.award-row .desc{font-family:var(--hebrew);font-size:15.5px;color:var(--ink-soft);line-height:1.7}
.award-row .desc em{font-family:var(--latin);font-size:14px;color:var(--ink-mute)}
@media (max-width:720px){.award-row{grid-template-columns:1fr;gap:6px}}

/* About */
.about-section{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.about-grid{display:grid;grid-template-columns:4fr 8fr;gap:80px;align-items:start}
@media (max-width:880px){.about-grid{grid-template-columns:1fr;gap:48px}}
.about-grid .lead{font-family:var(--hebrew);font-weight:500;font-size:24px;line-height:1.55;color:var(--ink);border-top:2px solid var(--accent);padding-top:22px}
.about-grid .body{font-family:var(--hebrew);font-size:17.5px;line-height:1.85;color:var(--ink)}
.about-grid .body p{margin-bottom:16px}
.about-grid .body p:first-of-type::first-letter{font-family:var(--latin);font-style:italic;font-weight:500;float:right;font-size:64px;line-height:0.85;color:var(--accent);margin-left:8px;margin-top:6px}

/* Purchase */
.purchase{text-align:center;padding:96px 0}
.purchase .small{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.32em;color:var(--ink-mute);margin-bottom:14px}
.purchase h3{font-family:var(--hebrew);font-weight:500;font-size:36px;letter-spacing:-0.02em;margin-bottom:36px}
.purchase .links{display:inline-flex;gap:0;border:1px solid var(--rule-strong)}
.purchase .links a{font-family:var(--sans);font-size:12.5px;text-transform:uppercase;letter-spacing:.18em;padding:18px 32px;color:var(--ink);border-left:1px solid var(--rule-strong);transition:background .2s,color .2s}
.purchase .links a:last-child{border-left:0}
.purchase .links a:hover{background:var(--ink);color:var(--paper)}
@media (max-width:720px){.purchase .links{flex-direction:column}.purchase .links a{border-left:0;border-top:1px solid var(--rule-strong)}.purchase .links a:first-child{border-top:0}}

/* Contact form */
.contact-section{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:96px 0}
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.contact-intro h3{font-family:var(--hebrew);font-weight:500;font-size:32px;letter-spacing:-0.02em;line-height:1.15;margin-bottom:18px;border-top:2px solid var(--accent);padding-top:18px}
.contact-intro p{font-family:var(--hebrew);font-size:16px;line-height:1.75;color:var(--ink-soft);margin-bottom:14px}
.contact-intro .direct{font-family:var(--latin);font-style:italic;font-size:15px;color:var(--ink-mute);margin-top:24px}
.contact-intro .direct a{color:var(--accent);font-style:normal;font-family:var(--sans);font-size:14px;letter-spacing:.04em}
form.contact{display:flex;flex-direction:column;gap:18px}
form.contact .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){form.contact .row{grid-template-columns:1fr}}
form.contact label{display:flex;flex-direction:column;gap:6px;font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-mute)}
form.contact input[type=text],form.contact input[type=email],form.contact textarea{font-family:var(--hebrew);font-size:16px;color:var(--ink);background:var(--paper);border:1px solid var(--rule-strong);padding:14px 16px;outline:none;transition:border-color .2s;border-radius:0}
form.contact input:focus,form.contact textarea:focus{border-color:var(--accent)}
form.contact textarea{resize:vertical;min-height:140px;line-height:1.6}
form.contact .check{display:flex;align-items:center;gap:10px;font-family:var(--hebrew);font-size:15px;color:var(--ink-soft);text-transform:none;letter-spacing:0;cursor:pointer}
form.contact .check input{width:18px;height:18px;accent-color:var(--accent)}
form.contact .honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
form.contact button{font-family:var(--sans);font-size:12.5px;text-transform:uppercase;letter-spacing:.18em;padding:18px 32px;background:var(--ink);color:var(--paper);border:0;cursor:pointer;transition:background .2s;align-self:flex-start}
form.contact button:hover{background:var(--accent)}
form.contact button:disabled{opacity:.5;cursor:not-allowed}
form.contact .status{font-family:var(--latin);font-style:italic;font-size:15px;min-height:24px}
form.contact .status.ok{color:#2A6B3A}
form.contact .status.err{color:var(--accent)}

/* Footer */
.foot{padding:32px 0 28px;border-top:1px solid var(--rule-strong);font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-mute)}
.foot .container{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center}
.foot .left{justify-self:start}
.foot .center{justify-self:center;display:flex;align-items:center;gap:12px}
.foot .right{justify-self:end}
.foot a{color:var(--ink-soft)}
.foot a:hover{color:var(--accent)}
@media (max-width:720px){.foot .container{grid-template-columns:1fr;text-align:center;gap:10px}.foot .left,.foot .center,.foot .right{justify-self:center}}

/* ===== Sub-page templates ===== */

/* ===== Mobile layout safety net (tablets and phones) ===== */
/* CSS Grid items have min-width:auto by default which means they refuse to shrink
   below their content's intrinsic min-width. On long Hebrew text or fixed-width
   children (covers, the writing-mode .vol element), this can push grid columns
   wider than the viewport and create the "content squeezed into a narrow strip"
   bug we kept hitting. Setting min-width:0 lets them shrink naturally. */
.hero-grid > *, .catalog-row > *, .section-head > *, .awards-list > *, .award-row > *,
.book-grid > *, .book-intro-grid > *, .about-grid > *, .contact-grid > *,
.stories-grid > *, .story-card > *, .masthead-inner > * {
  min-width: 0;
}

@media (max-width: 880px) {
  /* Phones + small tablets: force ALL multi-column layouts to a single full-width
     stack. We were relying on per-component @media rules, but several rules left
     decorative children at fixed grid positions that pushed the layout off-canvas
     on RTL phones. Sledgehammer the whole thing here. */
  .hero-grid, .catalog-row, .stories-grid, .awards-list,
  .book-grid, .book-intro-grid, .about-grid, .contact-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .section-head { grid-template-columns: 1fr !important; gap: 6px !important; }
  .award-row    { grid-template-columns: 1fr !important; gap: 4px !important; }
  /* Span-all-columns so previously-placed children don't get stranded in col 1. */
  .catalog-cover, .catalog-body, .catalog-action,
  .story-card.s1, .story-card.s2, .story-card.s3, .story-card.s4 {
    grid-column: 1 / -1 !important;
  }
  /* Decorative writing-mode element on the desktop hero — hidden + neutralized. */
  .hero-side { display: none !important; }
  /* Decorative outsize Roman numeral that pokes outside the poem frame on the
     desktop layout — keep but make sure it can't push the container's intrinsic width. */
  .hero-poem-frame::before { font-size: 28px; right: 4px; top: -4px; }
  /* Tighten gutter on phones so prose actually has breathing room. */
  .container { padding-left: 16px !important; padding-right: 16px !important; }
}

/* ===== Narrow-viewport adjustments (phones, ~480px and below) ===== */
@media (max-width: 480px) {
  :root { --gutter: 18px; }
  .container, .container-narrow, .container-medium { padding: 0 18px; }
  /* Hero typography */
  .hero { padding: 36px 0 32px; }
  .hero-poem-frame { padding: 0 6px; }
  .hero-poem-frame::before { font-size: 32px; top: -8px; right: -4px; }
  .hero-poem-title { font-size: 16px; margin-bottom: 22px; }
  .hero-poem-body { font-size: 22px !important; line-height: 1.72 !important; letter-spacing: 0 !important; }
  .author-block .name { font-size: 30px; }
  .author-block .name-en { font-size: 16px; }
  .portrait-frame, .portrait-caption { width: 200px; }
  .portrait-frame img { height: 250px; }
  /* Section headers + catalog tweaks */
  .section { padding: 48px 0; }
  .section-head { margin-bottom: 28px; padding-bottom: 14px; }
  .section-head h2 { font-size: 30px; }
  .section-head .sub { font-size: 14px; }
  .catalog-row { gap: 14px; padding: 28px 0; grid-template-columns: 64px 1fr; }
  .catalog-num { font-size: 38px; }
  .catalog-cover img, .catalog-cover.placeholder { width: 110px; height: auto; }
  .catalog-cover.placeholder { height: 165px; font-size: 18px; padding: 12px; }
  .catalog-body h3 { font-size: 24px; }
  .catalog-body blockquote { font-size: 15px; padding-right: 12px; }
  /* Book intro on phones */
  .book-intro-grid img.cover, .book-intro-grid .cover.placeholder { max-width: 180px; }
  .book-intro-grid .cover.placeholder { height: 270px; font-size: 30px; }
  .page-header { padding: 36px 0 28px; }
  .page-header h1 { font-size: clamp(28px, 7vw, 40px); }
  .page-header .subtitle { font-size: 16px; }
  /* TOC fits one column at phone widths */
  .toc ol { columns: 1; }
  /* Poem reading */
  .poem { margin-bottom: 48px; padding-bottom: 28px; }
  .poem h3 { font-size: 21px; }
  .poem .body { font-size: 18px !important; line-height: 1.85 !important; }
  /* Awards */
  .awards-ledger .award-row { gap: 4px; padding: 22px 0; }
  .award-row .yr { font-size: 32px; }
  .award-row .title { font-size: 18px; }
  /* Footer wraps cleanly */
  .foot .container { gap: 6px; }
  .foot { padding: 22px 0 18px; font-size: 10px; }
  /* Purchase block */
  .purchase { padding: 56px 0; }
  .purchase h3 { font-size: 26px; }
  .purchase .links a { padding: 14px 22px; font-size: 11.5px; }
}

/* Page header (sub-pages) */
.page-header{padding:64px 0 48px;border-bottom:1px solid var(--rule)}
.page-header .breadcrumb{font-family:var(--sans);font-size:10.5px;text-transform:uppercase;letter-spacing:.22em;color:var(--ink-mute);margin-bottom:18px}
.page-header .breadcrumb a{color:var(--ink-soft)}
.page-header .breadcrumb a:hover{color:var(--accent)}
.page-header .breadcrumb .sep{color:var(--ink-faint);margin:0 10px}
.page-header h1{font-family:var(--hebrew);font-weight:700;font-size:clamp(40px,5.5vw,72px);letter-spacing:-0.03em;line-height:1.02;margin-bottom:14px}
.page-header .subtitle{font-family:var(--latin);font-style:italic;font-size:22px;color:var(--ink-mute);margin-bottom:8px}
.page-header .meta{font-family:var(--sans);font-size:11.5px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-mute);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.page-header .meta .dot{color:var(--ink-faint);font-size:9px}

/* Book page: cover + intro */
.book-intro{padding:64px 0 80px;border-bottom:1px solid var(--rule)}
.book-intro-grid{display:grid;grid-template-columns:280px 1fr;gap:80px;align-items:start}
@media (max-width:780px){.book-intro-grid{grid-template-columns:1fr;gap:40px}.book-intro-grid img.cover{margin:0 auto;max-width:240px}}
.book-intro-grid img.cover{width:280px;height:auto;filter:drop-shadow(0 16px 32px rgba(26,24,20,0.3))}
.book-intro-grid .cover.placeholder{width:280px;height:420px;background:linear-gradient(170deg,#4A2018,#2A1410);display:flex;align-items:center;justify-content:center;color:var(--paper);font-family:var(--hebrew);font-weight:700;font-size:42px;line-height:1.15;text-align:center;padding:32px;filter:drop-shadow(0 16px 32px rgba(26,24,20,0.3))}
.book-intro p{font-family:var(--hebrew);font-size:18px;line-height:1.85;color:var(--ink);margin-bottom:16px}
.book-intro blockquote{font-family:var(--hebrew);font-style:italic;font-size:18px;line-height:1.75;color:var(--ink-soft);border-right:2px solid var(--accent);padding-right:20px;margin:24px 0 8px}
.book-intro cite{font-family:var(--latin);font-style:italic;font-size:14px;color:var(--ink-mute);display:block;margin-bottom:24px}

/* Table of contents */
.toc{padding:48px 0;border-bottom:1px solid var(--rule);background:var(--paper-2)}
.toc h2{font-family:var(--hebrew);font-weight:500;font-size:24px;margin-bottom:24px;display:flex;align-items:baseline;gap:14px}
.toc h2 .num{font-family:var(--latin);font-style:italic;color:var(--accent);font-size:16px}
.toc ol{list-style:none;counter-reset:poem;columns:2;column-gap:48px}
@media (max-width:720px){.toc ol{columns:1}}
.toc ol li{counter-increment:poem;padding:6px 0;font-size:15.5px;line-height:1.5;break-inside:avoid;display:grid;grid-template-columns:32px 1fr;gap:8px;align-items:baseline}
.toc ol li::before{content:counter(poem,upper-roman) ".";font-family:var(--latin);font-style:italic;color:var(--accent);font-size:13px;letter-spacing:.04em}
.toc ol li a{color:var(--ink-soft)}
.toc ol li a:hover{color:var(--accent)}

/* Poems on book pages */
.poems-wrap{padding:64px 0}
.poem{
  max-width:680px;margin:0 auto 80px;
  padding-bottom:48px;border-bottom:1px solid var(--rule);
}
.poem:last-child{border-bottom:0;margin-bottom:0}
.poem .ix{font-family:var(--latin);font-style:italic;color:var(--accent);font-size:14px;letter-spacing:.04em;margin-bottom:14px}
.poem h3{font-family:var(--hebrew);font-weight:500;font-size:26px;letter-spacing:-0.015em;line-height:1.2;margin-bottom:24px;color:var(--ink)}
.poem .body{font-family:var(--hebrew-light);font-weight:400;font-size:21px;line-height:1.7;color:var(--ink);white-space:pre-line}
.poem .body em{font-style:italic;color:var(--ink-soft)}
.poem .ornament{display:flex;justify-content:center;margin-top:32px}
.poem .ornament span{color:var(--accent);font-size:12px;letter-spacing:.6em}

/* Story page */
.story-page{padding:64px 0 96px}
.story-page .story-body{
  max-width:680px;margin:0 auto;
  font-family:var(--hebrew);font-size:19px;line-height:1.95;color:var(--ink);
}
.story-page .story-body p{margin-bottom:24px;text-align:justify}
.story-page .story-body p:first-of-type::first-letter{font-family:var(--latin);font-style:italic;font-weight:500;float:right;font-size:72px;line-height:0.85;color:var(--accent);margin-left:10px;margin-top:8px}
.story-page .story-body h2,.story-page .story-body h3{font-family:var(--hebrew);font-weight:700;font-size:24px;margin:48px 0 20px;color:var(--ink);text-align:center;letter-spacing:-0.01em}
.story-page .story-body h3{font-size:20px;text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:1px}
.story-page .story-body blockquote{margin:24px 0;padding-right:20px;border-right:2px solid var(--accent);font-style:italic;color:var(--ink-soft)}
.story-page .story-meta{display:flex;justify-content:center;gap:14px;margin-bottom:48px;font-family:var(--sans);font-size:11.5px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-mute)}
.story-page .story-meta .award{color:var(--accent);font-family:var(--latin);font-style:italic;text-transform:none;letter-spacing:0;font-size:14px}
.story-page .ornament{display:flex;justify-content:center;margin:48px auto}
.story-page .ornament span{color:var(--accent);font-size:14px;letter-spacing:.6em}

/* Back to top + page nav */
.page-nav{
  position:sticky;top:0;z-index:20;
  background:rgba(245,241,232,0.92);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--rule);
  padding:12px 0;
}
.page-nav .container{display:flex;justify-content:space-between;align-items:center;gap:18px}
.page-nav .back{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-soft)}
.page-nav .here{font-family:var(--latin);font-style:italic;font-size:14px;color:var(--ink-mute)}
