/* ============================================
   DETAIL PAGE (song.php / poem.php)
============================================ */

/* ---- Attribute Edit Modal ---- */
#attribute-edit .uk-modal-dialog {
    border-radius: 14px;
    padding: 0;
    overflow: hidden;
    width: 960px;
    max-width: calc(100vw - 40px);
    box-shadow: 0 12px 48px rgba(0,0,0,.18);
}
.attr-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px 14px;
    border-bottom: 1px solid var(--border);
    background: var(--cream);
}
.attr-modal-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--brown-deep);
    margin: 0;
}
.attr-modal-close {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-muted);
    font-size: 1.2rem;
    line-height: 1;
    padding: 2px 6px;
    border-radius: 6px;
    transition: background .12s, color .12s;
}
.attr-modal-close:hover { background: var(--border); color: var(--text); }
.attr-modal-body { padding: 18px 22px; }
.attr-modal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
    margin-bottom: 14px;
}
.attr-field { display: flex; flex-direction: column; gap: 4px; }
.attr-field-full { grid-column: 1 / -1; }
.attr-field label {
    font-family: 'Open Sans', sans-serif;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--text-muted);
}
.attr-field-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.attr-add-new-btn {
    font-family: 'Open Sans', sans-serif;
    font-size: .65rem;
    font-weight: 600;
    color: var(--gold);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: color .12s;
}
.attr-add-new-btn:hover { color: var(--brown-deep); }
.attr-field input[type="text"],
.attr-field select {
    font-family: 'Open Sans', sans-serif;
    font-size: .85rem;
    color: var(--text);
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px 12px;
    outline: none;
    transition: border-color .14s, box-shadow .14s;
    width: 100%;
    box-sizing: border-box;
}
.attr-field input[type="text"]:focus,
.attr-field select:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(200,136,58,.12);
}
/* Override select2 to match */
#attribute-edit .select2-container { width: 100% !important; }
#attribute-edit .select2-container--default .select2-selection--multiple {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 4px 8px;
    min-height: 38px;
    transition: border-color .14s, box-shadow .14s;
    background: #fff;
}
#attribute-edit .select2-container--default.select2-container--focus .select2-selection--multiple {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(200,136,58,.12);
}
#attribute-edit .select2-container--default .select2-selection--multiple .select2-selection__choice {
    background: var(--cream-mid);
    border: 1px solid rgba(200,136,58,.3);
    border-radius: 20px;
    color: var(--brown-deep);
    font-family: 'Open Sans', sans-serif;
    font-size: .73rem;
    padding: 1px 8px;
}
#attribute-edit .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: var(--brown-mid);
    margin-right: 4px;
}
.attr-add-inline {
    display: none;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
}
.attr-add-inline.open { display: flex; }
.attr-add-inline input {
    flex: 1;
    font-family: 'Open Sans', sans-serif;
    font-size: .8rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 5px 10px;
    outline: none;
    transition: border-color .14s;
}
.attr-add-inline input:focus { border-color: var(--gold); }
.attr-inline-save {
    background: var(--brown-deep);
    color: #fff;
    border: none;
    border-radius: 20px;
    padding: 5px 14px;
    font-family: 'Open Sans', sans-serif;
    font-size: .75rem;
    cursor: pointer;
    transition: background .12s;
    white-space: nowrap;
}
.attr-inline-save:hover { background: var(--gold); }
.attr-inline-cancel {
    background: none;
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 4px 12px;
    font-family: 'Open Sans', sans-serif;
    font-size: .75rem;
    cursor: pointer;
    color: var(--text-muted);
    transition: border-color .12s;
}
.attr-inline-cancel:hover { border-color: var(--text-muted); }
.attr-inline-msg {
    font-size: .72rem;
    color: #c00;
    font-family: 'Open Sans', sans-serif;
}
.attr-modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding: 14px 22px 18px;
    border-top: 1px solid var(--border);
}
.attr-btn-cancel {
    background: none;
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 7px 20px;
    font-family: 'Open Sans', sans-serif;
    font-size: .82rem;
    color: var(--text-muted);
    cursor: pointer;
    transition: border-color .12s, color .12s;
}
.attr-btn-cancel:hover { border-color: var(--text-muted); color: var(--text); }
.attr-btn-save {
    background: var(--brown-deep);
    color: #fff;
    border: none;
    border-radius: 20px;
    padding: 7px 24px;
    font-family: 'Open Sans', sans-serif;
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .14s;
}
.attr-btn-save:hover { background: var(--gold); }
@media (max-width: 640px) {
    .attr-modal-grid { grid-template-columns: 1fr; }
    .attr-field-full { grid-column: 1; }
    #attribute-edit .uk-modal-dialog { border-radius: 10px; }
}

