:root {
  --cream: #f6f2e8;
  --paper: #fffdf8;
  --ink: #163936;
  --ink-deep: #0d2a28;
  --ink-soft: #4a615e;
  --gold: #98753b;
  --gold-deep: #755628;
  --gold-soft: #e2d3b1;
  --stone: #a7aaa1;
  --line: #d8d2c4;
  --line-dark: #b9b3a5;
  --success: #2f6850;
  --warning: #7b552b;
  --shadow: 0 14px 38px rgba(13, 42, 40, .08);
  --serif: Georgia, "Times New Roman", serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream); color: var(--ink); font-family: var(--sans); font-size: 1rem; line-height: 1.65; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 3px solid #b3873e; outline-offset: 3px; }
.skip-link { position: fixed; left: 1rem; top: -5rem; z-index: 100; background: var(--ink-deep); color: white; padding: .75rem 1rem; text-decoration: none; }
.skip-link:focus { top: 1rem; }
.container { width: min(1120px, calc(100% - 2rem)); margin-inline: auto; }
.narrow { width: min(760px, calc(100% - 2rem)); margin-inline: auto; }

.site-header { position: relative; z-index: 20; background: rgba(246, 242, 232, .98); border-bottom: 1px solid rgba(22, 57, 54, .16); }
.site-header::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px; background: linear-gradient(90deg, transparent, rgba(152,117,59,.65) 18%, rgba(22,57,54,.22) 50%, rgba(152,117,59,.65) 82%, transparent); pointer-events: none; }
.nav-wrap { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.brand { display: inline-flex; align-items: center; gap: .7rem; color: var(--ink-deep); text-decoration: none; font-family: var(--serif); font-size: 1.22rem; line-height: 1.2; letter-spacing: -.01em; }
.brand-mark { position: relative; display: grid; place-items: center; width: 36px; height: 36px; border: 1px solid var(--gold); color: var(--gold-deep); font-size: 1rem; box-shadow: inset 0 0 0 3px var(--cream), inset 0 0 0 4px rgba(152,117,59,.3); }
.brand-mark::before, .brand-mark::after { content: ""; position: absolute; top: 5px; bottom: 5px; width: 1px; background: var(--gold); opacity: .8; }
.brand-mark::before { left: 6px; transform: rotate(28deg); }
.brand-mark::after { right: 6px; transform: rotate(-28deg); }
.site-nav { display: flex; align-items: center; gap: .1rem; }
.site-nav a { padding: .65rem .62rem; border-bottom: 2px solid transparent; text-decoration: none; font-size: 1rem; font-weight: 650; }
.site-nav a:hover { color: var(--gold); }
.site-nav a[aria-current="page"] { border-color: var(--gold); color: var(--ink-deep); }
.menu-button { display: none; min-height: 44px; border: 1px solid var(--line-dark); background: var(--paper); color: var(--ink); padding: .55rem .8rem; font-weight: 700; }

main { min-height: 65vh; }
.hero { position: relative; isolation: isolate; overflow: hidden; padding: 4.75rem 0 4rem; }
.hero::before { content: ""; position: absolute; z-index: -1; top: -95px; right: max(-130px, calc((100vw - 1120px) / 2 - 150px)); width: 370px; height: 370px; border: 1px solid rgba(152,117,59,.17); border-radius: 50%; background: repeating-conic-gradient(from 45deg, rgba(22,57,54,.045) 0 2deg, transparent 2deg 20deg); opacity: .7; transform: rotate(11deg); pointer-events: none; }
.hero::after { content: ""; position: absolute; z-index: -1; left: max(1rem, calc((100vw - 1120px) / 2)); bottom: 0; width: min(330px, 42vw); height: 24px; background: repeating-linear-gradient(90deg, transparent 0 13px, rgba(152,117,59,.34) 13px 14px, transparent 14px 18px), linear-gradient(rgba(22,57,54,.2), rgba(22,57,54,.2)) center / 100% 1px no-repeat; opacity: .7; pointer-events: none; }
.home-hero { padding: 4.25rem 0 3rem; background: var(--cream); }
.hero-intro { max-width: 850px; }
.hero-layout { display: grid; grid-template-columns: minmax(0, 3fr) minmax(250px, 1fr); align-items: end; gap: clamp(2rem, 6vw, 6rem); }
.eyebrow { margin: 0 0 .8rem; color: var(--gold); font-size: .82rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
h1, h2, h3 { margin-top: 0; color: var(--ink-deep); font-family: var(--serif); font-weight: 400; line-height: 1.12; }
h1 { max-width: 820px; margin-bottom: 1.2rem; font-size: clamp(3rem, 6.5vw, 5.7rem); letter-spacing: -.045em; }
.page-hero { padding: 4.8rem 0 3.6rem; border-bottom: 1px solid var(--line); }
.page-hero h1 { font-size: clamp(2.7rem, 6vw, 4.8rem); }
h2 { margin-bottom: 1rem; font-size: clamp(2rem, 4vw, 3.15rem); letter-spacing: -.025em; }
h3 { font-size: 1.45rem; }
.hero-copy, .lead { max-width: 720px; color: var(--ink-soft); font-size: clamp(1.08rem, 2vw, 1.24rem); }
.actions { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 2rem; }
.button { display: inline-flex; min-height: 48px; align-items: center; justify-content: center; border: 1px solid var(--ink); background: var(--ink); color: white; padding: .75rem 1.2rem; text-decoration: none; font-weight: 750; cursor: pointer; }
.button:hover { background: var(--ink-deep); }
.button-secondary { background: var(--paper); color: var(--ink); }
.button-secondary:hover { background: white; border-color: var(--gold); }
.button-gold { background: var(--gold-soft); border-color: var(--gold-soft); color: var(--ink-deep); }
.button-gold:hover { background: #eddfbd; }
.trust-summary { padding: 1.5rem 0 1.5rem 1.5rem; border-left: 2px solid var(--gold); }
.trust-summary strong { font-family: var(--serif); font-size: 1.25rem; font-weight: 400; }
.trust-summary p { margin: .5rem 0 0; color: var(--ink-soft); font-size: .95rem; }

.finder-section { padding: 0 0 1rem; }
.hero-finder { max-width: 900px; margin-top: 1.8rem; padding: 1.4rem; background: var(--ink-deep); color: white; box-shadow: var(--shadow); }
.hero-finder label, .hero-finder legend { color: white; }
.hero-finder input { min-height: 56px; font-size: 1.05rem; }
.home-chip-fieldset { margin: 1rem 0 0; padding: 0; border: 0; }
.home-chip-fieldset legend { margin-bottom: .5rem; font-size: .88rem; font-weight: 750; }
.home-filter-chips { display: flex; flex-wrap: wrap; gap: .5rem; }
.home-filter-chip { min-height: 42px; border: 1px solid rgba(255,255,255,.38); border-radius: 999px; background: transparent; color: white; padding: .45rem .8rem; font-weight: 700; cursor: pointer; }
.home-filter-chip:hover { background: rgba(255,255,255,.1); border-color: white; }
.home-filter-chip.is-active { border-color: var(--gold-soft); background: var(--gold-soft); color: var(--ink-deep); }
.home-filter-chip.is-active::before { content: "\2713"; margin-right: .4rem; }
.hero-browse { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: 1rem; }
.hero-browse .button { min-height: 46px; }
.trust-strip { background: #eee7d8; border-block: 1px solid var(--line); }
.trust-strip p { margin: 0; padding: .9rem 0; color: var(--ink-soft); font-size: .95rem; }
.trust-strip strong { color: var(--ink-deep); }
.home-full-text-section { background: var(--paper); }
.home-full-text-section .section-heading { align-items: center; }
.home-full-text-section .section-intro { max-width: 650px; }
.home-full-text-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.home-full-text-card { position: relative; display: flex; min-height: 390px; flex-direction: column; justify-content: space-between; gap: 1.25rem; padding: 1.4rem; border: 1px solid var(--line); border-top: 3px solid var(--gold); background: var(--cream); }
.home-full-text-card::after { content: ""; position: absolute; top: 0; right: 0; width: 68px; height: 68px; background: url("/assets/irish/transparent_corner_knot.png") top right / contain no-repeat; opacity: .13; pointer-events: none; }
.home-full-text-card h3 { max-width: 90%; margin-bottom: .35rem; font-size: 1.7rem; }
.home-full-text-card .description { margin: 0 0 1.1rem; }
.full-text-label { display: flex; align-items: center; gap: .45rem; width: fit-content; margin: 0 0 1rem; color: #245b47; font-size: .78rem; font-weight: 800; letter-spacing: .045em; text-transform: uppercase; }
.full-text-label::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #245b47; }
.home-poem-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .55rem; }
.home-poem-tags span { padding: .2rem .5rem; border: 1px solid var(--gold-soft); background: var(--paper); color: var(--ink-soft); font-size: .78rem; font-weight: 700; }
.home-poem-tags.theme-tags span { border-color: var(--line-dark); background: transparent; }
.home-full-text-card .card-button { width: 100%; background: var(--ink-deep); color: white; }
.home-full-text-card .card-button:hover { background: var(--ink); }
.guide-hero { padding-block: 4rem 3.25rem; }
.guide-hero-inner { position: relative; display: grid; grid-template-columns: minmax(0, 1fr) 250px; align-items: center; gap: 3rem; }
.guide-hero-inner > div { position: relative; z-index: 1; }
.guide-hero-inner img { width: 250px; height: 220px; object-fit: contain; opacity: .13; mix-blend-mode: multiply; }
.guide-hero-inner .guide-medallion { width: 220px; height: 220px; opacity: .1; }
.guide-intro-section { padding-block: 3.25rem; }
.guide-prose-grid { display: grid; grid-template-columns: minmax(0, 1.7fr) minmax(260px, .8fr); gap: 3rem; align-items: start; }
.guide-prose-grid h2 { font-size: clamp(1.9rem, 4vw, 2.7rem); }
.guide-prose-grid p { max-width: 760px; color: var(--ink-soft); font-size: 1.04rem; }
.guide-note { padding: 1.3rem; border-left: 3px solid var(--gold); background: var(--paper); }
.guide-note strong { color: var(--ink-deep); font-family: var(--serif); font-size: 1.25rem; font-weight: 500; }
.guide-note p { margin-bottom: 0; font-size: .96rem; }
.guide-poem-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.guide-three-grid { grid-template-columns: repeat(3, 1fr); }
.guide-poem-card { position: relative; display: flex; min-height: 350px; flex-direction: column; justify-content: space-between; gap: 1.25rem; padding: 1.35rem; border: 1px solid var(--line); border-top: 3px solid var(--gold); background: var(--paper); }
.guide-poem-card::after { content: ""; position: absolute; top: 0; right: 0; width: 62px; height: 62px; background: url("/assets/irish/transparent_corner_knot.png") top right / contain no-repeat; opacity: .11; pointer-events: none; }
.guide-poem-card h3 { max-width: 88%; margin: .75rem 0 .3rem; font-size: 1.65rem; }
.guide-poem-card > div > p:not(.poet):not(.guide-status) { color: var(--ink-soft); }
.guide-status { display: inline-flex; min-height: 30px; align-items: center; gap: .4rem; width: fit-content; margin: 0; padding: .2rem .5rem; border: 1px solid currentColor; font-size: .74rem; font-weight: 800; text-transform: uppercase; }
.guide-status::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.guide-status.status-full { color: #245b47; background: #edf5f0; }
.guide-status.status-commentary { color: var(--ink-soft); background: var(--cream); }
.guide-status.status-check { color: #725a1d; background: #fbf4df; }
.guide-card-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1rem; }
.guide-card-tags span { padding: .2rem .5rem; border: 1px solid var(--gold-soft); color: var(--ink-soft); font-size: .78rem; font-weight: 700; }
.guide-poem-card .card-button { width: 100%; }
.guide-links-panel { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 1fr); gap: 2.5rem; padding: 2rem; background: var(--ink-deep); color: white; }
.guide-links-panel h2 { color: white; }
.guide-links-panel p:not(.eyebrow) { color: #d7e0dd; }
.guide-links-panel nav { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; align-content: center; }
.guide-links-panel nav a { display: flex; min-height: 48px; align-items: center; padding: .55rem .75rem; border: 1px solid rgba(255,255,255,.42); color: white; font-weight: 700; text-decoration: none; }
.guide-links-panel nav a:hover { background: white; color: var(--ink-deep); }
.guide-theme-links { display: flex; flex-wrap: wrap; gap: .65rem; }
.guide-theme-links a { display: inline-flex; min-height: 46px; align-items: center; padding: .5rem .8rem; border: 1px solid var(--line-dark); background: var(--paper); color: var(--ink-deep); font-weight: 700; text-decoration: none; }
.guide-theme-links a:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.copyright-guide-note { position: relative; max-width: 900px; padding-left: 1.5rem; border-left: 3px solid var(--gold); }
.copyright-guide-note h2 { font-size: clamp(1.75rem, 3vw, 2.3rem); }
.copyright-guide-note p { color: var(--ink-soft); }
.candidate-link-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .7rem; }
.candidate-link-grid a { display: flex; min-height: 105px; flex-direction: column; justify-content: center; padding: 1rem; border: 1px solid var(--line); background: var(--paper); text-decoration: none; }
.candidate-link-grid a:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.candidate-link-grid strong { color: var(--ink-deep); font-family: var(--serif); font-size: 1.12rem; font-weight: 500; }
.candidate-link-grid span { color: var(--ink-soft); font-size: .86rem; }
.helpful-guides-section { padding-block: 2.75rem; background: var(--paper); }
.helpful-guides-section h2 { margin-bottom: 1.25rem; font-size: clamp(1.75rem, 3vw, 2.35rem); }
.helpful-guide-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: .7rem; }
.helpful-guide-links a { display: flex; min-height: 58px; align-items: center; padding: .75rem 1rem; border: 1px solid var(--line); background: var(--cream); color: var(--ink-deep); font-weight: 750; text-decoration: none; }
.helpful-guide-links a:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.search-panel { margin-top: -1rem; padding: clamp(1.5rem, 4vw, 2.5rem); background: var(--ink-deep); color: white; box-shadow: var(--shadow); }
.search-panel h2 { max-width: 650px; margin-bottom: .45rem; color: white; font-size: clamp(1.8rem, 3vw, 2.65rem); }
.search-panel .eyebrow { color: #d8bd83; }
.search-panel p { margin-top: 0; color: #d7e0dd; }
.home-search-form { margin-top: 1.5rem; }
.search-panel label { color: white; }
.search-row { display: grid; grid-template-columns: 1fr auto; gap: .65rem; }
.quick-links { display: flex; flex-wrap: wrap; align-items: center; gap: .55rem; margin-top: 1rem; color: #d7e0dd; font-size: .92rem; }
.quick-links a { min-height: 36px; display: inline-flex; align-items: center; padding: .25rem .7rem; border: 1px solid rgba(255,255,255,.32); color: white; text-decoration: none; }
.quick-links a:hover { background: white; color: var(--ink-deep); }

.section { padding: 3.75rem 0; }
.section-alt { background-color: var(--paper); background-image: linear-gradient(135deg, rgba(152,117,59,.018) 25%, transparent 25%, transparent 75%, rgba(22,57,54,.014) 75%); background-size: 28px 28px; border-block: 1px solid rgba(22, 57, 54, .1); }
.section-heading { position: relative; display: flex; justify-content: space-between; align-items: end; gap: 2rem; margin-bottom: 2rem; padding-bottom: 1rem; }
.section-heading::after { content: ""; position: absolute; left: 0; bottom: 0; width: min(290px, 48vw); height: 9px; background: repeating-linear-gradient(90deg, transparent 0 12px, rgba(152,117,59,.55) 12px 13px, transparent 13px 17px), linear-gradient(rgba(22,57,54,.25), rgba(22,57,54,.25)) center / 100% 1px no-repeat; }
.section-heading h2 { margin-bottom: 0; }
.text-link { font-weight: 700; text-underline-offset: .25em; text-decoration-color: var(--gold); }
.text-link:hover { color: var(--gold); }
.path-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.path-card { display: flex; flex-direction: column; justify-content: space-between; gap: 1.2rem; min-height: 240px; padding: 1.5rem; background: var(--paper); border: 1px solid var(--line); }
.path-card:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.path-label, .card-number { color: var(--gold); font-family: var(--serif); font-style: italic; }
.path-card h3 { margin: .05rem 0 .65rem; font-size: 1.7rem; }
.path-card p { margin: 0 0 1rem; color: var(--ink-soft); }
.path-card .card-button { width: 100%; }
.card-link { display: inline-block; margin-top: auto; color: var(--ink); font-size: .92rem; font-weight: 750; }

.card-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.card { display: flex; flex-direction: column; min-height: 250px; padding: 1.4rem; background: var(--cream); border: 1px solid var(--line); text-decoration: none; }
.card:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.card h3 { margin: 2.5rem 0 .55rem; }
.card p { margin: 0 0 1.2rem; color: var(--ink-soft); font-size: .95rem; }
.card .card-link { margin-top: auto; }
:where(.path-card, .card, .category-card, .featured-occasion-card, .occasion-directory-card, .featured-theme-card, .theme-directory-card, .featured-mood-card, .mood-directory-card, .directory-poet-card, .compact-poet-card, .poem-card, .public-domain-use-card, .verification-source-list a) { position: relative; }
:where(.path-card, .card, .category-card, .featured-occasion-card, .occasion-directory-card, .featured-theme-card, .theme-directory-card, .featured-mood-card, .mood-directory-card, .directory-poet-card, .compact-poet-card, .poem-card, .public-domain-use-card, .verification-source-list a)::after { content: ""; position: absolute; top: 9px; right: 9px; width: 21px; height: 21px; border-top: 1px solid rgba(152,117,59,.55); border-right: 1px solid rgba(152,117,59,.55); background: linear-gradient(45deg, transparent 45%, rgba(152,117,59,.24) 46% 49%, transparent 50%); pointer-events: none; transition: transform .18s ease, border-color .18s ease; }
:where(.path-card, .card, .category-card, .featured-occasion-card, .occasion-directory-card, .featured-theme-card, .theme-directory-card, .featured-mood-card, .mood-directory-card, .directory-poet-card, .compact-poet-card, .poem-card, .public-domain-use-card, .verification-source-list a):hover::after { border-color: var(--gold); transform: translate(-2px, 2px); }
.category-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.category-card { display: flex; min-height: 210px; flex-direction: column; padding: 1.4rem; background: var(--cream); border: 1px solid var(--line); text-decoration: none; }
.category-card:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.category-card h2 { margin-bottom: .6rem; font-size: 1.55rem; }
.category-card p { margin: 0 0 1rem; color: var(--ink-soft); }
.category-card span { margin-top: auto; font-weight: 750; text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: .25em; }
.related-panel { padding: 1.5rem; border-left: 3px solid var(--gold); background: var(--paper); }
.related-panel h2 { font-size: 1.8rem; }
.related-panel a { font-weight: 700; text-decoration-color: var(--gold); text-underline-offset: .2em; }
.poet-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.poet-card { display: flex; min-height: 300px; flex-direction: column; padding: 1.5rem; background: var(--cream); border: 1px solid var(--line); }
.poet-card h2 { font-size: 1.65rem; }
.poet-card .card-button { margin-top: auto; }
.guide-grid { display: grid; grid-template-columns: 2fr 1fr; align-items: start; gap: 2rem; }
.occasions-hero .hero-copy { max-width: 860px; }
.featured-occasions { background: var(--cream); }
.featured-occasion-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
.featured-occasion-card { display: flex; min-height: 340px; flex-direction: column; padding: 1.6rem; background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); }
.featured-occasion-card h3 { margin-bottom: .65rem; font-size: 1.9rem; }
.featured-occasion-card p { color: var(--ink-soft); }
.occasion-label { margin: 0 0 .5rem; color: var(--gold) !important; font-size: .8rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.featured-occasion-card .card-button { margin-top: auto; }
.related-links { display: flex; flex-wrap: wrap; gap: .4rem .7rem; align-items: center; margin-top: 1rem; color: var(--ink-soft); font-size: .9rem; }
.related-links span { font-weight: 750; }
.related-links a { min-height: 32px; display: inline-flex; align-items: center; font-weight: 700; text-decoration-color: var(--gold); text-underline-offset: .2em; }
.occasion-directory-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .85rem; }
.occasion-directory-card { display: flex; min-height: 215px; flex-direction: column; padding: 1.25rem; background: var(--cream); border: 1px solid var(--line); text-decoration: none; }
.occasion-directory-card:hover { border-color: var(--gold); background: var(--paper); box-shadow: var(--shadow); }
.occasion-directory-card h3 { margin-bottom: .55rem; font-size: 1.42rem; }
.occasion-directory-card p { margin: 0 0 1rem; color: var(--ink-soft); font-size: .96rem; }
.occasion-directory-card span { margin-top: auto; font-weight: 750; text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: .22em; }
.nature-links-section { padding-block: 2.5rem; }
.guidance-section { padding-top: 1rem; }
.guidance-card { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(280px, 1fr); align-items: center; gap: 2.5rem; padding: 2rem; background: var(--ink-deep); color: white; }
.guidance-card h2 { color: white; }
.guidance-card p:not(.eyebrow) { max-width: 700px; color: #d7e0dd; }
.guidance-actions { display: grid; gap: .65rem; }
.guidance-card .button-secondary { border-color: rgba(255,255,255,.7); background: transparent; color: white; }
.guidance-card .button-secondary:hover { background: white; color: var(--ink-deep); }
.themes-hero .hero-copy { max-width: 850px; }
.featured-themes { background: var(--cream); }
.featured-theme-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.featured-theme-card { display: flex; min-height: 355px; flex-direction: column; padding: 1.5rem; background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); }
.featured-theme-card h3 { margin-bottom: .65rem; font-size: 1.85rem; }
.featured-theme-card p { color: var(--ink-soft); }
.featured-theme-card .card-button { margin-top: auto; }
.theme-directory-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .85rem; }
.theme-directory-card { display: flex; min-height: 210px; flex-direction: column; padding: 1.2rem; background: var(--cream); border: 1px solid var(--line); text-decoration: none; }
.theme-directory-card:hover { border-color: var(--gold); background: var(--paper); box-shadow: var(--shadow); }
.theme-directory-card h3 { margin-bottom: .5rem; font-size: 1.4rem; }
.theme-directory-card p { margin: 0 0 1rem; color: var(--ink-soft); font-size: .96rem; }
.theme-directory-card span { margin-top: auto; font-weight: 750; text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: .22em; }
.moods-hero .hero-copy { max-width: 870px; }
.featured-moods { background: var(--cream); }
.featured-mood-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.featured-mood-card { display: flex; min-height: 365px; flex-direction: column; padding: 1.5rem; background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); }
.featured-mood-card h3 { margin-bottom: .65rem; font-size: 1.8rem; }
.featured-mood-card p { color: var(--ink-soft); }
.featured-mood-card .card-button { margin-top: auto; }
.mood-directory-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .85rem; }
.mood-directory-card { display: flex; min-height: 210px; flex-direction: column; padding: 1.2rem; background: var(--cream); border: 1px solid var(--line); text-decoration: none; }
.mood-directory-card:hover { border-color: var(--gold); background: var(--paper); box-shadow: var(--shadow); }
.mood-directory-card h3 { margin-bottom: .5rem; font-size: 1.4rem; }
.mood-directory-card p { margin: 0 0 1rem; color: var(--ink-soft); font-size: .96rem; }
.mood-directory-card span { margin-top: auto; font-weight: 750; text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: .22em; }
.poets-hero .hero-copy { max-width: 900px; }
.section-intro { max-width: 720px; margin: .7rem 0 0; color: var(--ink-soft); }
.featured-poet-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.modern-poet-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.directory-poet-card { display: flex; min-height: 360px; flex-direction: column; padding: 1.4rem; background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); }
.modern-poets-section .directory-poet-card { background: var(--cream); border-top-color: var(--ink-soft); }
.directory-poet-card h3 { margin-bottom: .6rem; font-size: 1.65rem; }
.directory-poet-card p { color: var(--ink-soft); }
.directory-poet-card .card-button { margin-top: auto; }
.poet-themes { font-size: .92rem; }
.poet-themes strong { color: var(--ink-deep); }
.copyright-badge { display: flex; align-items: flex-start; gap: .5rem; font-size: .88rem; font-weight: 750; }
.copyright-badge::before { content: ""; width: 9px; height: 9px; flex: 0 0 auto; margin-top: .38rem; border-radius: 50%; background: var(--warning); }
.copyright-possible::before { background: var(--success); }
.copyright-commentary::before { background: var(--ink-soft); }
.compact-poet-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .7rem; }
.compact-poet-card { display: flex; min-height: 92px; flex-direction: column; justify-content: center; gap: .25rem; padding: 1rem; background: var(--paper); border: 1px solid var(--line); text-decoration: none; }
.compact-poet-card:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.compact-poet-card strong { color: var(--ink-deep); font-family: var(--serif); font-size: 1.18rem; font-weight: 400; }
.compact-poet-card span { color: var(--ink-soft); font-size: .88rem; }
.poet-tools-section { padding: 1.25rem 0; background: var(--paper); border-bottom: 1px solid var(--line); }
.poet-directory-tools { display: grid; grid-template-columns: minmax(260px, 1fr) 2fr; align-items: end; gap: 1rem 2rem; }
.poet-search-field input { min-height: 54px; font-size: 1.02rem; }
.poet-filter-fieldset { margin: 0; padding: 0; border: 0; }
.poet-filter-fieldset legend { margin-bottom: .4rem; color: var(--ink-deep); font-size: .82rem; font-weight: 800; letter-spacing: .04em; }
.poet-tool-summary { grid-column: 1 / -1; display: flex; min-height: 38px; align-items: center; justify-content: space-between; gap: 1rem; border-top: 1px solid var(--line); }
.poet-tool-summary p { margin: .75rem 0 0; color: var(--ink-soft); font-weight: 700; }
.poet-tool-summary .clear-button { margin-top: .75rem; }
.poet-theme-links { display: flex; flex-wrap: wrap; gap: .4rem; margin: 1rem 0; }
.poet-theme-links strong { width: 100%; color: var(--ink-deep); font-size: .88rem; }
.poet-theme-links a { display: inline-flex; min-height: 34px; align-items: center; padding: .25rem .55rem; border: 1px solid var(--gold-soft); color: var(--ink); font-size: .84rem; font-weight: 700; text-decoration: none; }
.poet-theme-links a:hover { border-color: var(--gold); background: var(--cream); }
.poet-copyright-note { font-size: .88rem; }
.compact-poet-card small { color: var(--ink); font-size: .82rem; font-weight: 750; }
.poet-empty-state { margin-top: 1rem; }
[hidden] { display: none !important; }

