/* DOR Content Engine — dor.css */
/* Navy + Gold brand palette */
:root{
  --dor-navy:#1a2744;
  --dor-navy-mid:#253560;
  --dor-gold:#b8962e;
  --dor-gold-light:#f5ede0;
  --dor-gold-mid:#d4a83a;
  --dor-cream:#faf8f4;
  --dor-cream-dark:#f1ece2;
  --dor-ink:#1a1714;
  --dor-ink3:#6b6560;
  --dor-border:#e0d8cc;
  --dor-radius:10px;
  --dor-radius-lg:16px;
}

/* ---- Archive toolbar ---- */
.dor-archive__toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 0;border-bottom:1px solid var(--dor-border);margin-bottom:20px;}
.dor-search-wrap{position:relative;flex:1;min-width:200px;max-width:340px;display:flex;align-items:center;}
.dor-search-wrap svg{position:absolute;left:10px;color:var(--dor-ink3);pointer-events:none;}
.dor-search-wrap input{width:100%;padding:9px 12px 9px 30px;border:1px solid var(--dor-border);border-radius:var(--dor-radius);background:var(--dor-cream);font-size:13px;color:var(--dor-ink);outline:none;}
.dor-search-wrap input:focus{border-color:var(--dor-gold-mid);}
.dor-archive__toolbar select{padding:9px 28px 9px 10px;border:1px solid var(--dor-border);border-radius:var(--dor-radius);background:var(--dor-cream);font-size:13px;color:var(--dor-ink);}
.dor-archive__count{font-size:12px;color:var(--dor-ink3);margin-left:auto;}
.dor-archive__empty{color:var(--dor-ink3);padding:40px 0;text-align:center;}

/* ---- Post cards ---- */
.dor-archive__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;}
.dor-post-card{background:#fff;border:1px solid var(--dor-border);border-radius:var(--dor-radius-lg);overflow:hidden;display:flex;flex-direction:column;}
.dor-post-card__thumb{position:relative;height:160px;background:var(--dor-cream-dark);flex-shrink:0;}
.dor-post-card__thumb img{width:100%;height:100%;object-fit:cover;object-position:top;}
.dor-post-card__thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--dor-border);}

.dor-post-card__body{padding:12px 14px 10px;flex:1;display:flex;flex-direction:column;}
.dor-post-card__meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px;}
.dor-post-card__date{font-size:11px;color:var(--dor-ink3);}

.dor-post-card__moveable{font-size:11px;color:var(--dor-gold);title:attr(title);}
.dor-post-card__evergreen{font-size:10px;background:var(--dor-gold-light);color:var(--dor-gold);border-radius:4px;padding:1px 6px;font-weight:500;}
.dor-post-card__title{font-family:'Cormorant Garamond',Georgia,serif;font-size:18px;font-weight:600;color:var(--dor-ink);margin-bottom:5px;line-height:1.2;}
.dor-post-card__caption{font-size:12px;color:var(--dor-ink3);line-height:1.5;flex:1;}
.dor-post-card__foot{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 10px;border-top:1px solid var(--dor-border);margin-top:auto;}
.dor-post-card__view{font-size:12px;color:var(--dor-gold);font-weight:500;}