/* ---- Hero (compact variant) ---- */
.poems-hero.hero-item {
    padding: 24px 0 20px;
}
.poems-hero.hero-item h1 {
    font-size: 1.8rem;
    margin-bottom: 6px;
}
.item-hero-meta {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: .8rem;
    color: rgba(255,255,255,.6);
    margin-top: 6px;
}
.item-hero-meta img {
    width: 12px;
    height: 12px;
    opacity: .55;
    vertical-align: middle;
    filter: brightness(10);
}
@media (max-width: 640px) {
    .poems-hero.hero-item h1 { font-size: 1.35rem; }
}

/* ---- Section navigation tabs ---- */
.item-tabs {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.item-tab {
    padding: 5px 14px;
    border-radius: 20px;
    font-size: .8rem;
    font-family: 'Open Sans', sans-serif;
    color: var(--brown-mid);
    border: 1px solid var(--border);
    background: #fff;
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s;
}
.item-tab:hover {
    background: var(--brown-deep);
    color: #fff;
    border-color: var(--brown-deep);
    text-decoration: none;
}

/* ---- Article content card ---- */
.item-content-card {
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
    padding: 24px 28px;
    margin-bottom: 16px;
}
@media (max-width: 640px) {
    .item-content-card { padding: 16px; }
}

/* Content text (lyrics / poem) */
#article-content {
    font-family: 'Lora', serif;
    font-size: 1.1rem;
    line-height: 1.2;
    color: var(--text);
    white-space: pre-wrap;
    margin-top: 0;
}

/* ---- Editor toolbar ---- */
.toolbar {
    background: var(--cream-mid);
    border-radius: var(--radius);
    padding: 10px 14px;
    margin-bottom: 16px;
    border: 1px solid var(--cream-dark);
}

/* ---- Media sections (audio / notes / video) ---- */
.al-media {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    padding: 18px 22px !important;
    margin-top: 0 !important;
}
.media-container {
    margin-bottom: 14px;
}
.al-media h2 {
    font-family: 'Lora', serif !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    color: var(--text-faint) !important;
    background: none !important;
    width: auto !important;
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    padding: 0 0 8px !important;
    border-bottom: 1px solid var(--border);
    text-transform: uppercase;
    letter-spacing: .08em;
}

/* ---- Audio items ---- */
.audio-container {
    border: none !important;
    background: none !important;
    border-radius: 0 !important;
    padding: 10px 0 !important;
    margin-bottom: 0 !important;
    max-width: 100% !important;
}
.audio-container + .audio-container {
    border-top: 1px solid var(--border) !important;
}
.audio-container:first-child {
    padding-top: 0 !important;
}
.audio-container:last-child {
    padding-bottom: 0 !important;
}

