/* ═══════════════════════════════════════════════════════════════════════════
   STORY READER — reading (viewing) state styles
   ═══════════════════════════════════════════════════════════════════════════ */

/*** READER CONTROL BAND 'BUTTONS' ***/

.reader-control-band-btn-prev:hover,
.reader-control-band-btn-next:hover,
.reader-control-band-btn-back-to-stories:hover,
.reader-control-band-btn-share:hover {
	color: #330000 !important;
	cursor: pointer !important;
}
.reader-control-band-story-title {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.reader-control-band-count {
    white-space: nowrap;
}
.reader-control-band-btn-prev,
.reader-control-band-btn-next,
.reader-control-band-btn-share,
.reader-control-band-btn-back-to-stories {
    white-space: nowrap !important;
    text-decoration: underline !important;
    padding-left: .1rem !important;
    padding-right: .1rem !important;
}


/* ── BROWSE STATE OVERLAY ────────────────────────────────────────────────── */
.reader-control-band-overlay {
    position: absolute !important;
	top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
}


/* ── DISABLED NAV LINK STATE ─────────────────────────────────────────────── */
.reader-control-band-btn-prev--disabled,
.reader-control-band-btn-next--disabled {
    opacity: 0.3;
    cursor: default !important;
    pointer-events: none;
}


/* ── DESKTOP / TABLET — VIEWER BODY ──────────────────────────────────────── */
.story-viewer {
    padding: 1rem;
    overflow-y: auto;
    height: 100%;
}

.story-viewer-video-wrap {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* 16:9 */
    height: 0;
    margin-bottom: 1rem;
}

.story-viewer-youtube {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

.story-viewer-text {
    font-size: 0.95rem;
    line-height: 1.6;
    color: #222;
    margin-bottom: 1rem;
}

.story-viewer-text p {
    margin: 0 0 0.75rem 0;
}

.story-viewer-link-wrap {
    margin-bottom: 0.75rem;
}

.story-viewer-link {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.9rem;
    color: #0055cc;
    text-decoration: underline;
}

.story-viewer-link:hover {
    color: #003388;
}

.story-viewer-link-arrow {
    font-size: 0.8rem;
}

.story-viewer-empty {
    font-size: 0.9rem;
    color: #888;
    font-style: italic;
}

.story-viewer-meta-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 1.25rem;
    padding-top: 0.75rem;
    border-top: 1px solid #e0e0e0;
}

.story-viewer-meta-item {
    font-size: 0.72rem;
    font-weight: 700;
    color: #555;
    background: #f0f0f0;
    border-radius: 3px;
    padding: 0.15rem 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}


/* ── FILE RENDERER ───────────────────────────────────────────────────────── */

.story-viewer-file-wrap {
    width: 100%;
    margin-bottom: 1rem;
}

.story-viewer-html {
    width: 100% !important;
    height: 33rem !important;
    border: none !important;
    display: block !important;
}

.story-viewer-video {
    width: 100%;
    max-height: 100%;
    display: block;
}

.story-viewer-audio {
    width: 100%;
    display: block;
    margin: 0.5rem 0;
}

.story-viewer-pdf {
    width: 100%;
    height: 33rem;
    border: none;
    display: block;
}

.story-viewer-txt {
    font-size: 0.9rem;
    line-height: 1.6;
    color: #222;
    white-space: pre-wrap;
    word-break: break-word;
}

.story-viewer-loading {
    color: #888;
    font-style: italic;
    font-size: 0.85rem;
}


/* ── NEW TAB LINK (docx, unknown) ────────────────────────────────────────── */

.story-viewer-newtab-wrap {
    margin-bottom: 1rem;
}

.story-viewer-newtab-link {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 1.5rem;
    color: #0000DD;
    text-decoration: underline;
    font-weight: bold;
    margin-bottom: 1rem;
    margin-top: 1rem;
    margin-left: 2rem;
    justify-content: center;
}

.story-viewer-newtab-link:hover {
    color: #330000;
    
}

.story-viewer-newtab-msg {
    font-size: 1.5rem;
    font-weight: bold;
	justify-content: center;
    color: #000;
    font-style: italic;
    margin-top: 2rem;
    margin-left: 2rem;
    margin-bottom: 1rem;
    line-height: 1.4;
}


/* ── PHONE — FIXED VIEWER ────────────────────────────────────────────────── */
.story-reader-phone-viewer {
    position: fixed;
    top: 5.58rem !important;          /* JS will offset below site header via --reader-header-offset if needed */
    left: 0;
    right: 0;
    height: 50vh;
    z-index: 900;
    background: #fff;
    display: flex;
    flex-direction: column;
    box-shadow: 0 4px 20px rgba(0,0,0,0.18);
}


/* ── PHONE — TOP BAND ────────────────────────────────────────────────────── */

.story-reader-phone-top-band {
    display: flex !important;
    align-items: center !important;
    gap: 0.4rem !important;
    padding: 0.4rem 0.6rem !important;
    background: #f0f0f0 !important;
    border: 3px solid #2D7979 !important;
    flex-shrink: 0 !important;
}

.story-reader-phone-title {
    flex: 1 1 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: #222 !important;
    text-align: center !important;
}

.story-reader-phone-back,
.story-reader-phone-share {
    background: none !important;
    border: 1px solid #bbb !important;
    border-radius: 3px !important;
    padding: 0.2rem 0.45rem !important;
    font-size: 1.25rem !important;
    cursor: pointer !important;
    color: #111 !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    line-height: 1.4 !important;
    font-weight: 600 !important;
}

/* ── PHONE — VIEWER BODY ─────────────────────────────────────────────────── */

.story-reader-phone-viewer-body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 0.75rem;
    -webkit-overflow-scrolling: touch;
}


/* ── PHONE — BOTTOM BAND ─────────────────────────────────────────────────── */

.story-reader-phone-bottom-band {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 1rem !important;
    padding: 0.4rem 0.6rem !important;
    background: #f0f0f0 !important;
    border: 3px solid #2D7979 !important;
    flex-shrink: 0 !important;
}

.story-reader-phone-prev,
.story-reader-phone-next {
    background: none !important;
    border: 1px solid #888 !important;
    border-radius: 3px !important;
    padding: 0.2rem 0.6rem !important;
    font-size: 1.25rem !important;
    cursor: pointer !important;
    color: #333 !important;
    line-height: 1.4 !important;
}

.reader-control-link--disabled {
    opacity: 0.35 !important;
    cursor: default !important;
}

.story-reader-phone-count {
    font-size: 1.25rem !important;
    color: #333 !important;
    white-space: nowrap !important;
}


/* ── PHONE — SCRIM ───────────────────────────────────────────────────────── */

.story-reader-phone-scrim {
    position: fixed !important;
    top: 50vh !important;       /* sits below the viewer — matches .story-reader-phone-viewer height */
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.45) !important;
    z-index: 899 !important;    /* below viewer (900), above cards */
    pointer-events: none !important; /* cards non-interactive but still visible */
}


/* ── BODY READING STATE ──────────────────────────────────────────────────── */

/* Prevent body scroll on phone while viewer is open */
@media (max-width: 767px) {
    body.drp-reading {
        overflow: hidden !important;
    }
}
