/* Article layout, metadata, and edit/view mode styling */
/* Base article layout and media */
.article {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

@media (max-width: var(--bp-md)) {
    .article { grid-template-columns: 1fr; }
}

.article img {
    width: 100%;
    height: auto;           /* no height limit on large screens */
    object-fit: contain;    /* preserve entire image */
    display: block;
    margin: 0;              /* no top/left margins on large screens */
}

.article-body {
    padding: var(--card-pad);
    white-space: pre-wrap;
}

.article-body h2 {
    margin-top: 0;
    color: var(--green2);
}

/* Image + date block */
.card.article .article-media {
    display: inline-block;  /* wraps image width */
    text-align: left;       /* image itself left */
    position: relative;     /* anchor for absolute children */
}

.card.article .article-media .article-date {
    font-size: 0.9em;
    text-align: right;      /* right edge of the image/block */
    margin: 0.25em 0 0.5em 0; /* subtle spacing below date */
    position: absolute;
    bottom: 0.5em;
    color: var(--white);
    background: transparent;
    padding: 0.2em 0.5em;
    margin: 0 !important; /* override inline margins */
    border-radius: calc(var(--space-half) / 2);
    pointer-events: none; /* don’t block clicks on image */
}

.article-meta {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--space-half);
    margin: calc(var(--space-half) / 2) 0;
}

/* Segment blocks */
.article-segment {
    margin-top: var(--space);
}

.article-segment:first-of-type {
    margin-top: 0;
}

.article-segment-title {
    padding-left: var(--card-pad-x);
    padding-right: var(--card-pad-x);
    margin: calc(var(--space-half) + var(--size-2)) 0 var(--space-half);
}

.segment-subtitle-input {
    width: 100%;
    font-size: 1.1rem;
    font-weight: 700;
    padding: calc(var(--space-half) + var(--size-2)) calc(var(--space-half) + var(--size-4));
    border-radius: var(--radius-inner);
    border: var(--size-1) solid var(--border-mid);
    background: var(--glass);
    color: var(--ink);
    margin-bottom: calc(var(--space-half) + var(--size-2));
}

.segment-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--nav-pill-gap);
    margin-top: var(--space-half);
}

/* Article page edit/view mode styling */
.edit-capsule {
    position: absolute;
    right: var(--space);
    top: var(--space);
    z-index: 9999;
}

.edit-mode-badge {
    position: absolute;
    right: var(--space);
    top: var(--space);
    z-index: 9999;
    transform: translate(calc(var(--size-6) * -1), var(--size-4));
}

.delete-handle {
    position: absolute;
    left: var(--space-half);
    top: var(--space-half);
    width: var(--size-18);
    height: var(--size-18);
    padding: 0;
    border-radius: var(--pill-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--danger-strong);
    color: var(--white);
    font-weight: 800;
    font-size: var(--size-12);
    line-height: 1;
    border: none;
    cursor: pointer;
    user-select: none;
    z-index: 4;
}

.delete-handle:hover {
    background: var(--danger-strong-hover);
    transform: translateY(calc(var(--size-1) * -1));
}

.delete-handle:active {
    transform: translateY(0);
}

.article-edit-form {
    margin-top: calc(var(--space-half) - var(--size-2));
}

.article-edit-title {
    width: 100%;
    font-size: 1.6rem;
    font-weight: 700;
    padding: calc(var(--space-half) + var(--size-2)) calc(var(--space-half) + var(--size-4));
    border-radius: var(--radius-inner);
    border: var(--size-1) solid var(--border-mid);
    background: var(--glass);
    color: var(--ink);
    margin-bottom: calc(var(--space-half) + var(--size-2));
}