/* Title row */
.audio-container .filename {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 7px !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: .8rem !important;
    font-weight: 500 !important;
    color: var(--brown-mid) !important;
    float: none !important;
}
/* Only the title link stretches — exclude badge and download icon */
.audio-container .filename a:not(.al-type):not(.midi-download) {
    color: var(--brown-mid) !important;
    text-decoration: none !important;
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.audio-container .filename a:not(.al-type):not(.midi-download):hover {
    color: var(--brown-deep) !important;
    text-decoration: none !important;
}
/* No bottom margin when filename has no player below (MIDI / notes) */
.audio-container .filename:last-child {
    margin-bottom: 0 !important;
}

/* Type badge */
.al-type {
    float: none !important;
    display: inline-block !important;
    flex: none !important;
    font-size: .62rem !important;
    font-family: 'Open Sans', sans-serif !important;
    background: var(--cream-mid) !important;
    color: var(--brown-light) !important;
    padding: 2px 8px !important;
    border-radius: 20px !important;
    border: 1px solid var(--cream-dark) !important;
    font-weight: 400 !important;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background .15s, color .15s;
}
.al-type:hover {
    background: var(--brown-deep) !important;
    color: #fff !important;
    border-color: var(--brown-deep) !important;
}

/* Download icon (MIDI / notes) — plain icon button, no circle, matches Plyr controls */
.midi-download {
    float: none !important;
    display: inline-flex !important;
    flex: none !important;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 4px;
    border: none;
    background: none;
    color: var(--text-muted);
    transition: color .15s, background .15s;
}
.midi-download:hover {
    color: var(--brown-deep);
    background: var(--cream-mid);
}

/* Hide original SVGs — both the broken Plyr sprite and Plyr's own download icon */
.midi-download svg,
.plyr__controls .plyr__control[data-plyr="download"] svg {
    display: none !important;
}

/* Shared download icon applied to both buttons */
.midi-download::before,
.plyr__controls .plyr__control[data-plyr="download"]::before {
    content: '';
    display: block;
    width: 22px;
    height: 22px;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 16l-5-5h3V4h4v6h3l-5 5zM4 19v2h16v-2H4z'/%3E%3C/svg%3E");
    mask-image:         url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 16l-5-5h3V4h4v6h3l-5 5zM4 19v2h16v-2H4z'/%3E%3C/svg%3E");
    -webkit-mask-size: contain;
    mask-size:         contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat:         no-repeat;
    -webkit-mask-position: center;
    mask-position:         center;
}

/* Plyr audio wrapper */
.audio-container .container {
    max-width: 100%;
}

/* ---- Plyr player theme ---- */
.plyr {
    --plyr-color-main:                    var(--brown-deep);
    --plyr-audio-controls-background:     var(--cream);
    --plyr-audio-control-color:           var(--brown-mid);
    --plyr-audio-control-color-hover:     var(--brown-deep);
    --plyr-audio-progress-buffered-background: var(--cream-dark);
    --plyr-range-track-height:            3px;
    --plyr-range-thumb-height:            12px;
    --plyr-range-thumb-background:        var(--brown-deep);
    font-family: 'Open Sans', sans-serif;
    font-size: .8rem;
    border-radius: 6px;
    overflow: hidden;
}
.plyr--audio .plyr__controls {
    background: var(--cream) !important;
    border: 1px solid var(--border) !important;
    border-radius: 6px !important;
    padding: 6px 10px !important;
}
.plyr--audio .plyr__control {
    color: var(--brown-mid) !important;
}
.plyr--audio .plyr__control:hover,
.plyr--audio .plyr__control:focus {
    background: var(--brown-deep) !important;
    color: #fff !important;
}
.plyr__progress__container .plyr__progress input[type=range] {
    color: var(--brown-deep) !important;
}

/* ---- Video items ---- */
.video-container {
    max-width: 100% !important;
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 0 !important;
}
.video-container + .video-container {
    margin-top: 14px;
}

/* ---- Comments ---- */
.comments-wrap {
    margin-bottom: 16px;
}
.comments-title {
    font-family: 'Lora', serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--brown-deep);
    border-bottom: 1px solid var(--border);
    padding-bottom: 8px;
    margin-bottom: 14px;
}

/* Individual comment card */
.uk-comment-primary {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    padding: 10px 13px !important;
    margin-top: 6px !important;
    box-shadow: var(--shadow-sm) !important;
}