/* ---- Buttons ---- */
.dor-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;text-decoration:none;border:none;font-family:inherit;transition:background .15s;}
.dor-btn--dl{background:var(--dor-navy);color:#fff;}
.dor-btn--dl:hover{background:var(--dor-navy-mid);color:#fff;}
.dor-btn--lock{background:transparent;border:1px solid var(--dor-border);color:var(--dor-ink3);}
.dor-btn--lock:hover{border-color:var(--dor-gold-mid);color:var(--dor-gold);}

/* ---- Calendar grid ---- */
.dor-calendar{background:#fff;border:1px solid var(--dor-border);border-radius:var(--dor-radius-lg);overflow:hidden;}
.dor-cal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--dor-border);}
.dor-cal__title{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;font-weight:600;color:var(--dor-ink);}
.dor-cal__nav{background:none;border:1px solid var(--dor-border);border-radius:6px;padding:6px 12px;cursor:pointer;font-size:16px;color:var(--dor-ink);transition:background .15s;}
.dor-cal__nav:hover{background:var(--dor-cream-dark);}
.dor-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--dor-border);}
.dor-cal__dow{background:var(--dor-cream-dark);padding:8px 6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--dor-ink3);text-align:center;}
.dor-cal__cell{background:#fff;min-height:100px;padding:8px 6px;position:relative;display:flex;flex-direction:column;}
.dor-cal__cell--empty{background:var(--dor-cream-dark);}
.dor-cal__cell--today{background:#fefdf5;}
.dor-cal__day-num{font-size:13px;font-weight:600;color:var(--dor-ink);display:block;margin-bottom:4px;}
.dor-cal__cell--today .dor-cal__day-num{color:var(--dor-gold);background:var(--dor-gold-light);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.dor-cal__post-chip{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--dor-navy);background:var(--dor-cream-dark);border-radius:4px;padding:3px 6px;margin-bottom:3px;text-decoration:none;overflow:hidden;font-weight:500;}
.dor-cal__post-chip img{width:18px;height:18px;border-radius:2px;object-fit:cover;flex-shrink:0;}
.dor-cal__post-chip span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dor-cal__more{font-size:10px;color:var(--dor-ink3);}

/* ---- Week strip ---- */
.dor-week-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;}
.dor-week-day{background:#fff;border-radius:var(--dor-radius);padding:10px 9px 8px;min-height:120px;display:flex;flex-direction:column;gap:0;}
.dor-week-day--today{background:var(--dor-gold-light);}
.dor-week-day--empty{background:var(--dor-cream-dark);opacity:.8;}

/* Liturgical label — above the date, subtle but color-coded */
.dor-week-day__lect{display:block;font-size:9px;font-weight:600;letter-spacing:.03em;line-height:1.25;margin-bottom:4px;font-style:italic;border-radius:3px;padding:2px 4px;width:fit-content;}
.dor-week-day__lect--solemnity{color:#7a4f0e;background:#fef3d0;}
.dor-week-day__lect--feast{color:#1a3d6e;background:#ddeaf7;}
.dor-week-day__lect--named{color:#4a4a4a;background:#ece8e2;}

/* Date row */
.dor-week-day__date{display:flex;align-items:baseline;gap:4px;margin-bottom:8px;}
.dor-week-day__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--dor-ink3);}
.dor-week-day__num{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;font-weight:700;color:var(--dor-ink);line-height:1;}

/* Posts — the focal point */
.dor-week-day__posts{display:flex;flex-direction:column;gap:6px;flex:1;}
.dor-week-day__post{display:flex;align-items:flex-start;gap:7px;text-decoration:none;padding:4px 5px;border-radius:5px;transition:background .12s;}
.dor-week-day__post:hover{background:var(--dor-cream-dark);}
.dor-week-day__post img{width:38px;height:38px;border-radius:4px;object-fit:cover;flex-shrink:0;}
.dor-week-day__post-placeholder{width:38px;height:38px;background:var(--dor-border);border-radius:4px;flex-shrink:0;}
.dor-week-day__post-title{font-size:11px;font-weight:600;color:var(--dor-navy);line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}

/* No-content placeholder */
.dor-week-day__no-posts{font-size:10px;color:var(--dor-ink3);font-style:italic;margin:0;flex:1;}

/* Readings link — very small, bottom of card, unobtrusive */
.dor-week-day__readings{display:inline-block;margin-top:auto;padding-top:6px;font-size:9px;color:var(--dor-ink3);opacity:.5;text-decoration:none;transition:opacity .15s;white-space:nowrap;}
.dor-week-day__readings:hover{opacity:1;color:var(--dor-navy);}

/* ---- Single post ---- */
.dor-single__image-text{background:var(--dor-gold-light);border-left:3px solid var(--dor-gold-mid);padding:14px 18px;border-radius:0 8px 8px 0;margin-bottom:20px;font-size:15px;color:var(--dor-ink);font-style:italic;}
.dor-single__caption{margin-bottom:20px;}
.dor-single__caption h3{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--dor-ink3);margin-bottom:6px;}
.dor-single__caption p{font-size:15px;color:var(--dor-ink);line-height:1.7;}
.dor-single__images{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;}
.dor-single__image-item{display:flex;flex-direction:column;gap:8px;}
.dor-single__image-item img{width:100%;border-radius:8px;object-fit:cover;}

/* ---- Email gate modal ---- */
#dor-overlay{display:none;position:fixed;inset:0;background:rgba(26,23,20,.5);z-index:9998;backdrop-filter:blur(2px);}
#dor-overlay.is-open{display:block;}
#dor-modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;background:#fff;border-radius:var(--dor-radius-lg);padding:44px 36px 36px;width:90%;max-width:440px;box-shadow:0 20px 50px rgba(26,39,68,.18);text-align:center;}
#dor-modal.is-open{display:block;}
.dor-modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:22px;color:var(--dor-ink3);cursor:pointer;padding:4px 8px;border-radius:6px;}
.dor-modal-close:hover{background:var(--dor-cream-dark);}
.dor-modal-cross{width:28px;height:28px;position:relative;margin:0 auto 14px;}
.dor-modal-cross::before,.dor-modal-cross::after{content:'';position:absolute;background:var(--dor-gold);border-radius:2px;}
.dor-modal-cross::before{width:4px;height:28px;left:12px;top:0;}
.dor-modal-cross::after{width:28px;height:4px;left:0;top:12px;}
.dor-modal-eyebrow{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dor-gold);font-weight:500;margin-bottom:8px;}
.dor-modal-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:26px;font-weight:600;color:var(--dor-ink);margin-bottom:10px;line-height:1.2;}
.dor-modal-sub{font-size:13px;color:var(--dor-ink3);line-height:1.65;margin-bottom:20px;}
.dor-gate-label{display:block;font-size:12px;font-weight:500;color:var(--dor-ink);margin-bottom:6px;text-align:left;}
.dor-gate-input{width:100%;padding:11px 13px;border:1.5px solid var(--dor-border);border-radius:var(--dor-radius);font-size:14px;font-family:inherit;color:var(--dor-ink);background:var(--dor-cream);outline:none;box-sizing:border-box;margin-bottom:8px;}
.dor-gate-input:focus{border-color:var(--dor-gold-mid);}
.dor-gate-error{font-size:12px;color:#b42318;text-align:left;margin-bottom:8px;}
.dor-gate-submit{width:100%;padding:13px;background:var(--dor-navy);color:#fff;border:none;border-radius:var(--dor-radius);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;margin-bottom:12px;transition:background .15s;}
.dor-gate-submit:hover:not(:disabled){background:var(--dor-navy-mid);}
.dor-gate-submit:disabled{opacity:.6;cursor:not-allowed;}
.dor-modal-fine{font-size:11px;color:var(--dor-ink3);line-height:1.5;}

/* ---- Responsive ---- */
@media(max-width:768px){
  .dor-archive__list{grid-template-columns:1fr 1fr;}
  .dor-week-strip{grid-template-columns:repeat(7,1fr);gap:4px;}
  .dor-week-day{padding:6px 4px;min-height:90px;}
  .dor-week-day__num{font-size:16px;}
  .dor-week-day__post img,.dor-week-day__post-placeholder{width:28px;height:28px;}
  .dor-week-day__post-title{-webkit-line-clamp:2;font-size:10px;}
  .dor-week-day__no-posts{display:none;}
  .dor-week-day__lect{font-size:8px;}
  .dor-cal__cell{min-height:70px;padding:5px 4px;}
  .dor-cal__post-chip{font-size:9px;}
  #dor-modal{padding:36px 20px 28px;border-radius:14px;}
}
@media(max-width:480px){
  .dor-archive__list{grid-template-columns:1fr;}
  .dor-cal__post-chip span{display:none;}
  .dor-week-day__post span{display:none;}
}

/* ---- Video + carousel additions ---- */
.dor-post-card__play-overlay{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:44px;height:44px;border-radius:50%;
    background:rgba(26,39,68,.75);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:18px;pointer-events:none;
    padding-left:3px;
}
.dor-post-card__count-badge{
    position:absolute;bottom:7px;right:8px;
    background:rgba(26,23,20,.6);color:#fff;
    font-size:10px;padding:2px 8px;border-radius:999px;
    font-weight:500;
}

/* ============================================================
   CARD CAROUSEL
   ============================================================ */
.dor-post-card__thumb-wrap {
    position: relative;
    height: 180px;
    background: var(--dor-cream-dark);
    overflow: hidden;
    flex-shrink: 0;
}
.dor-card-single,
.dor-card-carousel {
    width: 100%;
    height: 100%;
    position: relative;
}
.dor-card-single img,
.dor-card-carousel img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}

/* Carousel track */
.dor-card-carousel__track {
    display: flex;
    height: 100%;
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    will-change: transform;
}
.dor-card-carousel__slide {
    min-width: 100%;
    height: 100%;
    position: relative;
    flex-shrink: 0;
}
.dor-card-carousel__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}

