/* WCL Photo Harvester - Admin Styles */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=IBM+Plex+Mono:wght@300;400;500&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap');

:root {
    --wcl-bg: #f5f0e8;
    --wcl-surface: #ffffff;
    --wcl-surface2: #f0ebe0;
    --wcl-border: #d8d0c0;
    --wcl-ink: #1a1612;
    --wcl-muted: #7a7060;
    --wcl-accent: #c8391a;
    --wcl-green: #2d6a4f;
    --wcl-gold: #e8a020;
    --wcl-mono: 'IBM Plex Mono', monospace;
    --wcl-sans: 'IBM Plex Sans', sans-serif;
    --wcl-display: 'Bebas Neue', cursive;
}

/* ── Wrap ─────────────────────────────────────────────────────────────────── */
.wcl-ph-wrap {
    background: var(--wcl-bg);
    margin: -20px -20px 0;
    min-height: 100vh;
    font-family: var(--wcl-sans);
    color: var(--wcl-ink);
    padding-bottom: 80px;
}

/* ── Header ───────────────────────────────────────────────────────────────── */
.wcl-ph-header {
    background: var(--wcl-surface);
    border-bottom: 3px solid var(--wcl-ink);
    padding: 20px 28px 16px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}
.wcl-ph-logo h1 {
    font-family: var(--wcl-display);
    font-size: 3rem;
    line-height: 0.9;
    color: var(--wcl-ink);
    margin: 0;
    padding: 0;
}
.wcl-ph-logo h1 span { color: var(--wcl-accent); }
.wcl-ph-sub {
    font-family: var(--wcl-mono);
    font-size: 0.62rem;
    color: var(--wcl-muted);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 5px 0 0;
}
.wcl-ph-settings-link {
    font-family: var(--wcl-mono);
    font-size: 0.75rem;
    color: var(--wcl-muted);
    text-decoration: none;
    border: 1.5px solid var(--wcl-border);
    border-radius: 4px;
    padding: 6px 14px;
    transition: border-color 0.15s, color 0.15s;
}
.wcl-ph-settings-link:hover { border-color: var(--wcl-ink); color: var(--wcl-ink); }

/* ── Layout ───────────────────────────────────────────────────────────────── */
.wcl-ph-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
}