/* Header: avatar + name + date in one row */
.uk-comment-primary .uk-comment-header {
    margin-bottom: 5px !important;
    padding-bottom: 0 !important;
    border: none !important;
    background: none !important;
}

/* Tiny avatar — decorative only */
.uk-comment-primary .uk-comment-avatar {
    width: 20px !important;
    height: 20px !important;
    border-radius: 50%;
    opacity: .45;
}

/* Author name */
.uk-comment-primary .uk-comment-title {
    font-family: 'Open Sans', sans-serif !important;
    font-size: .75rem !important;
    font-weight: 600 !important;
    color: var(--brown-mid) !important;
    font-style: normal !important;
    letter-spacing: .01em;
}
.uk-comment-primary .uk-comment-title a {
    color: inherit !important;
}

/* Date / Reply meta row */
.uk-comment-primary .uk-comment-meta {
    font-size: .68rem !important;
    color: var(--text-faint) !important;
    margin-top: 0 !important;
}
.uk-comment-primary .uk-comment-meta a {
    color: var(--text-faint) !important;
}
.uk-comment-primary .uk-comment-meta a:hover {
    color: var(--brown-mid) !important;
}

/* Comment body */
.uk-comment-primary .uk-comment-body {
    background: none !important;
    padding: 0 !important;
    border: none !important;
    border-radius: 0 !important;
    font-family: 'Lora', serif !important;
    font-size: .82rem !important;
    line-height: 1.55 !important;
    color: var(--text-muted) !important;
}
.uk-comment-primary .uk-comment-body p {
    margin: 0 !important;
}
.uk-comment-primary .uk-comment-body p {
    margin: 0 !important;
}
div#article-content {
    padding-bottom: 2rem;
}

/* Comment body text */
.uk-comment-primary .comment-body-text {
    font-family: 'Lora', serif;
    font-size: .82rem;
    line-height: 1.55;
    color: var(--text-muted);
}
.uk-comment-primary .comment-body-text p,
.uk-comment-primary .comment-body-text br { margin: 0; }

/* Quote block inside comments */
.comment-quote {
    border-left: 3px solid var(--gold);
    background: rgba(200,136,58,.07);
    margin: 0 0 8px 0;
    padding: 6px 10px;
    border-radius: 0 4px 4px 0;
}
.comment-quote cite {
    display: block;
    font-family: 'Open Sans', sans-serif;
    font-size: .68rem;
    font-weight: 700;
    color: var(--brown-mid);
    font-style: normal;
    margin-bottom: 3px;
}
.comment-quote p {
    font-family: 'Lora', serif;
    font-size: .78rem;
    color: var(--text-muted);
    margin: 0 !important;
    line-height: 1.4;
    opacity: .85;
}

/* Reply / Quote action buttons */
.comment-actions {
    margin-top: 8px;
    display: flex;
    gap: 10px;
}
.comment-reply-btn,
.comment-quote-btn {
    background: none;
    border: none;
    padding: 0;
    font-family: 'Open Sans', sans-serif;
    font-size: .68rem;
    color: var(--gold);
    cursor: pointer;
    transition: color .12s;
}
.comment-reply-btn:hover,
.comment-quote-btn:hover { color: var(--brown-deep); }

