:root {
    --bg: #460044;
    --panel: #54004f;
    --panel2: #5c0057;
    --text: #ffffff;
    --muted: #d7c2d7;
    --border: #b99ab9;
    --accent: #ff9aaa;
    --accent2: #ffffff;
    --button-bg: #7f7cff;
    --button-border: #b8b8ff;
    --shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* v18: safe old-browser color fallbacks only.
   This keeps the v16 visual layout intact in modern browsers.
   Do NOT add float/grid fallbacks here; they changed the card layout in v17. */
header, nav, main, section, article, footer { display: block; }
body { background: #460044; color: #ffffff; }
a { color: #ff9aaa; }
a:hover { color: #ffffff; }
.nav { background: #460044; border-top: 1px solid #b99ab9; border-bottom: 1px solid #b99ab9; }
.nav a, .quick-links a, .button, .page-button { background: #7f7cff; border-color: #b8b8ff; color: #ffffff; }
.nav a.active, .quick-links a.active, .page-button.active, .buy-button, .video-actions .quick-buy-button, .video-actions .buy-button { background: #ff9aaa; border-color: #ff9aaa; color: #ffffff; }
.controls, .empty { background: #54004f; border-color: #b99ab9; }
.card, .video-card, .detail { background: #5c0057; border-color: #b99ab9; }
.search, .select { background: #f7eaf7; color: #000000; border-color: #b99ab9; }
.summary, .meta, .meta a, .small, .footer, .empty { color: #d7c2d7; }
.pill { background: #74146f; border-color: #a64aa1; color: #ffffff; }
.pill.big-video-library { background: #e9f3ff; border-color: #7fb2e8; color: #174f86; }
.updated, .share-x-link { color: #ff9aaa; }
.thumb-link, .video-thumb, .detail-media { background: #2e002c; }

*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}
a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent2);text-decoration:underline}
.wrap{max-width:1180px;width:calc(100% - 28px);margin:0 auto}.top{padding:24px 0 14px;text-align:center}.logo{display:block;max-width:760px;width:min(90%,760px);height:auto;margin:0 auto 14px}
.nav{position:sticky;top:0;z-index:10;background:#460044;border-top:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:0 4px 18px rgba(0,0,0,.25)}
.nav-inner{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:10px 0}.nav a,.quick-links a{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border:1px solid var(--button-border);border-radius:999px;background:var(--button-bg);color:#fff;font-weight:bold;font-size:13px;white-space:nowrap}.nav a:hover,.quick-links a:hover{background:#9996ff;color:#fff;text-decoration:none}.nav a.active,.quick-links a.active{background:var(--accent);border-color:var(--accent);color:#fff}
.controls{margin:22px 0;padding:16px;background:var(--panel);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.controls-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center}.controls-row .button{width:auto;min-width:0;justify-self:start;white-space:nowrap}.search{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;font-size:16px;background:#f7eaf7;color:#000}.button{padding:12px 14px;border:1px solid var(--button-border);border-radius:12px;background:var(--button-bg);color:#fff;font-weight:bold;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.button:hover{background:#9996ff;color:#fff;text-decoration:none}.small-button{padding:8px 11px;font-size:13px}
h1{margin:8px 0 12px;text-align:center;font-size:28px}.summary{margin:12px 0 18px;text-align:center;color:var(--muted);font-size:14px}.empty{padding:30px;text-align:center;background:var(--panel);border:1px solid var(--border);border-radius:18px;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px;margin:18px 0 34px}.card{background:var(--panel2);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column;position:relative}.card:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(0,0,0,.45)}.thumb-link{display:block;background:#2e002c;overflow:hidden;padding:4px;height:255px;text-align:center}.thumb{display:block;height:100%;width:auto;max-width:none;margin:0 auto;border-radius:12px}.model-thumb-fallback{height:100%;display:flex;align-items:center;justify-content:center;color:#d7c2d7;font-weight:bold;padding:14px;text-align:center}@supports(object-fit:contain){.thumb{width:100%;height:100%;max-width:none;object-fit:contain;object-position:top center}}@supports(aspect-ratio:2/3){.thumb-link{height:auto;aspect-ratio:2/3}}
.content{padding:9px 10px 8px;display:flex;flex-direction:column;flex:1}.name{margin:0 0 5px;font-size:14px;line-height:1.2;text-align:center}.name a{color:#fff}.name a:hover{color:var(--accent)}.updated{margin-top:5px;font-size:13px;color:var(--accent);text-align:center}.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:5px;margin:0 0 6px}.pill{display:inline-flex;align-items:center;justify-content:center;padding:3px 6px;border-radius:999px;background:#74146f;border:1px solid #a64aa1;color:#fff;font-size:12px;font-weight:bold;white-space:nowrap}.pill:hover{color:#fff;text-decoration:none}.pill.big-video-library{background:#e9f3ff;border-color:#7fb2e8;color:#174f86}
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;margin:18px 0 34px}.video-card{background:var(--panel2);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}.video-thumb{display:flex;align-items:center;justify-content:center;height:155px;background:#2e002c;text-decoration:none;color:#fff}.video-thumb img{width:100%;height:100%;object-fit:cover}.thumb-fallback,.detail-fallback{letter-spacing:2px;color:#d7c2d7;font-weight:bold}.video-body{padding:13px}.video-body h3{margin:0 0 6px;font-size:18px;line-height:1.2}.video-body h3 a{color:#fff}.meta,.meta a{font-size:13px;color:var(--muted)}.facts{font-size:13px;color:#fff;margin:8px 0}.facts span{color:var(--muted)}.video-body p{font-size:14px;line-height:1.35;color:#eadbea}.quick-links{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:8px 0 16px}
.detail{display:grid;grid-template-columns:minmax(260px,420px) 1fr;gap:18px;background:var(--panel2);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:16px;margin:18px 0 34px}.detail-media{background:#2e002c;border-radius:12px;min-height:260px;display:flex;align-items:center;justify-content:center;overflow:hidden}.detail-media img{width:100%;height:auto;display:block}.detail-info h1{text-align:left;margin-top:0}.detail-info p{line-height:1.45}.detail-facts{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.detail-facts span{border:1px solid var(--border);border-radius:999px;padding:7px 10px;background:#74146f}.small{font-size:12px;color:var(--muted)}
.pagination{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:0 0 34px}.page-button{display:inline-flex;align-items:center;justify-content:center;min-width:38px;padding:8px 11px;border:1px solid var(--button-border);border-radius:999px;background:var(--button-bg);color:#fff;font-weight:bold;font-size:13px;text-decoration:none}.page-button:hover{background:#9996ff;color:#fff;text-decoration:none}.page-button.active{background:var(--accent);border-color:var(--accent)}.footer{border-top:1px solid var(--border);padding:22px 0 30px;color:var(--muted);text-align:center;font-size:13px}.mobile-menu-button{display:none}
@media(max-width:720px){.controls-row{grid-template-columns:1fr}.combined-controls-row{grid-template-columns:minmax(0,1fr) auto}.combined-controls-row .combined-search-input{grid-column:1 / -1}.combined-controls-row .combined-sort-select{grid-column:1;width:100%;min-width:0}.combined-controls-row .combined-search-button{grid-column:2;justify-self:end;width:auto}.grid{grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:12px}.video-grid{grid-template-columns:1fr}.detail{grid-template-columns:1fr}.thumb-link{height:203px}.mobile-menu-button{display:block;width:calc(100% - 20px);margin:8px auto;padding:10px 12px;border:1px solid var(--button-border);border-radius:999px;background:var(--button-bg);color:#fff;font-weight:bold;font-size:15px;cursor:pointer}.nav-inner{display:none;padding:0 0 10px}.nav.open .nav-inner{display:flex}.nav a{flex:1 1 calc(50% - 8px);text-align:center}}

/* v3: model thumbnails are generated from video_product model + sc_volume only. */
.thumb-link .model-thumb-fallback {
    display: none;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
    padding: 18px;
    color: #ffffff;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    background: #2e002c;
}
.thumb-link.thumb-missing .model-thumb-fallback {
    display: flex;
}


/* v4: real video previews and buy buttons */
.video-thumb {
    height: auto;
    aspect-ratio: 3 / 2;
}
.video-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-top: 10px;
}
.buy-button {
    background: var(--accent);
    border-color: var(--accent);
    color: #ffffff !important;
}
.buy-button:hover {
    background: #ffb0bd;
    border-color: #ffb0bd;
    color: #ffffff !important;
}
.detail-info .buy-button {
    font-size: 16px;
    padding: 12px 18px;
}

/* v6: model sort controls */
.sort-controls {
    margin-top: -8px;
    padding: 10px 14px;
}
.model-sort-row {
    grid-template-columns: auto auto;
    justify-content: center;
}
.select {
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: 12px;
    font-size: 15px;
    background: #f7eaf7;
    color: #000000;
}
@media(max-width:720px){
    .model-sort-row { grid-template-columns: 1fr; }
    .select { width: 100%; }
}


/* v7: align video action buttons and add QuickBuy */
.video-card {
    display: flex;
    flex-direction: column;
}
.video-body {
    display: flex;
    flex-direction: column;
    flex: 1;
}
.video-body p {
    flex: 1 1 auto;
}
.video-actions {
    margin-top: auto;
    padding-top: 10px;
    min-height: 46px;
    align-items: flex-end;
}
.video-actions .button {
    min-width: 72px;
    text-align: center;
}
.quick-buy-button {
    background: #00a86b;
    border-color: #72e6b8;
    color: #ffffff !important;
}
.quick-buy-button:hover {
    background: #11bd7e;
    border-color: #8cf2c9;
    color: #ffffff !important;
}
.detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
.detail-actions .button {
    margin-right: 0;
}


/* v8: put QuickBuy / BUY / More on one row and match BUY color */
.video-grid {
    grid-template-columns: repeat(auto-fill, minmax(285px, 1fr));
}
.video-actions {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 7px;
    width: 100%;
    margin-top: auto;
    padding-top: 10px;
    min-height: 42px;
}
.video-actions .button {
    min-width: 0;
    padding: 8px 10px;
    font-size: 13px;
    line-height: 1;
    white-space: nowrap;
    border-radius: 14px;
}
.video-actions .quick-buy-button,
.video-actions .buy-button {
    background: var(--accent);
    border-color: var(--accent);
    color: #ffffff !important;
}
.video-actions .quick-buy-button:hover,
.video-actions .buy-button:hover {
    background: #ffb0bd;
    border-color: #ffb0bd;
    color: #ffffff !important;
}
.video-actions .quick-buy-button {
    flex: 1 1 104px;
}
.video-actions .buy-button {
    flex: 0 1 82px;
}
.video-actions .button:not(.quick-buy-button):not(.buy-button) {
    flex: 0 1 58px;
}
@media(max-width:720px){
    .video-grid { grid-template-columns: 1fr; }
    .video-actions .button { font-size: 13px; padding: 8px 9px; }
}

/* v10: tighter action buttons + Share on X link */
.video-actions {
    gap: 6px;
    justify-content: center;
    flex-wrap: nowrap;
}
.video-actions .button {
    flex: 0 0 auto !important;
    min-width: 0 !important;
    width: auto !important;
    padding: 8px 12px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    border-radius: 13px !important;
}
.video-actions .quick-buy-button {
    flex: 0 0 auto !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
}
.video-actions .buy-button {
    flex: 0 0 auto !important;
}
.video-actions .button:not(.quick-buy-button):not(.buy-button) {
    flex: 0 0 auto !important;
}
.share-row {
    text-align: center;
    margin-top: 7px;
}
.share-x-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: 12px;
    font-weight: bold;
    text-decoration: none;
}
.share-x-link:hover {
    color: #ffffff;
    text-decoration: underline;
}
.share-x-button {
    background: var(--button-bg);
    border-color: var(--button-border);
    color: #ffffff !important;
}
.share-x-button:hover {
    background: #9996ff;
    border-color: var(--button-border);
    color: #ffffff !important;
}
@media(max-width:720px){
    .video-actions .button {
        padding: 8px 10px !important;
        font-size: 12px !important;
    }
}

/* v16: search results show matching model cards first, then matching video cards */
.search-section {
    margin: 20px 0 34px;
}
.search-section h2 {
    margin: 8px 0 6px;
    text-align: center;
    font-size: 24px;
}
.search-models-section {
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,.25);
}


/* v22: favorite stars matched to the main home.php favorite-button style */
.fav-star {
    border-radius: 999px;
    border: 1px solid var(--button-border);
    background: rgba(70, 0, 68, 0.85);
    color: #d7c2d7;
    cursor: pointer;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}
.fav-star:hover {
    color: #ffffff;
    background: var(--button-bg);
    text-decoration: none;
}
.fav-star.active,
.fav-star.is-favorite {
    color: #ffcc00;
    background: rgba(70, 0, 68, 0.95);
    border-color: #ffcc00;
    text-decoration: none;
}
.model-fav-star {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 3;
    width: 28px;
    height: 28px;
    font-size: 17px;
    line-height: 24px;
}
.inline-fav-star {
    display: inline-block;
    width: 21px;
    height: 21px;
    font-size: 13px;
    line-height: 18px;
    margin: 0 5px 0 0;
    padding: 0;
    vertical-align: middle;
}
.video-card {
    position: relative;
}

/* v20: favorite toggle fallback/feedback */
.fav-star.saving {
    opacity: .65;
}


/* v23: customer purchased-video login link */
.member-nav-link {
    background: #ff9aaa !important;
    border-color: #ff9aaa !important;
    color: #ffffff !important;
}
.member-login-button {
    background: #ff9aaa !important;
    border-color: #ff9aaa !important;
    color: #ffffff !important;
}
.member-login-button:hover,
.member-nav-link:hover {
    background: #ffb0bd !important;
    border-color: #ffb0bd !important;
    color: #ffffff !important;
    text-decoration: none !important;
}
.already-bought-link {
    color: var(--muted);
    font-size: 12px;
    font-weight: bold;
    text-decoration: none;
}
.already-bought-link:hover {
    color: #ffffff;
    text-decoration: underline;
}
.share-sep {
    color: var(--muted);
    font-size: 12px;
    padding: 0 3px;
}


/* v26: keep mobile menu styling consistent from the first mobile breakpoint.
   Fixes the 721px-760px gap where PHP showed the Menu button before the main
   stylesheet's 720px mobile rule applied, leaving the browser-default gray button. */
@media (max-width: 760px) {
    .nav .mobile-menu-button {
        display: block;
        width: calc(100% - 36px);
        margin: 16px auto;
        padding: 16px 20px;
        border: 1px solid var(--button-border);
        border-radius: 999px;
        background: var(--button-bg);
        color: #ffffff;
        font-weight: bold;
        font-size: 15px;
        line-height: 1.2;
        text-align: center;
        cursor: pointer;
        appearance: none;
        -webkit-appearance: none;
        box-shadow: none;
    }

    .nav.open .mobile-menu-button {
        background: var(--accent);
        border-color: var(--accent);
        color: #ffffff;
    }
}


/* v32: combined videoshome search/sort row.
   Desktop: Search field | Sort dropdown | Search button.
   This fixes the Search button wrapping into a huge full-width second row. */
.combined-controls-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 10px;
    align-items: center;
}
.combined-controls-row .combined-search-input {
    min-width: 0;
}
.combined-controls-row .combined-sort-select {
    width: auto;
    min-width: 190px;
}
.combined-controls-row .combined-search-button {
    width: auto;
    min-width: 0;
    justify-self: start;
    white-space: nowrap;
}
@media(max-width:720px){
    .combined-controls-row {
        grid-template-columns: minmax(0, 1fr) auto;
    }
    .combined-controls-row .combined-search-input {
        grid-column: 1 / -1;
    }
    .combined-controls-row .combined-sort-select {
        grid-column: 1;
        width: 100%;
        min-width: 0;
    }
    .combined-controls-row .combined-search-button {
        grid-column: 2;
        justify-self: end;
        width: auto;
    }
}

/* v28: customer-selectable purple themes.  Classic is the existing default. */
:root,
body.theme-classic {
    --bg: #460044;
    --panel: #54004f;
    --panel2: #5c0057;
    --text: #ffffff;
    --muted: #d7c2d7;
    --border: #b99ab9;
    --accent: #ff9aaa;
    --accent2: #ffffff;
    --button-bg: #7f7cff;
    --button-border: #b8b8ff;
    --button-hover: #9996ff;
    --button-text: #ffffff;
    --accent-hover: #ffb0bd;
    --nav-bg: #460044;
    --input-bg: #f7eaf7;
    --input-text: #000000;
    --thumb-bg: #2e002c;
    --card-link: #ffffff;
    --body-copy: #eadbea;
    --pill-bg: #74146f;
    --pill-border: #a64aa1;
    --pill-text: #ffffff;
    --special-pill-bg: #e9f3ff;
    --special-pill-border: #7fb2e8;
    --special-pill-text: #174f86;
    --fav-bg: rgba(70, 0, 68, 0.85);
    --fav-active-bg: rgba(70, 0, 68, 0.95);
    --section-divider: rgba(255,255,255,.25);
    --shadow: 0 10px 30px rgba(0,0,0,.35);
}
body.theme-light {
    --bg: #f4e7f4;
    --panel: #ffffff;
    --panel2: #fbf4fb;
    --text: #2e0731;
    --muted: #725374;
    --border: #c59ac7;
    --accent: #9b2f84;
    --accent2: #5b145c;
    --button-bg: #8057c7;
    --button-border: #a98bda;
    --button-hover: #6b42b0;
    --button-text: #ffffff;
    --accent-hover: #b24897;
    --nav-bg: #ead3eb;
    --input-bg: #ffffff;
    --input-text: #1e1020;
    --thumb-bg: #dcc2df;
    --card-link: #3a0b3d;
    --body-copy: #3d2941;
    --pill-bg: #ead2ec;
    --pill-border: #bc86c0;
    --pill-text: #4a154e;
    --special-pill-bg: #f2e7ff;
    --special-pill-border: #a98bda;
    --special-pill-text: #4c287e;
    --fav-bg: rgba(255, 255, 255, 0.90);
    --fav-active-bg: rgba(255, 255, 255, 0.98);
    --section-divider: rgba(70,0,68,.22);
    --shadow: 0 8px 22px rgba(70,0,68,.16);
}
body.theme-dark {
    --bg: #120012;
    --panel: #210020;
    --panel2: #2b002b;
    --text: #fff7ff;
    --muted: #caa5cc;
    --border: #744274;
    --accent: #ff78b7;
    --accent2: #ffffff;
    --button-bg: #5a43bd;
    --button-border: #8879df;
    --button-hover: #725ee0;
    --button-text: #ffffff;
    --accent-hover: #ff95c7;
    --nav-bg: #120012;
    --input-bg: #f1dcf2;
    --input-text: #160016;
    --thumb-bg: #080008;
    --card-link: #ffffff;
    --body-copy: #f1d9f1;
    --pill-bg: #3b003c;
    --pill-border: #743777;
    --pill-text: #ffffff;
    --special-pill-bg: #201b42;
    --special-pill-border: #7469ce;
    --special-pill-text: #e5e0ff;
    --fav-bg: rgba(18, 0, 18, 0.88);
    --fav-active-bg: rgba(18, 0, 18, 0.96);
    --section-divider: rgba(255,255,255,.18);
    --shadow: 0 12px 34px rgba(0,0,0,.62);
}

.nav { background: var(--nav-bg); }
.nav a,
.quick-links a,
.button,
.page-button,
.nav .mobile-menu-button {
    background: var(--button-bg);
    border-color: var(--button-border);
    color: var(--button-text) !important;
}
.nav a:hover,
.quick-links a:hover,
.button:hover,
.page-button:hover,
.nav .mobile-menu-button:hover {
    background: var(--button-hover);
    color: var(--button-text) !important;
    text-decoration: none;
}
.nav a.active,
.quick-links a.active,
.page-button.active,
.buy-button,
.video-actions .quick-buy-button,
.video-actions .buy-button,
.member-nav-link,
.member-login-button,
.nav.open .mobile-menu-button {
    background: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #ffffff !important;
}
.buy-button:hover,
.video-actions .quick-buy-button:hover,
.video-actions .buy-button:hover,
.member-login-button:hover,
.member-nav-link:hover {
    background: var(--accent-hover) !important;
    border-color: var(--accent-hover) !important;
    color: #ffffff !important;
}
.search,
.select {
    background: var(--input-bg);
    color: var(--input-text);
    border-color: var(--border);
}
.card,
.video-card,
.detail,
.controls,
.empty {
    background: var(--panel2);
    border-color: var(--border);
}
.controls,
.empty { background: var(--panel); }
.thumb-link,
.video-thumb,
.detail-media,
.thumb-link .model-thumb-fallback {
    background: var(--thumb-bg);
}
.model-thumb-fallback,
.thumb-fallback,
.detail-fallback,
.summary,
.meta,
.meta a,
.small,
.footer,
.empty,
.already-bought-link,
.share-sep {
    color: var(--muted);
}
.name a,
.video-body h3 a {
    color: var(--card-link);
}
.name a:hover,
.video-body h3 a:hover,
.updated,
.share-x-link {
    color: var(--accent);
}
.video-body p {
    color: var(--body-copy);
}
.facts,
.detail-info p,
.detail-info h1,
h1,
.search-section h2 {
    color: var(--text);
}
.pill,
.detail-facts span {
    background: var(--pill-bg);
    border-color: var(--pill-border);
    color: var(--pill-text);
}
.pill.big-video-library {
    background: var(--special-pill-bg);
    border-color: var(--special-pill-border);
    color: var(--special-pill-text);
}
.search-models-section {
    border-bottom-color: var(--section-divider);
}
.fav-star {
    background: var(--fav-bg);
    color: var(--muted);
}
.fav-star:hover {
    background: var(--button-bg);
    color: #ffffff;
}
.fav-star.active,
.fav-star.is-favorite {
    background: var(--fav-active-bg);
    color: #ffcc00;
    border-color: #ffcc00;
}
.already-bought-link:hover,
.share-x-link:hover {
    color: var(--accent2);
}

.theme-picker {
    position: fixed;
    top: 10px;
    left: 10px;
    z-index: 99999;
    font-family: Arial, Helvetica, sans-serif;
}
.theme-toggle {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    border: 1px solid var(--button-border);
    background: var(--button-bg);
    color: #ffffff;
    box-shadow: var(--shadow);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
}
.theme-toggle:hover,
.theme-picker.open .theme-toggle {
    background: var(--accent);
    border-color: var(--accent);
}
.theme-menu {
    display: none;
    min-width: 118px;
    margin-top: 8px;
    padding: 8px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--panel);
    box-shadow: var(--shadow);
}
.theme-picker.open .theme-menu,
.theme-picker:focus-within .theme-menu {
    display: block;
}
.theme-menu button {
    display: block;
    width: 100%;
    margin: 0 0 6px;
    padding: 8px 10px;
    border: 1px solid var(--button-border);
    border-radius: 999px;
    background: var(--button-bg);
    color: var(--button-text);
    font-weight: bold;
    cursor: pointer;
    text-align: center;
}
.theme-menu button:last-child {
    margin-bottom: 0;
}
.theme-menu button:hover,
.theme-menu button.active {
    background: var(--accent);
    border-color: var(--accent);
    color: #ffffff;
}
@media(max-width:720px){
    .theme-picker {
        top: 8px;
        left: 8px;
    }
    .theme-toggle {
        width: 34px;
        height: 34px;
        font-size: 16px;
    }
}

/* v34: update countdown/date box copied from photo home.php */
.update-countdown {
    position: absolute;
    top: 6px;
    right: 8px;
    z-index: 999;
    padding: 6px 9px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: rgba(70, 0, 68, 0.88);
    color: #ffffff;
    font-size: 11px;
    line-height: 1.35;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.35);
    text-align: left;
    cursor: pointer;
}
.update-countdown strong {
    color: var(--accent);
}
.update-dropdown {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
    transition: max-height 0.25s ease, opacity 0.25s ease, margin-top 0.25s ease, padding-top 0.25s ease;
}
.update-countdown.open .update-dropdown {
    max-height: 420px;
    opacity: 1;
    margin-top: 7px;
    padding-top: 7px;
    border-top: 1px solid rgba(255, 255, 255, 0.35);
}
.update-dropdown ul {
    margin: 6px 0 0;
    padding-left: 18px;
}
.update-dropdown li {
    margin: 2px 0;
}
body.theme-light .update-countdown {
    background: rgba(255, 255, 255, 0.96);
    color: var(--text);
    border-color: var(--border);
    box-shadow: 0 4px 14px rgba(70, 0, 68, 0.18);
}
body.theme-light .update-countdown strong {
    color: var(--accent2);
}
body.theme-light .update-countdown.open .update-dropdown {
    border-top-color: rgba(70, 0, 68, 0.22);
}
@media (max-width: 1080px) {
    .update-countdown {
        display: none;
    }
}
@media (max-width: 720px) {
    .update-dropdown li {
        white-space: normal;
    }
}