.public-domain-hero .hero-copy { max-width: 900px; }
.copyright-caution { max-width: 820px; margin-top: 1.5rem; padding: 1rem 1.2rem; border-left: 4px solid var(--gold); background: var(--paper); }
.copyright-caution strong { color: var(--ink-deep); }
.copyright-caution p { margin: .3rem 0 0; color: var(--ink-soft); }
.public-domain-explainer h2 { margin-bottom: .8rem; }
.public-domain-count { margin: 1.25rem 0; color: var(--ink-deep); font-weight: 750; }
.public-domain-poem-card { min-height: 485px; }
.source-note { margin-top: 1rem; padding: .85rem; background: var(--cream); border-left: 3px solid var(--gold); }
.source-note strong { color: var(--ink-deep); font-size: .85rem; }
.source-note p { margin: .3rem 0 0; color: var(--ink-soft); font-size: .88rem; }
.public-domain-use-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.public-domain-use-card { display: flex; min-height: 230px; flex-direction: column; padding: 1.35rem; background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); text-decoration: none; }
.public-domain-use-card:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.public-domain-use-card h3 { margin-bottom: .55rem; font-size: 1.45rem; }
.public-domain-use-card p { margin: 0 0 1rem; color: var(--ink-soft); }
.public-domain-use-card span { margin-top: auto; color: var(--ink-deep); font-weight: 750; text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: .22em; }
.verification-layout { display: grid; grid-template-columns: minmax(260px, .8fr) minmax(0, 1.2fr); gap: 3rem; align-items: start; }
.verification-checklist { margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--line); }
.verification-checklist li { position: relative; padding: .9rem .5rem .9rem 2rem; border-bottom: 1px solid var(--line); color: var(--ink-soft); }
.verification-checklist li::before { content: "\2713"; position: absolute; left: .35rem; color: var(--ink-deep); font-weight: 800; }
.verification-disclaimer { padding: .85rem 1rem; border-left: 3px solid var(--gold); background: var(--paper); color: var(--ink-deep); }
.verification-sources-layout { display: grid; grid-template-columns: minmax(260px, .8fr) minmax(0, 1.2fr); gap: 3rem; align-items: start; }
.verification-source-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: .7rem; margin: 0; padding: 0; list-style: none; }
.verification-source-list a { display: flex; min-height: 92px; flex-direction: column; justify-content: center; padding: 1rem; border: 1px solid var(--line); background: var(--cream); color: var(--ink-deep); font-weight: 750; text-decoration-color: var(--gold); text-underline-offset: .2em; }
.verification-source-list a:hover { border-color: var(--gold); background: var(--paper); box-shadow: var(--shadow); }
.verification-source-list span { margin-top: .3rem; color: var(--ink-soft); font-size: .82rem; font-weight: 600; }
.related-browse-links { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: 1.2rem; }
.related-browse-links a { display: inline-flex; min-height: 44px; align-items: center; padding: .55rem .8rem; border: 1px solid var(--line-dark); background: var(--paper); color: var(--ink-deep); font-weight: 700; text-decoration: none; }
.related-browse-links a:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.admin-hero { padding: 3rem 0 2.25rem; background: var(--cream); border-bottom: 1px solid var(--line); }
.admin-hero h1 { max-width: 850px; font-size: clamp(2.5rem, 6vw, 4.5rem); }
.verification-back-link { width: auto; margin-left: auto; }
.verification-admin-shell { max-width: 1500px; }
.verification-admin-summary { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; padding: .85rem 1rem; background: var(--cream); border: 1px solid var(--line); }
.verification-admin-summary p { margin: 0; color: var(--ink-deep); font-weight: 700; }
.verification-table-wrap { overflow-x: auto; border: 1px solid var(--line-dark); background: var(--paper); }
.verification-table { width: 100%; min-width: 1500px; border-collapse: collapse; font-size: .88rem; }
.verification-table caption { padding: 1rem; color: var(--ink-deep); font-family: var(--serif); font-size: 1.3rem; text-align: left; }
.verification-table th, .verification-table td { padding: .8rem; border-top: 1px solid var(--line); border-right: 1px solid var(--line); text-align: left; vertical-align: top; }
.verification-table thead th { position: sticky; top: 0; background: var(--ink-deep); color: white; font-size: .78rem; letter-spacing: .03em; }
.verification-table tbody th { min-width: 210px; color: var(--ink-deep); font-family: var(--serif); font-size: 1rem; font-weight: 600; }
.verification-table td:nth-child(2) { min-width: 160px; }
.verification-table td:nth-child(5), .verification-table td:nth-child(9) { min-width: 290px; color: var(--ink-soft); }
.verification-table tbody tr:nth-child(even) { background: var(--cream); }
.verification-table tbody tr:hover { background: #f1eadb; }
.verification-table .needs-title-review { box-shadow: inset 4px 0 0 var(--gold); }
.table-flag { display: block; width: fit-content; margin-bottom: .35rem; padding: .15rem .4rem; background: var(--gold-soft); color: var(--ink-deep); font-family: var(--sans); font-size: .7rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
.review-badge { display: inline-flex; min-height: 28px; align-items: center; padding: .2rem .5rem; border: 1px solid currentColor; font-size: .76rem; font-weight: 800; white-space: nowrap; }
.review-likelihood-yes { color: #245b47; background: #edf5f0; }
.review-likelihood-no { color: #7b332d; background: #f8edeb; }
.review-likelihood-uncertain { color: #725a1d; background: #fbf4df; }
.review-verified-no { color: #7b332d; background: #f8edeb; }
.review-verified-yes { color: #245b47; background: #edf5f0; }
.not-added { color: var(--ink-soft); font-style: italic; }
.verification-error { margin-top: 1rem; }

.poem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.poem-card { display: flex; min-height: 365px; flex-direction: column; justify-content: space-between; gap: 1.25rem; padding: 1.5rem; background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); }
.poem-card h2, .poem-card h3 { margin-bottom: .3rem; font-size: 1.65rem; }
.poem-kicker { margin: 0 0 .65rem; color: var(--gold); font-size: .78rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.poet { margin: 0 0 1rem; color: var(--ink-soft); font-family: var(--serif); font-style: italic; }
.description { color: var(--ink-soft); }
.card-button { display: inline-flex; min-height: 44px; align-items: center; justify-content: center; border: 1px solid var(--ink); color: var(--ink); padding: .6rem .9rem; text-decoration: none; font-weight: 750; }
.card-button:hover { background: var(--ink); color: white; }

.finder-main { padding: 0 0 5rem; background: var(--paper); }
.finder-hero { background: var(--paper); }
.finder-trust-note { max-width: 760px; margin: 1.2rem 0 0; padding: .8rem 1rem; border-left: 3px solid var(--gold); background: var(--cream); color: var(--ink-soft); }
.filter-panel { position: relative; top: -1px; padding: 1.5rem; background: var(--cream); border: 1px solid var(--line); }
.primary-search input { min-height: 56px; font-size: 1.05rem; }
.poem-finder-form { padding: 1.5rem; }
.finder-search-row { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; align-items: end; gap: .7rem; }
.finder-search-row input { min-height: 54px; font-size: 1.05rem; }
.finder-search-row .button { min-height: 54px; }
.finder-group { margin: 1.4rem 0 0; padding: 1.1rem 0 0; border: 0; border-top: 1px solid var(--line); }
.finder-group legend { padding: 0 .75rem 0 0; color: var(--ink-deep); font-family: var(--serif); font-size: 1.2rem; font-weight: 400; }
.finder-options { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.4rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }
.results-toolbar { display: flex; align-items: end; justify-content: space-between; gap: 1rem; padding: 1.35rem 0 .25rem; border-bottom: 1px solid var(--line); }
.active-summary { margin: 0; color: var(--ink-deep); font-weight: 750; }
.results-toolbar .result-count { margin: .25rem 0 .7rem; }
.select-filters { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1rem; }
.filter-select-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-top: 1rem; }
.checkbox-filter { display: flex; align-items: center; gap: .65rem; margin-top: 1.2rem; font-weight: 700; }
.checkbox-filter input { width: 20px; min-height: 20px; accent-color: var(--ink); }
.active-filters { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; margin-top: 1rem; color: var(--ink-soft); font-size: .9rem; }
.active-filter-chip { padding: .3rem .6rem; border: 1px solid var(--gold); background: var(--paper); color: var(--ink-deep); font-weight: 700; }
.field label, .chip-fieldset legend { display: block; margin-bottom: .4rem; color: var(--ink-deep); font-size: .82rem; font-weight: 800; letter-spacing: .04em; }
input, select, textarea { width: 100%; min-height: 48px; border: 1px solid var(--line-dark); border-radius: 0; background: white; color: var(--ink-deep); padding: .7rem .8rem; }
input::placeholder, textarea::placeholder { color: #687a77; opacity: 1; }
textarea { min-height: 160px; resize: vertical; }
.chip-fieldset { margin: 1.3rem 0 0; padding: 0; border: 0; }
.filter-chips { display: flex; flex-wrap: wrap; gap: .55rem; }
.filter-chip { min-height: 44px; border: 1px solid var(--line-dark); border-radius: 999px; background: var(--paper); color: var(--ink); padding: .48rem .9rem; font-weight: 700; cursor: pointer; }
.filter-chip:hover { border-color: var(--gold); }
.filter-chip.is-active { border-color: var(--ink); background: var(--ink); color: white; }
.filter-chip.is-active::before { content: "\2713"; margin-right: .4rem; }
.status-chip { border-style: dashed; }
.status-chip-public { border-color: var(--success); }
.filter-summary { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 52px; margin-top: 1rem; border-top: 1px solid var(--line); }
.result-count { margin: 1rem 0 0; color: var(--ink-soft); font-weight: 650; }
.clear-button { margin-top: 1rem; border: 0; background: transparent; color: var(--ink); padding: .3rem; text-decoration: underline; text-underline-offset: .25em; cursor: pointer; font-weight: 700; }
.finder-main .poem-grid { margin-top: 1.5rem; }
.finder-results .poem-card { min-height: 410px; }
.poem-meta { margin: 1rem 0; }
.meta-row { display: grid; grid-template-columns: 78px 1fr; gap: .5rem; margin: .4rem 0; font-size: .92rem; }
.meta-label { color: var(--ink-soft); font-weight: 750; }
.meta-value { color: var(--ink-deep); }
.tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: .9rem 0; }
.tag { padding: .22rem .55rem; border: 1px solid var(--gold-soft); color: var(--ink-soft); font-size: .82rem; }
.status { display: flex; gap: .5rem; align-items: flex-start; margin: 1rem 0; color: var(--ink-deep); font-size: .86rem; font-weight: 750; }
.status::before { content: ""; flex: 0 0 auto; width: 9px; height: 9px; margin-top: .38rem; border-radius: 50%; background: var(--warning); }
.status-public::before { background: var(--success); }
.empty-state { grid-column: 1 / -1; padding: 3rem 1.5rem; background: var(--cream); border: 1px solid var(--line); text-align: center; }
.empty-state h2 { margin-bottom: .5rem; font-size: 1.8rem; }
.empty-state p { color: var(--ink-soft); }

.trust-list { border-top: 1px solid var(--line); }
.trust-list p { position: relative; margin: 0; padding: 1rem 0 1rem 2rem; border-bottom: 1px solid var(--line); color: var(--ink-soft); }
.trust-list p::before { content: ""; position: absolute; left: .35rem; top: 1.55rem; width: 7px; height: 7px; border-radius: 50%; background: var(--gold); }
.note { border-left: 3px solid var(--gold); padding: 1.2rem 1.4rem; background: var(--paper); }
.prose h2 { margin-top: 2.5rem; font-size: 2rem; }
.prose a { text-decoration-color: var(--gold); text-underline-offset: .2em; }
.poem-text { position: relative; margin: 2.5rem 0; padding: 2.25rem 2rem; background: var(--paper); border: 1px solid var(--line); border-top: 2px solid var(--gold); font-family: var(--serif); font-size: 1.1rem; line-height: 1.85; white-space: pre-line; }
.poem-text::first-letter { float: left; margin: .08em .12em 0 0; color: var(--gold-deep); font-size: 3.6em; line-height: .78; text-shadow: 1px 1px 0 var(--gold-soft); }
.poem-text::after { content: ""; position: absolute; right: 10px; bottom: 10px; width: 28px; height: 28px; border-right: 1px solid rgba(152,117,59,.65); border-bottom: 1px solid rgba(152,117,59,.65); background: linear-gradient(135deg, transparent 44%, rgba(152,117,59,.28) 45% 48%, transparent 49%); pointer-events: none; }
.related-poem-links { display: flex; flex-wrap: wrap; gap: .65rem; margin: 1rem 0 2rem; }
.related-poem-links a { display: inline-flex; min-height: 44px; align-items: center; padding: .55rem .8rem; border: 1px solid var(--line-dark); background: var(--paper); color: var(--ink-deep); font-family: var(--sans); font-weight: 700; text-decoration: none; }
.related-poem-links a:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.meta-list { padding: 0; list-style: none; border-top: 1px solid var(--line); }
.meta-list li { padding: .7rem 0; border-bottom: 1px solid var(--line); }
.visually-hidden { position: absolute !important; width: 1px !important; height: 1px !important; padding: 0 !important; margin: -1px !important; overflow: hidden !important; clip: rect(0, 0, 0, 0) !important; white-space: nowrap !important; border: 0 !important; }

.poem-page-hero { padding-bottom: 3rem; }
.poem-page-hero::before { opacity: .055; }
.poem-hero-content { position: relative; }
.poem-page-status { display: inline-flex; min-height: 32px; align-items: center; margin-bottom: 1.1rem; padding: .3rem .65rem; border: 1px solid currentColor; color: var(--ink-deep); font-size: .78rem; font-weight: 800; letter-spacing: .045em; text-transform: uppercase; }
.poem-page-status::before { content: ""; width: 8px; height: 8px; margin-right: .5rem; border-radius: 50%; background: currentColor; }
.poem-page-status.is-full-text { color: #245b47; background: #edf5f0; }
.poem-page-status.is-commentary { color: var(--ink-soft); background: var(--paper); }
.poem-page-status.is-check { color: #725a1d; background: #fbf4df; }
.poem-page-hero h1 { max-width: 900px; margin-bottom: .65rem; }
.poem-byline { margin: 0; color: var(--ink-soft); font-family: var(--serif); font-size: 1.3rem; font-style: italic; }
.poem-byline a { text-decoration-color: var(--gold); text-underline-offset: .22em; }
.poem-intro { max-width: 760px; margin: 1.25rem 0 0; color: var(--ink-soft); font-size: 1.08rem; }
.poem-tag-groups { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.25rem; margin-top: 2rem; padding-top: 1.25rem; border-top: 1px solid var(--line); }
.poem-tag-groups > div > span { display: block; margin-bottom: .45rem; color: var(--ink-deep); font-size: .78rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; }
.poem-tag-groups > div > div { display: flex; flex-wrap: wrap; gap: .4rem; }
.poem-tag { display: inline-flex; min-height: 36px; align-items: center; padding: .25rem .6rem; border: 1px solid var(--gold-soft); background: rgba(255,253,248,.7); color: var(--ink); font-size: .84rem; font-weight: 700; text-decoration: none; }
.poem-tag:hover { border-color: var(--gold); background: var(--paper); }

.poem-page-body { position: relative; background: var(--paper); }
.poem-reading-column { position: relative; width: min(880px, calc(100% - 2rem)); margin-inline: auto; }
.poem-reading-column::before { content: ""; position: absolute; z-index: 0; top: 2rem; right: -190px; width: 310px; height: 240px; background: url("/assets/irish/transparent_botanical_reeds.png") center / contain no-repeat; opacity: .045; pointer-events: none; }
.poem-reading, .poem-information, .commentary-section, .related-poems-section, .poem-browse-back, .poem-rights-note { position: relative; z-index: 1; }
.poem-reading { width: min(760px, 100%); margin: 0 auto 3.5rem; }
.poem-divider { width: min(680px, 92%); height: 54px; margin: 0 auto 1.5rem; background: url("/assets/irish/transparent_divider_horizontal.png") center / contain no-repeat; opacity: .48; }
.poem-divider-after { margin: 1.5rem auto 0; transform: rotate(180deg); opacity: .34; }
.full-text-page .poem-text { margin: 0; padding: clamp(2rem, 5vw, 3.5rem); border: 0; border-inline: 1px solid rgba(152,117,59,.22); background: transparent; color: var(--ink-deep); font-size: clamp(1.16rem, 2.1vw, 1.34rem); line-height: 2.05; }
.full-text-page .poem-text::first-letter { margin-top: .12em; font-size: 3.4em; }
.full-text-page .poem-text::after { width: 72px; height: 72px; opacity: .09; }
.poem-information { margin-top: 2.5rem; padding: clamp(1.3rem, 3vw, 2rem); border: 1px solid var(--line); background: var(--cream); }
.poem-information h2 { font-size: clamp(1.65rem, 3vw, 2.15rem); }
.poem-information h3 { margin-bottom: .45rem; font-size: 1.15rem; }
.poem-information p { color: var(--ink-soft); }
.source-information-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.source-information-grid > div + div { padding-left: 2rem; border-left: 1px solid var(--line); }
.poem-rights-note { margin: 0 0 1.75rem; }
.commentary-section { max-width: 760px; }
.commentary-section h2 { margin-top: 2.4rem; font-size: clamp(1.7rem, 3vw, 2.15rem); }
.commentary-section p { color: var(--ink-soft); font-size: 1.04rem; }

.related-poems-section { margin-top: 3.5rem; padding-top: 2.5rem; border-top: 1px solid var(--line); }
.related-poems-section h2, .poem-browse-back h2 { font-size: clamp(1.7rem, 3vw, 2.2rem); }
.related-poem-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; }
.related-poem-cards a { display: flex; min-height: 145px; flex-direction: column; padding: 1rem; border: 1px solid var(--line); background: var(--cream); text-decoration: none; }
.related-poem-cards a:hover { border-color: var(--gold); box-shadow: var(--shadow); }
.related-poem-cards strong { color: var(--ink-deep); font-family: var(--serif); font-size: 1.15rem; font-weight: 500; }
.related-poem-cards span { margin-top: .25rem; color: var(--ink-soft); font-size: .9rem; }
.related-poem-cards small { margin-top: auto; padding-top: .75rem; color: var(--ink); font-size: .78rem; font-weight: 750; }
.poem-browse-back { margin-top: 3rem; padding: 1.5rem; background: var(--ink-deep); color: white; }
.poem-browse-back h2 { margin-bottom: 1rem; color: white; }
.poem-browse-back > div { display: flex; flex-wrap: wrap; gap: .55rem; }
.poem-browse-back a { display: inline-flex; min-height: 44px; align-items: center; padding: .5rem .75rem; border: 1px solid rgba(255,255,255,.45); color: white; font-weight: 700; text-decoration: none; }
.poem-browse-back a:hover { background: white; color: var(--ink-deep); }

.site-footer { position: relative; overflow: hidden; padding: 3rem 0; background: var(--ink-deep); color: white; }
.site-footer::before { content: "Full poems are included only where public domain or permission safe."; display: block; width: min(1120px, calc(100% - 2rem)); margin: 0 auto 2rem; padding-bottom: 1rem; border-bottom: 1px solid rgba(255,255,255,.18); color: #d8e0de; font-size: .9rem; }
.site-footer::after { content: ""; position: absolute; right: -45px; bottom: -72px; width: 230px; height: 230px; border: 1px solid rgba(226,211,177,.16); border-radius: 50%; background: repeating-conic-gradient(from 45deg, rgba(226,211,177,.075) 0 2deg, transparent 2deg 23deg); pointer-events: none; }
.footer-title::after { content: ""; display: block; width: 90px; height: 9px; margin-top: .75rem; background: repeating-linear-gradient(90deg, transparent 0 10px, rgba(226,211,177,.62) 10px 11px, transparent 11px 15px), linear-gradient(rgba(226,211,177,.28), rgba(226,211,177,.28)) center / 100% 1px no-repeat; }
.footer-grid { display: grid; grid-template-columns: 1.5fr .7fr 1fr; gap: 2.5rem; }
.footer-title { margin: 0; color: white; font-family: var(--serif); font-size: 1.35rem; }
.footer-note, .copyright-note, .fine-print { color: #cbd7d3; font-size: .9rem; }
.copyright-note { display: none; }
.footer-links { display: grid; align-content: start; gap: .4rem; }
.footer-links a { width: fit-content; min-height: 36px; color: white; text-underline-offset: .2em; }
.footer-links-title { margin-top: .55rem; color: var(--gold-soft); font-size: .78rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; }

@media (max-width: 900px) {
  .hero-layout { grid-template-columns: 1fr; }
  .trust-summary { max-width: 560px; }
  .path-grid { grid-template-columns: 1fr; }
  .path-card { min-height: 0; }
  .card-grid, .poem-grid, .category-grid, .poet-grid { grid-template-columns: repeat(2, 1fr); }
  .filter-select-grid { grid-template-columns: 1fr 1fr; }
  .guide-grid { grid-template-columns: 1fr; }
  .finder-search-row { grid-template-columns: 1fr 1fr; }
  .finder-search-row .field { grid-column: 1 / -1; }
  .occasion-directory-grid { grid-template-columns: repeat(2, 1fr); }
  .guidance-card { grid-template-columns: 1fr; }
  .featured-theme-grid { grid-template-columns: repeat(2, 1fr); }
  .theme-directory-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-mood-grid { grid-template-columns: repeat(2, 1fr); }
  .mood-directory-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-poet-grid, .modern-poet-grid { grid-template-columns: repeat(2, 1fr); }
  .compact-poet-grid { grid-template-columns: repeat(2, 1fr); }
  .poet-directory-tools { grid-template-columns: 1fr; }
  .poet-tool-summary { grid-column: auto; }
  .public-domain-use-grid { grid-template-columns: repeat(2, 1fr); }
  .verification-layout, .verification-sources-layout { grid-template-columns: 1fr; gap: 1.5rem; }
  .home-full-text-grid { grid-template-columns: repeat(2, 1fr); }
  .home-full-text-card:last-child { grid-column: 1 / -1; min-height: 330px; }
  .guide-hero-inner { grid-template-columns: 1fr 180px; gap: 1rem; }
  .guide-hero-inner img { width: 180px; height: 180px; }
  .guide-prose-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .guide-three-grid { grid-template-columns: repeat(2, 1fr); }
  .guide-three-grid .guide-poem-card:last-child { grid-column: 1 / -1; }
  .candidate-link-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1050px) {
  .menu-button { display: block; }
  .site-nav { display: none; position: absolute; left: 0; right: 0; top: 76px; padding: .7rem; background: var(--paper); border-bottom: 1px solid var(--line); box-shadow: var(--shadow); flex-direction: column; align-items: stretch; }
  .site-nav.is-open { display: flex; }
  .site-nav a { min-height: 48px; display: flex; align-items: center; border: 0; border-left: 3px solid transparent; padding-inline: .9rem; }
  .site-nav a[aria-current="page"] { border-left-color: var(--gold); background: var(--cream); }
}

@media (max-width: 680px) {
  .container, .narrow { width: min(100% - 1.25rem, 1120px); }
  .nav-wrap { min-height: 68px; }
  .brand { font-size: 1.05rem; }
  .brand-mark { width: 30px; height: 30px; }
  .site-nav { top: 68px; }
  .hero { padding: 3.5rem 0 3rem; }
  .hero::before { top: -65px; right: -125px; width: 250px; height: 250px; opacity: .42; }
  .hero::after { width: 180px; opacity: .55; }
  .home-hero { padding: 3rem 0 2.25rem; }
  .page-hero { padding: 3.4rem 0 2.6rem; }
  h1 { font-size: clamp(2.65rem, 14vw, 4.25rem); }
  .hero-copy { font-size: 1.08rem; }
  .actions { display: grid; }
  .button { width: 100%; }
  .hero-finder { margin-top: 1.35rem; padding: 1rem; }
  .hero-browse { display: grid; }
  .home-filter-chip { min-height: 44px; }
  .trust-summary { padding: 1rem 0 1rem 1rem; }
  .finder-section { padding-top: 0; }
  .search-panel { margin-top: 0; padding: 1.25rem; }
  .search-row { grid-template-columns: 1fr; }
  .section { padding: 3rem 0; }
  .section-heading { align-items: start; flex-direction: column; gap: .5rem; }
  .path-card { padding: 1.25rem; }
  .home-full-text-grid { grid-template-columns: 1fr; }
  .home-full-text-card, .home-full-text-card:last-child { grid-column: auto; min-height: 0; }
  .home-full-text-card h3 { max-width: 88%; }
  .guide-hero { padding-block: 3.2rem 2.6rem; }
  .guide-hero-inner { grid-template-columns: 1fr; }
  .guide-hero-inner img { position: absolute; right: -75px; bottom: -70px; width: 210px; height: 190px; opacity: .06; pointer-events: none; }
  .guide-poem-grid, .guide-three-grid, .candidate-link-grid { grid-template-columns: 1fr; }
  .guide-three-grid .guide-poem-card:last-child { grid-column: auto; }
  .guide-poem-card { min-height: 0; }
  .guide-links-panel { grid-template-columns: 1fr; padding: 1.3rem; }
  .guide-links-panel nav { grid-template-columns: 1fr; }
  .guide-theme-links a { flex: 1 1 135px; justify-content: center; }
  .helpful-guide-links { grid-template-columns: 1fr; }
  .card-grid, .poem-grid, .select-filters, .filter-select-grid, .category-grid, .poet-grid, .footer-grid { grid-template-columns: 1fr; }
  .card { min-height: 220px; }
  .poem-card { min-height: 0; }
  .poem-text { padding: 1.6rem 1.25rem; font-size: 1.04rem; line-height: 1.8; }
  .poem-text::first-letter { font-size: 3.2em; }
  .filter-panel { padding: 1rem; }
  .filter-chip { min-height: 44px; }
  .filter-summary { align-items: flex-start; }
  .meta-row { grid-template-columns: 65px 1fr; }
  .finder-search-row, .finder-options { grid-template-columns: 1fr; }
  .finder-search-row .field { grid-column: auto; }
  .finder-search-row .button { width: 100%; }
  .finder-group { margin-top: 1.15rem; }
  .filter-chips { gap: .45rem; }
  .filter-chip { padding-inline: .78rem; }
  .results-toolbar { align-items: flex-start; }
  .finder-results .poem-card { min-height: 0; }
  .featured-occasion-grid, .occasion-directory-grid { grid-template-columns: 1fr; }
  .featured-occasion-card, .occasion-directory-card { min-height: 0; }
  .guidance-card { padding: 1.35rem; }
  .guidance-actions .button { width: 100%; }
  .featured-theme-grid, .theme-directory-grid { grid-template-columns: 1fr; }
  .featured-theme-card, .theme-directory-card { min-height: 0; }
  .featured-mood-grid, .mood-directory-grid { grid-template-columns: 1fr; }
  .featured-mood-card, .mood-directory-card { min-height: 0; }
  .featured-mood-card .related-links a { min-height: 44px; padding-block: .35rem; }
  .mood-directory-card { padding: 1.3rem; }
  .featured-poet-grid, .modern-poet-grid, .compact-poet-grid { grid-template-columns: 1fr; }
  .directory-poet-card { min-height: 0; }
  .compact-poet-card { min-height: 88px; }
  .poet-filter-fieldset .filter-chip { min-height: 46px; }
  .poet-theme-links a { min-height: 44px; }
  .poet-tool-summary { align-items: flex-start; }
  .public-domain-use-grid { grid-template-columns: 1fr; }
  .public-domain-use-card, .public-domain-poem-card { min-height: 0; }
  .verification-source-list { grid-template-columns: 1fr; }
  .verification-back-link { min-height: 44px; padding-inline: .65rem; font-size: .85rem; }
  .verification-admin-summary { align-items: flex-start; flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; }
}

/* Supplied Irish artwork: restrained identity and page accents. */
.brand-mark {
  width: 42px;
  height: 42px;
  overflow: hidden;
  border: 0;
  background: url("/assets/irish/transparent_monogram_m.png") center / 48px 48px no-repeat;
  color: transparent;
  box-shadow: none;
  mix-blend-mode: multiply;
}
.brand-mark::before, .brand-mark::after { display: none; }

.hero::before {
  top: -125px;
  right: max(-145px, calc((100vw - 1120px) / 2 - 165px));
  width: 430px;
  height: 430px;
  border: 0;
  border-radius: 0;
  background: url("/assets/irish/transparent_celtic_medallion.png") center / contain no-repeat;
  mix-blend-mode: multiply;
  opacity: .075;
  transform: rotate(8deg);
}
.hero-botanical {
  position: absolute;
  z-index: -1;
  right: max(-40px, calc((100vw - 1120px) / 2 - 35px));
  bottom: -115px;
  width: min(520px, 43vw);
  height: auto;
  opacity: .13;
  mix-blend-mode: multiply;
  pointer-events: none;
}
.home-hero .container { position: relative; }
.home-hero .hero-intro, .home-hero .hero-finder, .home-hero .hero-browse { position: relative; z-index: 1; }

.home-page main > .section { position: relative; }
.home-page main > .section::before {
  content: "";
  position: absolute;
  z-index: 2;
  top: -22px;
  left: 50%;
  width: min(760px, calc(100% - 3rem));
  height: 44px;
  background: url("/assets/irish/transparent_divider_horizontal.png") center / contain no-repeat;
  mix-blend-mode: multiply;
  opacity: .42;
  transform: translateX(-50%);
  pointer-events: none;
}

:where(.path-card, .card, .category-card, .featured-occasion-card, .occasion-directory-card, .featured-theme-card, .theme-directory-card, .featured-mood-card, .mood-directory-card, .directory-poet-card, .compact-poet-card, .poem-card, .public-domain-use-card, .verification-source-list a)::after { display: none; }
:where(.path-card, .featured-occasion-card, .featured-theme-card, .featured-mood-card, .poem-card, .public-domain-use-card)::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  right: 0;
  width: 74px;
  height: 74px;
  border: 0;
  background: url("/assets/irish/transparent_corner_knot.png") top right / contain no-repeat;
  mix-blend-mode: multiply;
  opacity: .16;
  transform: none;
  pointer-events: none;
}
:where(.path-card, .featured-occasion-card, .featured-theme-card, .featured-mood-card, .poem-card, .public-domain-use-card):hover::after {
  border: 0;
  opacity: .23;
  transform: none;
}

.poem-detail-page .prose { position: relative; }
.poem-detail-page .prose::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -78px;
  width: 42px;
  background: url("/assets/irish/transparent_divider_vertical.png") center top / 38px auto no-repeat;
  mix-blend-mode: multiply;
  opacity: .2;
  pointer-events: none;
}
.poem-detail-page .poem-text::after {
  width: 54px;
  height: 54px;
  right: 0;
  bottom: 0;
  border: 0;
  background: url("/assets/irish/transparent_corner_knot.png") bottom right / contain no-repeat;
  mix-blend-mode: multiply;
  opacity: .13;
}

.site-footer::after {
  right: -80px;
  bottom: -115px;
  width: 310px;
  height: 310px;
  border: 0;
  border-radius: 0;
  background: url("/assets/irish/transparent_celtic_medallion.png") center / contain no-repeat;
  mix-blend-mode: screen;
  opacity: .075;
}

@media (max-width: 900px) {
  .hero-botanical { right: -95px; width: 430px; opacity: .09; }
  .poem-detail-page .prose::before { left: -48px; width: 30px; background-size: 28px auto; opacity: .14; }
  .poem-reading-column::before { right: -80px; width: 240px; opacity: .035; }
}

@media (max-width: 680px) {
  .brand-mark { width: 36px; height: 36px; background-size: 42px 42px; }
  .hero::before { top: -75px; right: -105px; width: 245px; height: 245px; opacity: .055; }
  .hero-botanical { right: -110px; bottom: -35px; width: 310px; opacity: .07; }
  .home-page main > .section::before { top: -15px; width: calc(100% - 2.5rem); height: 30px; opacity: .32; }
  :where(.path-card, .featured-occasion-card, .featured-theme-card, .featured-mood-card, .poem-card, .public-domain-use-card)::after { width: 54px; height: 54px; opacity: .12; }
  .poem-detail-page .prose::before { display: none; }
  .site-footer::after { width: 210px; height: 210px; opacity: .055; }
  .poem-page-hero { padding-bottom: 2.5rem; }
  .poem-page-status { min-height: 34px; font-size: .74rem; }
  .poem-byline { font-size: 1.18rem; }
  .poem-intro { font-size: 1rem; }
  .poem-tag-groups { grid-template-columns: 1fr; gap: 1rem; }
  .poem-tag { min-height: 42px; }
  .poem-reading-column { width: min(100% - 1.25rem, 880px); }
  .poem-reading-column::before { display: none; }
  .poem-divider { width: 100%; height: 38px; margin-bottom: 1rem; }
  .poem-divider-after { margin-top: 1rem; }
  .full-text-page .poem-text { padding: 1.25rem .35rem 1.5rem; border-inline: 0; font-size: 1.08rem; line-height: 1.9; }
  .full-text-page .poem-text::first-letter { font-size: 3em; }
  .full-text-page .poem-text::after { width: 50px; height: 50px; }
  .source-information-grid { grid-template-columns: 1fr; gap: 1rem; }
  .source-information-grid > div + div { padding: 1rem 0 0; border-top: 1px solid var(--line); border-left: 0; }
  .poem-information { padding: 1.2rem; }
  .related-poem-cards { grid-template-columns: 1fr; }
  .related-poem-cards a { min-height: 120px; }
  .poem-browse-back { padding: 1.2rem; }
  .poem-browse-back a { flex: 1 1 130px; justify-content: center; }
}