/* Admin action buttons */
.comment-admin-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}
.comment-approve-btn,
.comment-delete-btn {
    font-family: 'Open Sans', sans-serif;
    font-size: .65rem;
    padding: 2px 8px;
    border-radius: 12px;
    cursor: pointer;
    border: 1px solid;
    transition: all .12s;
}
.comment-approve-btn {
    border-color: #4caf50;
    color: #4caf50;
    background: none;
}
.comment-approve-btn:hover { background: #4caf50; color: #fff; }
.comment-delete-btn {
    border-color: #c0392b;
    color: #c0392b;
    background: none;
}
.comment-delete-btn:hover { background: #c0392b; color: #fff; }

/* Pending comment highlight */
.comment-pending {
    background: #fffbf0 !important;
    border-color: rgba(200,136,58,.4) !important;
}
.comment-pending-badge {
    font-size: .63rem;
    color: var(--gold);
    font-weight: 600;
    font-family: 'Open Sans', sans-serif;
}

/* Nested replies */
.comment-replies {
    margin-left: 16px !important;
    padding-left: 0 !important;
    list-style: none !important;
    border-left: 2px solid rgba(200,136,58,.18);
    margin-top: 8px !important;
    padding-left: 10px !important;
}
.comment-replies > li { padding: 0; margin: 0; }

/* ── Comment form ──────────────────────────────────────────────────────── */
.comment-form-wrap {
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}
#comment-reply-info {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(200,136,58,.08);
    border-left: 3px solid var(--gold);
    padding: 6px 10px;
    border-radius: 0 4px 4px 0;
    margin-bottom: 10px;
    font-family: 'Open Sans', sans-serif;
    font-size: .75rem;
    color: var(--brown-mid);
}
#comment-cancel-reply {
    background: none;
    border: none;
    cursor: pointer;
    font-size: .9rem;
    color: var(--text-faint);
    margin-left: auto;
    line-height: 1;
}
#comment-cancel-reply:hover { color: var(--brown-deep); }
#comment-text {
    width: 100%;
    min-height: 90px;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
    font-family: 'Lora', serif;
    font-size: .85rem;
    color: var(--text);
    background: #fff;
    resize: vertical;
    box-sizing: border-box;
    transition: border-color .15s;
}
#comment-text:focus {
    outline: none;
    border-color: var(--gold);
}
.comment-form-footer {
    display: flex;
    justify-content: flex-end;
    margin-top: 8px;
}
#comment-submit-btn {
    font-family: 'Open Sans', sans-serif;
    font-size: .78rem;
    padding: 6px 18px;
    border-radius: 20px;
    border: none;
    background: var(--brown-deep);
    color: #fff;
    cursor: pointer;
    transition: background .14s;
}
#comment-submit-btn:hover { background: var(--gold); }
#comment-submit-btn:disabled { opacity: .6; cursor: wait; }
#comment-msg {
    margin-top: 10px;
    padding: 8px 12px;
    border-radius: 6px;
    font-family: 'Open Sans', sans-serif;
    font-size: .78rem;
}
.uk-alert-success { background: #e8f5e9; color: #2e7d32; }
.uk-alert-danger  { background: #ffebee; color: #c62828; }
.comment-login-prompt {
    font-family: 'Open Sans', sans-serif;
    font-size: .8rem;
    color: var(--text-muted);
    text-align: center;
    padding: 14px 0;
}
.comment-login-prompt a { color: var(--gold); }
.comment-login-prompt a:hover { color: var(--brown-deep); }

/* ── Emoji picker ─────────────────────────────────────────────────────────── */
.emoji-picker-wrap {
    position: relative;
}
#emoji-toggle {
    background: none;
    border: 1px solid var(--border);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    font-size: 1.1rem;
    cursor: pointer;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color .14s, background .14s;
    flex-shrink: 0;
}
#emoji-toggle:hover {
    border-color: var(--gold);
    background: rgba(200,136,58,.08);
}
#emoji-picker {
    position: absolute;
    bottom: calc(100% + 6px);
    left: 0;
    z-index: 200;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 10px;
    box-shadow: 0 6px 28px rgba(0,0,0,.13);
    width: 280px;
    padding: 10px;
}
.emoji-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}
.emoji-tab {
    background: none;
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 3px 10px;
    font-family: 'Open Sans', sans-serif;
    font-size: .65rem;
    cursor: pointer;
    color: var(--text-muted);
    transition: all .12s;
    white-space: nowrap;
}
.emoji-tab.active,
.emoji-tab:hover {
    background: var(--brown-deep);
    border-color: var(--brown-deep);
    color: #fff;
}
.emoji-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
}
.emoji-item {
    background: none;
    border: none;
    width: 34px;
    height: 34px;
    font-size: 1.2rem;
    cursor: pointer;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .1s;
    line-height: 1;
}
.emoji-item:hover { background: rgba(200,136,58,.12); }