/* ── Sidebar ──────────────────────────────────────────────────────────────── */
.wcl-ph-sidebar {
    background: var(--wcl-surface);
    border-right: 2px solid var(--wcl-border);
    padding: 20px 18px;
}
.wcl-ph-section-label {
    font-family: var(--wcl-mono);
    font-size: 0.6rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--wcl-muted);
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--wcl-border);
}
.wcl-ph-field { margin-bottom: 14px; }
.wcl-ph-field label {
    display: block;
    font-family: var(--wcl-mono);
    font-size: 0.64rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--wcl-muted);
    margin-bottom: 4px;
    font-weight: 400;
}
.wcl-ph-sidebar input[type="text"],
.wcl-ph-sidebar input[type="password"],
.wcl-ph-sidebar input[type="number"] {
    width: 100%;
    background: var(--wcl-surface2);
    border: 1.5px solid var(--wcl-border) !important;
    border-radius: 4px !important;
    padding: 8px 10px !important;
    color: var(--wcl-ink) !important;
    font-family: var(--wcl-mono) !important;
    font-size: 0.76rem !important;
    box-shadow: none !important;
    outline: none;
    transition: border-color 0.15s;
    height: auto !important;
}
.wcl-ph-sidebar input:focus { border-color: var(--wcl-ink) !important; }
.wcl-ph-hint {
    font-family: var(--wcl-mono);
    font-size: 0.6rem;
    color: var(--wcl-muted);
    margin-top: 4px;
    line-height: 1.5;
}
.wcl-ph-hint code, .wcl-ph-hint a { color: var(--wcl-accent); font-size: inherit; }
.wcl-ph-divider { border: none; border-top: 1px solid var(--wcl-border); margin: 16px 0; }
.wcl-ph-name-preview {
    background: var(--wcl-surface2);
    border: 1px dashed var(--wcl-border);
    border-radius: 4px;
    padding: 8px 10px;
    font-family: var(--wcl-mono);
    font-size: 0.6rem;
    color: var(--wcl-muted);
    margin-top: 7px;
    line-height: 1.6;
}
.wcl-ph-name-preview strong { color: var(--wcl-accent); }
.wcl-ph-name-preview code { color: var(--wcl-accent); background: none; padding: 0; font-size: inherit; }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.wcl-ph-btn-fetch {
    width: 100%;
    background: var(--wcl-ink);
    color: #f5f0e8;
    border: none;
    border-radius: 4px;
    padding: 11px 16px;
    font-family: var(--wcl-display);
    font-size: 1.2rem;
    letter-spacing: 0.08em;
    cursor: pointer;
    transition: background 0.15s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: auto;
    line-height: 1;
}
.wcl-ph-btn-fetch:hover:not(:disabled) { background: var(--wcl-accent); }
.wcl-ph-btn-fetch:disabled { opacity: 0.45; cursor: not-allowed; }
.wcl-ph-btn-fetch .btn-icon { font-size: 1rem; }
.wcl-ph-btn-sm {
    background: transparent;
    border: 1.5px solid var(--wcl-border);
    border-radius: 4px;
    padding: 6px 12px;
    font-family: var(--wcl-mono);
    font-size: 0.7rem;
    cursor: pointer;
    color: var(--wcl-ink);
    transition: border-color 0.15s;
    height: auto;
    line-height: 1.4;
}
.wcl-ph-btn-sm:hover { border-color: var(--wcl-ink); }
.wcl-ph-btn-drive {
    background: var(--wcl-green);
    color: #fff;
    border: none;
    border-radius: 4px;
    padding: 9px 18px;
    font-family: var(--wcl-display);
    font-size: 1rem;
    letter-spacing: 0.06em;
    cursor: pointer;
    transition: opacity 0.15s;
    height: auto;
    line-height: 1.4;
}
.wcl-ph-btn-drive:hover:not(:disabled) { opacity: 0.85; }
.wcl-ph-btn-drive:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Main area ────────────────────────────────────────────────────────────── */
.wcl-ph-main { padding: 20px 22px 80px; }
.wcl-ph-main-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; flex-wrap: wrap; gap: 10px; }
.wcl-ph-stats { display: flex; gap: 20px; }
.wcl-stat { font-family: var(--wcl-mono); font-size: 0.68rem; color: var(--wcl-muted); }
.wcl-stat strong { display: block; font-family: var(--wcl-display); font-size: 1.6rem; color: var(--wcl-ink); line-height: 1; margin-bottom: 1px; font-weight: 400; }
.wcl-ph-toolbar { display: flex; gap: 7px; }