.article-edit-body {
    width: 100%;
    min-height: var(--size-220);
    padding: var(--card-pad);
    border-radius: var(--radius-inner);
    border: var(--size-1) solid var(--border-mid);
    background: var(--glass);
    color: var(--ink);
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

.article-edit-actions {
    display: flex;
    gap: var(--nav-pill-gap);
    margin-top: calc(var(--space-half) + var(--size-4));
    align-items: center;
    transform: translateY(calc(var(--size-8) * -1));
}

.article-edit-actions.article-view-actions {
    margin-top: var(--space);
    margin-bottom: var(--space);
    transform: none;
}

.article-upload-form {
    margin-top: calc(var(--space-half) + var(--size-2));
    padding-left: var(--card-pad-x);
    padding-right: var(--card-pad-x);
}

.article-upload-row {
    display: flex;
    gap: var(--nav-pill-gap);
    align-items: center;
}

.article-upload-input {
    flex: 1;
    font-size: 0.95rem;
}

.article-upload-hint {
    margin-top: calc(var(--space-half) - var(--size-2));
    font-size: 0.85rem;
    opacity: 0.8;
}

.upload-progress {
    margin-top: var(--space-half);
    padding-left: var(--card-pad-x);
    padding-right: var(--card-pad-x);
}

.upload-progress-row {
    display: flex;
    align-items: center;
    gap: var(--nav-pill-gap);
}

.upload-progress progress {
    flex: 1;
    height: var(--size-12);
}

.article-page .card.articles {
    position: relative;
}

.article-page section.card.articles > h2 {
    padding-left: var(--card-pad-x);
    padding-right: var(--card-pad-x);
}

.article-page section.card.articles .article-meta {
    padding-left: var(--card-pad-x);
    padding-right: var(--card-pad-x);
}

.article-page section.card.articles .article-body {
    padding: var(--card-pad);
}

.btn-delete {
    margin-left: auto; /* push to the far right */
}

.pl-modal-backdrop {
    position: fixed;
    inset: 0;
    background: var(--overlay-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space);
    z-index: 10000;
}

.pl-modal {
    display: inline-block;
    width: auto;
    max-width: var(--modal-max-width);
    background: var(--cream);
    color: var(--ink);
    border-radius: var(--radius);
    box-shadow: var(--modal-shadow);
    border: var(--size-1) solid var(--panel-border);
    padding: var(--card-pad);
}

.pl-modal-title {
    font-weight: 800;
    font-size: 1.05rem;
    margin-bottom: calc(var(--space-half) + var(--size-2));
    text-align: center;
}

.pl-modal-body {
    line-height: 1.35;
    margin-bottom: var(--space);
    font-weight: 600;
    text-align: center;
}

.pl-modal-actions {
    display: flex;
    gap: var(--nav-pill-gap);
    justify-content: flex-end;
    align-items: center;
}

.pl-modal .btn-cancel,
.pl-modal .btn-delete {
    transform: none; /* prevent inherited translateY from hover rules visually shifting layout */
}

.pl-modal .btn-cancel:focus,
.pl-modal .btn-delete:focus {
    outline: var(--size-2) solid var(--accent-outline);
    outline-offset: var(--size-2);
}

.future-feature {
    padding: var(--btn-pad-y) var(--btn-pad-x);
    border-radius: var(--radius-inner);
    background: var(--glass-strong);
    color: var(--ink);
    font-weight: 700;
}

.drop-zone-row {
    display: flex;
    align-items: stretch;
    gap: var(--nav-pill-gap);
    padding-left: 0;
    padding-right: 0;
}

.drop-zone-row .future-feature {
    flex: 1;
}

#uploadDropZone {
    margin-top: var(--space);
    cursor: pointer;
}

#uploadDropZone.is-drop-target {
    outline: var(--size-2) dashed var(--accent-outline-strong);
    outline-offset: calc(var(--space-half) - var(--size-2));
    border-radius: var(--radius);
}

#uploadDropZone .delete-handle,
#uploadDropZone .drag-handle,
#uploadDropZone #dropZoneChooseBtn {
    cursor: pointer;
}

.article-page section.card.articles .carousel-slide img {
    height: var(--carousel-height);
    width: auto;
    max-width: var(--carousel-max-width);
    object-fit: contain;
    display: block;
    cursor: pointer;
}