/* Emoji in rendered comments */
.comment-body-text .emoji-char {
    font-size: 1.1em;
    vertical-align: middle;
}

/* ---- Card action buttons (print / PDF) ---- */
.card-actions {
    display: flex;
    gap: 6px;
    margin-left: auto;
}
.print-btn,
.pdf-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 4px 11px;
    border-radius: 20px;
    background: none;
    font-family: 'Open Sans', sans-serif;
    font-size: .72rem;
    cursor: pointer;
    transition: color .15s, border-color .15s, background .15s;
}
.print-btn {
    border: 1px solid var(--brown-mid);
    color: var(--brown-mid);
    background: var(--cream-mid);
}
.print-btn:hover {
    color: #fff;
    border-color: var(--brown-deep);
    background: var(--brown-deep);
}
.pdf-btn {
    border: 1px solid var(--brown-mid);
    color: var(--brown-mid);
    background: var(--cream-mid);
}
.pdf-btn:hover {
    color: #fff;
    border-color: var(--brown-deep);
    background: var(--brown-deep);
}
.pdf-btn:disabled {
    opacity: 0.55;
    cursor: wait;
}
.print-btn svg,
.pdf-btn svg {
    width: 13px;
    height: 13px;
    fill: currentColor;
    flex-shrink: 0;
}

/* ---- Print footer (hidden on screen) ---- */
#print-footer {
    display: none;
}

/* ---- Print styles ---- */

/* margin:0 removes the browser's built-in header/footer (URL, title, date).
   Our own footer replaces it via position:fixed. */
@page {
    margin: 0;
}

@media print {
    header.al-header,
    .poems-hero,
    .item-tabs,
    .toolbar,
    #media-list,
    .comments-wrap,
    .al-sidebar,
    .al-spinner,
    #audio-active,
    .card-actions {
        display: none !important;
    }

    body {
        background: #fff;
        padding: 1cm 0 0 0; /* top breathing room on first page */
    }

    .uk-container,
    .uk-grid,
    [uk-grid],
    .uk-width-2-3\@m {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .item-content-card {
        border: none !important;
        box-shadow: none !important;
        padding: 0 1.5rem 1.4cm 2.5rem !important;
        margin: 0 !important;
    }

    #article-content {
        font-size: 0.95rem;
    }

    /* Keep each verse/paragraph together — never split across pages */
    #article-content p,
    #article-content .verse,
    #article-content .chorus {
        break-inside: avoid;
        page-break-inside: avoid;
    }

    /* Force black & white */
    .item-content-card h2 {
        color: #000 !important;
    }
    .item-content-card h2::after {
        display: none !important;
    }
    #article-content,
    #article-content * {
        color: #000 !important;
    }

    #print-footer {
        display: block;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 3px 0 2px;
        border-top: 1px solid #ddd;
        text-align: center;
        font-family: 'Open Sans', sans-serif;
        font-size: 0.65rem;
        line-height: 1;
        white-space: nowrap;
        color: #aaa;
        letter-spacing: 0.07em;
        background: #fff;
    }
}
.item-content-card h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--brown-deep);
    text-align: left;
    letter-spacing: 0.01em;
    line-height: 1.25;
    margin-top: 0;
    margin-bottom: 1.75rem;
    padding-bottom: 1.25rem;
    position: relative;
}
.item-content-card h2::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 72px;
    height: 2px;
    background: linear-gradient(to right, var(--gold), transparent);
    border-radius: 2px;
}

@media (max-width: 640px) {
    .item-content-card h2 {
        font-size: 1.4rem;
        margin-bottom: 1.5rem;
        padding-bottom: 1rem;
    }
}