/* ── Terminal ─────────────────────────────────────────────────────────────── */
.wcl-ph-terminal { background: var(--wcl-ink); border-radius: 5px; overflow: hidden; margin-bottom: 18px; }
.wcl-ph-tbar { display: flex; align-items: center; gap: 5px; padding: 7px 12px; border-bottom: 1px solid rgba(255,255,255,0.07); }
.td { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.td-r { background: #ff5f57; } .td-y { background: #febc2e; } .td-g { background: #28c840; }
.wcl-ph-ttitle { font-family: var(--wcl-mono); font-size: 0.6rem; color: rgba(255,255,255,0.28); margin-left: 5px; text-transform: uppercase; letter-spacing: 0.1em; }
.wcl-ph-tbody {
    padding: 10px 13px;
    font-family: var(--wcl-mono);
    font-size: 0.7rem;
    max-height: 160px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.wcl-ll { display: flex; gap: 9px; }
.wcl-lts { color: rgba(255,255,255,0.2); flex-shrink: 0; }
.wcl-lt { color: rgba(255,255,255,0.76); word-break: break-all; }
.wcl-ll.ok .wcl-lt { color: #43e97b; }
.wcl-ll.err .wcl-lt { color: #ff6b6b; }
.wcl-ll.info .wcl-lt { color: #64b5f6; }
.wcl-ll.warn .wcl-lt { color: #ffd54f; }

/* ── Product grid ─────────────────────────────────────────────────────────── */
.wcl-ph-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 11px; }
.wcl-pc {
    background: var(--wcl-surface);
    border: 2px solid var(--wcl-border);
    border-radius: 6px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.15s;
    position: relative;
}
.wcl-pc:hover { border-color: var(--wcl-ink); transform: translateY(-2px); box-shadow: 3px 3px 0 var(--wcl-border); }
.wcl-pc.sel { border-color: var(--wcl-accent); box-shadow: 3px 3px 0 rgba(200,57,26,0.2); }
.wcl-pck {
    position: absolute; top: 7px; right: 7px;
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--wcl-accent); display: none;
    align-items: center; justify-content: center; z-index: 2;
    font-size: 11px; color: white;
}
.wcl-pc.sel .wcl-pck { display: flex; }
.wcl-pt { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; background: var(--wcl-surface2); border-radius: 4px 4px 0 0; }
.wcl-pi { padding: 8px 9px; border-top: 1px solid var(--wcl-border); }
.wcl-pn { font-size: 0.71rem; font-weight: 600; line-height: 1.3; margin-bottom: 2px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.wcl-ps { font-family: var(--wcl-mono); font-size: 0.58rem; color: var(--wcl-muted); }
.wcl-pic { font-family: var(--wcl-mono); font-size: 0.57rem; color: var(--wcl-green); margin-top: 2px; }

/* ── Pagination ───────────────────────────────────────────────────────────── */
.wcl-ph-pagination { display: flex; gap: 6px; align-items: center; justify-content: center; margin-top: 22px; flex-wrap: wrap; font-family: var(--wcl-mono); font-size: 0.7rem; }
.wcl-pbtn { background: var(--wcl-surface); border: 1.5px solid var(--wcl-border); border-radius: 4px; padding: 5px 10px; cursor: pointer; color: var(--wcl-ink); transition: all 0.15s; height: auto; }
.wcl-pbtn:hover { border-color: var(--wcl-ink); }
.wcl-pbtn.act { background: var(--wcl-ink); color: var(--wcl-bg); border-color: var(--wcl-ink); }
.wcl-pbtn:disabled { opacity: 0.3; cursor: not-allowed; }

/* ── Action bar ───────────────────────────────────────────────────────────── */
.wcl-ph-action-bar {
    position: fixed; bottom: 0; left: 160px; right: 0;
    background: var(--wcl-surface);
    border-top: 2px solid var(--wcl-ink);
    padding: 12px 24px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; flex-wrap: wrap; z-index: 9999;
}
.wcl-ph-ainfo { font-family: var(--wcl-mono); font-size: 0.73rem; color: var(--wcl-muted); }
.wcl-ph-ainfo strong { color: var(--wcl-ink); font-size: 1rem; }
.wcl-ph-abtns { display: flex; gap: 9px; }
.wcl-ph-prog-wrap { background: var(--wcl-border); height: 3px; width: 100%; border-radius: 2px; overflow: hidden; margin-top: 8px; }
.wcl-ph-prog-bar { height: 100%; background: var(--wcl-green); width: 0; transition: width 0.3s ease; border-radius: 2px; }

/* ── Empty state ──────────────────────────────────────────────────────────── */
.wcl-ph-empty { text-align: center; padding: 60px 30px; color: var(--wcl-muted); }
.wcl-ph-empty-icon { font-size: 4rem; margin-bottom: 14px; }
.wcl-ph-empty p { font-family: var(--wcl-mono); font-size: 0.76rem; line-height: 1.8; }

/* ── Spinner ──────────────────────────────────────────────────────────────── */
.wcl-spinner { display: inline-block; width: 13px; height: 13px; border: 2px solid rgba(255,255,255,0.3); border-top-color: currentColor; border-radius: 50%; animation: wcl-spin 0.7s linear infinite; vertical-align: middle; }
@keyframes wcl-spin { to { transform: rotate(360deg); } }

/* ── Settings page ────────────────────────────────────────────────────────── */
.wcl-ph-settings-wrap .wcl-ph-layout { display: block; }
.wcl-ph-settings-form { max-width: 720px; padding: 28px; }
.wcl-ph-settings-card { background: var(--wcl-surface); border: 1.5px solid var(--wcl-border); border-radius: 8px; padding: 24px 28px; margin-bottom: 20px; }
.wcl-ph-settings-card h2 { font-family: var(--wcl-display); font-size: 1.5rem; letter-spacing: 0.04em; color: var(--wcl-ink); margin: 0 0 6px; font-weight: 400; }
.wcl-ph-settings-desc { font-family: var(--wcl-mono); font-size: 0.72rem; color: var(--wcl-muted); margin-bottom: 18px; line-height: 1.6; }
.wcl-ph-settings-table { width: 100%; border-collapse: collapse; }
.wcl-ph-settings-table th { text-align: left; font-family: var(--wcl-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--wcl-muted); font-weight: 400; padding: 10px 16px 10px 0; width: 180px; vertical-align: top; padding-top: 14px; }
.wcl-ph-settings-table td { padding: 8px 0; }
.wcl-ph-settings-table input.regular-text { font-family: var(--wcl-mono) !important; font-size: 0.82rem !important; }
.wcl-ph-settings-table p.description { font-family: var(--wcl-mono); font-size: 0.65rem; color: var(--wcl-muted); margin-top: 5px; }
.wcl-ph-settings-table code { color: var(--wcl-accent); background: rgba(200,57,26,0.08); padding: 1px 4px; border-radius: 3px; }
.wcl-ph-settings-form .submit { padding-left: 0; }
.wcl-ph-settings-form .button-primary { background: var(--wcl-ink) !important; border-color: var(--wcl-ink) !important; font-family: var(--wcl-display) !important; font-size: 1.1rem !important; letter-spacing: 0.06em !important; padding: 5px 20px !important; height: auto !important; border-radius: 4px !important; }
.wcl-ph-settings-form .button-primary:hover { background: var(--wcl-accent) !important; border-color: var(--wcl-accent) !important; }

/* ── OAuth / Drive connection status ──────────────────────────────────────── */
.wcl-drive-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--wcl-mono);
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 100px;
    text-decoration: none;
    white-space: nowrap;
}
.wcl-drive-status.connected {
    background: rgba(45,106,79,0.12);
    border: 1.5px solid rgba(45,106,79,0.35);
    color: var(--wcl-green);
}
.wcl-drive-status.disconnected {
    background: rgba(200,57,26,0.08);
    border: 1.5px solid rgba(200,57,26,0.3);
    color: var(--wcl-accent);
    cursor: pointer;
    transition: background 0.15s;
}
.wcl-drive-status.disconnected:hover { background: rgba(200,57,26,0.15); }

.wcl-drive-connected-box {
    background: rgba(45,106,79,0.08);
    border: 1.5px solid rgba(45,106,79,0.25);
    border-radius: 6px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    font-family: var(--wcl-mono);
    font-size: 0.7rem;
    color: var(--wcl-green);
}
.wcl-drive-connect-box {
    background: var(--wcl-surface2);
    border: 1px dashed var(--wcl-border);
    border-radius: 6px;
    padding: 12px;
    text-align: center;
}
.wcl-ph-btn-connect {
    display: inline-block;
    margin-top: 10px;
    background: var(--wcl-green);
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    padding: 8px 16px;
    font-family: var(--wcl-display);
    font-size: 1rem;
    letter-spacing: 0.05em;
    transition: opacity 0.15s;
}
.wcl-ph-btn-connect:hover { opacity: 0.85; color: #fff; }
.wcl-revoke-btn {
    background: transparent;
    border: 1px solid rgba(45,106,79,0.4);
    border-radius: 4px;
    padding: 3px 10px;
    font-family: var(--wcl-mono);
    font-size: 0.62rem;
    color: var(--wcl-green);
    cursor: pointer;
    transition: border-color 0.15s;
}
.wcl-revoke-btn:hover { border-color: var(--wcl-accent); color: var(--wcl-accent); }

/* ── Folder selected display ──────────────────────────────────────────────── */
.wcl-folder-selected {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--wcl-surface2);
    border: 1.5px solid var(--wcl-border);
    border-radius: 4px;
    padding: 8px 10px;
    min-height: 38px;
}
.wcl-folder-icon { font-size: 1rem; flex-shrink: 0; }
.wcl-folder-name {
    font-family: var(--wcl-mono);
    font-size: 0.72rem;
    color: var(--wcl-ink);
    flex: 1;
    word-break: break-all;
    line-height: 1.3;
}
.wcl-folder-browse-btn {
    background: var(--wcl-ink);
    color: var(--wcl-bg);
    border: none;
    border-radius: 3px;
    padding: 4px 10px;
    font-family: var(--wcl-mono);
    font-size: 0.65rem;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background 0.15s;
}
.wcl-folder-browse-btn:hover { background: var(--wcl-accent); }

/* ── Modal overlay ────────────────────────────────────────────────────────── */
.wcl-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(26, 22, 18, 0.55);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(2px);
}
.wcl-modal {
    background: var(--wcl-surface);
    border: 2px solid var(--wcl-ink);
    border-radius: 8px;
    width: 480px;
    max-width: calc(100vw - 40px);
    max-height: 70vh;
    display: flex;
    flex-direction: column;
    box-shadow: 8px 8px 0 rgba(26,22,18,0.15);
    animation: wcl-modal-in 0.15s ease;
}
@keyframes wcl-modal-in {
    from { opacity: 0; transform: translateY(-12px) scale(0.97); }
    to   { opacity: 1; transform: none; }
}

/* Modal header */
.wcl-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px 14px;
    border-bottom: 2px solid var(--wcl-ink);
}
.wcl-modal-title {
    font-family: var(--wcl-display);
    font-size: 1.4rem;
    letter-spacing: 0.04em;
    color: var(--wcl-ink);
}
.wcl-modal-close {
    background: none;
    border: none;
    font-size: 1rem;
    cursor: pointer;
    color: var(--wcl-muted);
    padding: 2px 6px;
    border-radius: 3px;
    transition: color 0.15s, background 0.15s;
    line-height: 1;
}
.wcl-modal-close:hover { color: var(--wcl-accent); background: rgba(200,57,26,0.08); }

/* Breadcrumb */
.wcl-modal-breadcrumb {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 18px;
    border-bottom: 1px solid var(--wcl-border);
    background: var(--wcl-surface2);
    flex-wrap: wrap;
    min-height: 36px;
}
.wcl-crumb {
    font-family: var(--wcl-mono);
    font-size: 0.68rem;
    color: var(--wcl-muted);
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 3px;
    transition: color 0.15s, background 0.15s;
    white-space: nowrap;
}
.wcl-crumb:hover { color: var(--wcl-ink); background: var(--wcl-border); }
.wcl-crumb-active {
    color: var(--wcl-ink);
    font-weight: 500;
    cursor: default;
    pointer-events: none;
}
.wcl-crumb-sep {
    font-family: var(--wcl-mono);
    font-size: 0.65rem;
    color: var(--wcl-border);
    flex-shrink: 0;
}

/* Folder list */
.wcl-modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 8px 10px;
    min-height: 200px;
    max-height: 360px;
}
.wcl-folder-loading {
    text-align: center;
    padding: 40px 20px;
    font-family: var(--wcl-mono);
    font-size: 0.75rem;
    color: var(--wcl-muted);
}
.wcl-folder-empty {
    text-align: center;
    padding: 40px 20px;
    font-family: var(--wcl-mono);
    font-size: 0.72rem;
    color: var(--wcl-muted);
}
.wcl-folder-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 5px;
    cursor: pointer;
    transition: background 0.1s;
    border: 1.5px solid transparent;
}
.wcl-folder-item:hover { background: var(--wcl-surface2); }
.wcl-folder-item.wcl-folder-selected-item {
    background: rgba(45,106,79,0.08);
    border-color: rgba(45,106,79,0.35);
}
.wcl-folder-item-icon { font-size: 1.1rem; flex-shrink: 0; }
.wcl-folder-item-name {
    font-family: var(--wcl-mono);
    font-size: 0.75rem;
    color: var(--wcl-ink);
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.wcl-folder-item-arrow {
    font-size: 0.75rem;
    color: var(--wcl-muted);
    flex-shrink: 0;
    padding: 3px 6px;
    border-radius: 3px;
    transition: background 0.1s, color 0.1s;
}
.wcl-folder-item-arrow:hover {
    background: var(--wcl-border);
    color: var(--wcl-ink);
}

/* Use Root option */
.wcl-use-root {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 5px;
    cursor: pointer;
    border: 1.5px dashed var(--wcl-border);
    margin-bottom: 8px;
    transition: border-color 0.15s, background 0.15s;
}
.wcl-use-root:hover { border-color: var(--wcl-ink); background: var(--wcl-surface2); }
.wcl-use-root.wcl-folder-selected-item { border-color: rgba(45,106,79,0.5); background: rgba(45,106,79,0.06); }
.wcl-use-root-name { font-family: var(--wcl-mono); font-size: 0.72rem; color: var(--wcl-muted); }

/* Modal footer */
.wcl-modal-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 18px;
    border-top: 1px solid var(--wcl-border);
    gap: 12px;
    flex-wrap: wrap;
}
.wcl-modal-current {
    font-family: var(--wcl-mono);
    font-size: 0.68rem;
    color: var(--wcl-muted);
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.wcl-ph-btn-select {
    background: var(--wcl-green);
    color: #fff;
    border: none;
    border-radius: 4px;
    padding: 8px 18px;
    font-family: var(--wcl-display);
    font-size: 1rem;
    letter-spacing: 0.05em;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.15s;
}
.wcl-ph-btn-select:hover { opacity: 0.85; }

/* ── Shared Drives entry ──────────────────────────────────────────────────── */
.wcl-shared-drives-entry {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 5px;
    cursor: pointer;
    border: 1.5px solid var(--wcl-border);
    margin-bottom: 4px;
    background: var(--wcl-surface2);
    transition: border-color 0.12s, background 0.12s;
}
.wcl-shared-drives-entry:hover {
    border-color: var(--wcl-ink);
    background: var(--wcl-border);
}

/* ── Product card thumbnail wrap + pick button ───────────────────────────── */
.wcl-pt-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 4px 4px 0 0;
    background: var(--wcl-surface2);
}
.wcl-pt-wrap .wcl-pt {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 0;
}
.wcl-img-pick-btn {
    position: absolute;
    bottom: 6px;
    right: 6px;
    background: rgba(26,22,18,0.72);
    color: #fff;
    border: none;
    border-radius: 4px;
    padding: 3px 8px;
    font-size: 0.65rem;
    font-family: var(--wcl-mono);
    cursor: pointer;
    backdrop-filter: blur(3px);
    transition: background 0.15s;
    z-index: 2;
    white-space: nowrap;
}
.wcl-img-pick-btn:hover { background: var(--wcl-accent); }