/* Prev/next buttons */
.dor-card-carousel__btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(26,39,68,.65);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 28px;
    height: 28px;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    opacity: 0;
    transition: opacity .15s;
    padding: 0 0 1px 0;
}
.dor-post-card:hover .dor-card-carousel__btn,
.dor-card-carousel__btn:focus {
    opacity: 1;
}
.dor-card-carousel__prev { left: 6px; }
.dor-card-carousel__next { right: 6px; }

/* Dot indicators */
.dor-card-carousel__dots {
    position: absolute;
    bottom: 7px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 4px;
    z-index: 2;
}
.dor-card-carousel__dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(255,255,255,.5);
    transition: background .15s, transform .15s;
}
.dor-card-carousel__dot.is-active {
    background: #fff;
    transform: scale(1.3);
}

/* Video overlays */
.dor-card-play-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}
.dor-card-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--dor-cream-dark);
    color: var(--dor-border);
}
.dor-card-placeholder--video {
    background: #e8eef8;
    color: var(--dor-navy);
}



/* Single post media grid */
.dor-single__media {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
    margin-top: 20px;
}
.dor-single__media-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.dor-single__media-item img {
    width: 100%;
    border-radius: 8px;
    object-fit: cover;
}
.dor-single__video-embed { border-radius: 8px; overflow: hidden; }
.dor-single__video-embed iframe { width: 100%; aspect-ratio: 16/9; border: none; }
.dor-single__video-note { font-size: 11px; color: var(--dor-ink3); }
.dor-single__image-text {
    background: var(--dor-gold-light);
    border-left: 3px solid var(--dor-gold-mid);
    padding: 14px 18px;
    border-radius: 0 8px 8px 0;
    margin-bottom: 20px;
    font-size: 15px;
    color: var(--dor-ink);
    font-style: italic;
}
.dor-single__caption h3 {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--dor-ink3);
    margin-bottom: 6px;
}
.dor-single__caption p { font-size: 15px; line-height: 1.7; }