/* ── Image picker modal ───────────────────────────────────────────────────── */
.wcl-img-picker-overlay {
    position: fixed;
    inset: 0;
    background: rgba(26,22,18,0.6);
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(2px);
}
.wcl-img-picker {
    background: var(--wcl-surface);
    border: 2px solid var(--wcl-ink);
    border-radius: 8px;
    width: 520px;
    max-width: calc(100vw - 40px);
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 8px 8px 0 rgba(26,22,18,0.15);
    animation: wcl-modal-in 0.15s ease;
}
.wcl-img-picker-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 2px solid var(--wcl-ink);
    font-family: var(--wcl-mono);
    font-size: 0.75rem;
    color: var(--wcl-muted);
    gap: 12px;
}
.wcl-img-picker-header strong { color: var(--wcl-ink); }
.wcl-img-picker-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 10px;
    padding: 14px;
    overflow-y: auto;
}
.wcl-img-thumb {
    border: 2px solid var(--wcl-border);
    border-radius: 6px;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.15s, transform 0.1s;
    background: var(--wcl-surface2);
}
.wcl-img-thumb:hover { border-color: var(--wcl-ink); transform: scale(1.02); }
.wcl-img-thumb.active { border-color: var(--wcl-green); box-shadow: 0 0 0 2px rgba(45,106,79,0.25); }
.wcl-img-thumb img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    display: block;
}
.wcl-img-thumb-label {
    text-align: center;
    padding: 4px 6px;
    font-family: var(--wcl-mono);
    font-size: 0.62rem;
    color: var(--wcl-muted);
    background: var(--wcl-surface2);
}
.wcl-img-thumb.active .wcl-img-thumb-label { color: var(--wcl-green); font-weight: 600; }

/* ── Front-end shortcode adjustments ─────────────────────────────────────── */
.wcl-ph-frontend {
    max-width: 1400px;
    margin: 0 auto;
}
/* Some themes reset box-sizing — enforce it for our elements */
.wcl-ph-wrap *, .wcl-ph-wrap *::before, .wcl-ph-wrap *::after {
    box-sizing: border-box;
}
/* Login notice */
.wcl-ph-login-notice {
    font-family: var(--wcl-mono);
    font-size: 0.85rem;
    padding: 20px;
    background: var(--wcl-surface2);
    border: 1.5px solid var(--wcl-border);
    border-radius: 6px;
    text-align: center;
}

/* ── Per-product filename pattern on card ─────────────────────────────────── */
.wcl-card-pattern-wrap {
    margin-top: 7px;
    border-top: 1px solid var(--wcl-border);
    padding-top: 7px;
}
.wcl-card-pattern {
    width: 100%;
    font-family: var(--wcl-mono);
    font-size: 0.62rem;
    background: var(--wcl-surface);
    border: 1.5px solid var(--wcl-border);
    border-radius: 3px;
    padding: 4px 6px;
    color: var(--wcl-ink);
    box-sizing: border-box;
    transition: border-color 0.15s;
}
.wcl-card-pattern:focus {
    outline: none;
    border-color: var(--wcl-ink);
}
.wcl-pc.sel .wcl-card-pattern {
    background: rgba(45,106,79,0.05);
    border-color: rgba(45,106,79,0.3);
}
.wcl-card-pattern-preview {
    margin-top: 3px;
    font-family: var(--wcl-mono);
    font-size: 0.58rem;
    color: var(--wcl-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