@media (max-width: 480px) {
    .dor-card-carousel__btn { opacity: 1; width: 24px; height: 24px; font-size: 15px; }
    .dor-post-card__thumb-wrap { height: 150px; }
}

/* ---- Calendar/week "more" links ---- */
.dor-cal__more {
    display: block;
    font-size: 10px;
    color: var(--dor-navy);
    font-weight: 500;
    margin-top: 2px;
    text-decoration: none;
    padding: 1px 4px;
    border-radius: 3px;
    background: var(--dor-navy-light, #e8ecf4);
}
.dor-cal__more:hover { background: var(--dor-navy); color: #fff; text-decoration: none; }

.dor-week-day__more {
    display: block;
    font-size: 10px;
    color: var(--dor-navy);
    font-weight: 500;
    margin-top: 4px;
    text-decoration: none;
    padding: 2px 6px;
    border-radius: 4px;
    background: var(--dor-navy-light, #e8ecf4);
    text-align: center;
}
.dor-week-day__more:hover { background: var(--dor-navy); color: #fff; text-decoration: none; }

/* ---- Archive date filter badge ---- */
.dor-archive__date-filter {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 500;
    color: var(--dor-navy);
    background: var(--dor-navy-light, #e8ecf4);
    border: 1px solid #c3d0e8;
    padding: 5px 10px;
    border-radius: 6px;
}
.dor-archive__clear-date {
    color: var(--dor-ink3);
    font-size: 14px;
    line-height: 1;
    font-weight: 400;
    text-decoration: none;
    padding: 0 2px;
}
.dor-archive__clear-date:hover { color: var(--dor-navy); }

/* ---- Calendar readings ---- */
.dor-cal__readings {
    margin-top: auto;
    padding-top: 4px;
    font-size: 10px;
    line-height: 1.4;
}
.dor-cal__readings-toggle {
    display: inline-block;
    color: var(--dor-ink3);
    font-size: 8px;
    font-weight: 400;
    opacity: .35;
    text-decoration: none;
    transition: opacity .15s;
    white-space: nowrap;
    letter-spacing: .02em;
}
.dor-cal__readings-toggle:hover { opacity: .9; text-decoration: none; color: var(--dor-navy); }
.dor-cal__readings-refs {
    margin-top: 3px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.dor-cal__readings-ref {
    font-size: 10px;
    color: var(--dor-navy);
    font-weight: 500;
    text-decoration: none;
    display: block;
    opacity: .75;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dor-cal__readings-ref:hover { opacity: 1; text-decoration: underline; }
.dor-cal__readings-loading {
    font-size: 10px;
    color: var(--dor-border2);
    font-style: italic;
}

/* ---- Calendar holy day label ---- */
.dor-cal__holy-day{display:block;font-size:9px;font-weight:600;letter-spacing:.03em;line-height:1.25;margin-bottom:3px;font-style:italic;padding:1px 4px;border-radius:3px;width:fit-content;}
.dor-cal__holy-day--solemnity{color:#7a4f0e;background:#fef3d0;}
.dor-cal__holy-day--feast{color:#1a3d6e;background:#ddeaf7;}
.dor-cal__holy-day--named{color:#4a4a4a;background:#ece8e2;}

/* ============================================================
   DAY VIEW DRAWER
   ============================================================ */

/* Clickable cells */
.dor-cal__cell--clickable { cursor: pointer; }
.dor-cal__cell--clickable:hover { background: var(--dor-cream-dark); }
.dor-cal__cell--clickable:focus-visible { outline: 2px solid var(--dor-gold); outline-offset: -2px; }

/* Backdrop */
.dor-day-drawer { display: none; position: fixed; inset: 0; z-index: 1000; }
.dor-day-drawer.is-open { display: block; }
.dor-day-drawer__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,16,30,.45);
    backdrop-filter: blur(2px);
    animation: dvFadeIn .2s ease;
}
@keyframes dvFadeIn { from { opacity: 0; } to { opacity: 1; } }

/* Panel — slides in from right */
.dor-day-drawer__panel {
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: min(520px, 100vw);
    background: var(--dor-cream);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: -4px 0 32px rgba(10,16,30,.18);
    animation: dvSlideIn .22s cubic-bezier(.4,0,.2,1);
}
@keyframes dvSlideIn { from { transform: translateX(100%); } to { transform: translateX(0); } }

/* Header */
.dor-day-drawer__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 20px 20px 16px;
    background: var(--dor-navy);
    color: #fff;
    gap: 12px;
    flex-shrink: 0;
}
.dor-day-drawer__title-wrap { display: flex; flex-direction: column; gap: 4px; }
.dor-day-drawer__date { font-size: 13px; opacity: .75; font-weight: 500; letter-spacing: .03em; }
.dor-day-drawer__day-name {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 22px;
    font-weight: 600;
    line-height: 1.2;
}
.dor-day-drawer__close {
    background: rgba(255,255,255,.12);
    border: none;
    color: #fff;
    width: 32px; height: 32px;
    border-radius: 50%;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .14s;
}
.dor-day-drawer__close:hover { background: rgba(255,255,255,.25); }

/* Readings strip */
.dor-day-drawer__readings {
    padding: 10px 20px;
    background: var(--dor-cream-dark);
    border-bottom: 1px solid var(--dor-border);
    flex-shrink: 0;
}
.dv-readings { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.dv-reading {
    font-size: 11px;
    color: var(--dor-navy);
    background: var(--dor-navy-light);
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 500;
}
.dv-readings__link {
    font-size: 11px;
    color: var(--dor-gold);
    font-weight: 600;
    margin-left: 4px;
    white-space: nowrap;
}

/* Scrollable body */
.dor-day-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.dor-day-drawer__loading {
    text-align: center;
    color: var(--dor-ink3);
    font-style: italic;
    padding: 40px 0;
    font-size: 14px;
}
.dor-day-drawer__empty {
    text-align: center;
    color: var(--dor-ink3);
    padding: 40px 20px;
    font-size: 14px;
    font-style: italic;
}

/* Post cards in drawer */
.dv-card {
    background: #fff;
    border-radius: 10px;
    border: 1px solid var(--dor-border);
    display: flex;
    gap: 14px;
    overflow: hidden;
    transition: box-shadow .15s;
}
.dv-card:hover { box-shadow: 0 3px 14px rgba(26,39,68,.1); }
.dv-card__image-link { display: block; flex-shrink: 0; }
.dv-card__img {
    width: 100px;
    height: 100px;
    object-fit: cover;
    object-position: top;
    display: block;
}
.dv-card__img--placeholder {
    background: var(--dor-cream-dark);
    width: 100px;
    height: 100px;
}
.dv-card__body {
    padding: 12px 14px 12px 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 0;
}
.dv-card__meta { display: flex; gap: 6px; flex-wrap: wrap; }
.dv-card__type {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--dor-gold);
    background: var(--dor-gold-light);
    padding: 1px 6px;
    border-radius: 20px;
}
.dv-card__title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 17px;
    font-weight: 600;
    line-height: 1.25;
    margin: 0;
}
.dv-card__title a { color: var(--dor-ink); text-decoration: none; }
.dv-card__title a:hover { color: var(--dor-navy); }
.dv-card__caption {
    font-size: 12px;
    color: var(--dor-ink3);
    line-height: 1.4;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.dv-card__dl {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 4px;
    font-size: 11px;
    font-weight: 600;
    color: var(--dor-navy);
    background: var(--dor-navy-light);
    padding: 3px 10px;
    border-radius: 20px;
    text-decoration: none;
    width: fit-content;
    transition: background .14s;
}
.dv-card__dl:hover { background: var(--dor-navy); color: #fff; text-decoration: none; }
.dv-card__dl--locked { color: var(--dor-ink3); background: var(--dor-cream-dark); cursor: default; }

/* Footer */
.dor-day-drawer__footer {
    padding: 14px 20px;
    border-top: 1px solid var(--dor-border);
    background: #fff;
    flex-shrink: 0;
}
.dor-day-drawer__footer a {
    font-size: 13px;
    font-weight: 600;
    color: var(--dor-navy);
    text-decoration: none;
}
.dor-day-drawer__footer a:hover { color: var(--dor-gold); }

/* Mobile — full screen bottom sheet */
@media (max-width: 600px) {
    .dor-day-drawer__panel {
        top: auto;
        left: 0; right: 0; bottom: 0;
        width: 100%;
        max-height: 90vh;
        border-radius: 16px 16px 0 0;
        animation: dvSlideUp .22s cubic-bezier(.4,0,.2,1);
    }
    @keyframes dvSlideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
}
