/* ============================================================
   Outlook skin - overrides applied when .wm-skin-outlook is set.
   Loads AFTER webmail.css so these selectors win.
   Palette mirrors the M365 Outlook on the Web Fluent design.
   ============================================================ */

.wm-skin-outlook {
    --wm-ol-accent: #0F6CBD;
    --wm-ol-accent-hover: #115EA3;
    --wm-ol-accent-pressed: #0C3B5E;
    --wm-ol-accent-bg: #DEECF9;
    --wm-ol-accent-bg-soft: #EDF6FC;
    --wm-ol-page: #FAF9F8;
    --wm-ol-surface: #FFFFFF;
    --wm-ol-border: #EDEBE9;
    --wm-ol-border-strong: #C8C6C4;
    --wm-ol-text: #323130;
    --wm-ol-text-muted: #605E5C;
    --wm-ol-text-soft: #A19F9D;
    --wm-ol-hover: #F3F2F1;
    --wm-ol-selected: #CCE4F7;
    --wm-ol-radius: 4px;
    --wm-ol-font: "Segoe UI", "Segoe UI Web (West European)", -apple-system, BlinkMacSystemFont, Roboto, "Helvetica Neue", sans-serif;
    --wm-ol-shadow: 0 1.6px 3.6px rgba(0,0,0,.13), 0 0.3px 0.9px rgba(0,0,0,.11);
    font-family: var(--wm-ol-font);
}

.wm-skin-outlook .wm,
.wm-skin-outlook .wm-msg-row,
.wm-skin-outlook .wm-folder,
.wm-skin-outlook .wm-compose,
.wm-skin-outlook .wm-settings,
.wm-skin-outlook .wm-reader-body .wm-html-body,
.wm-skin-outlook .wm-list-header,
.wm-skin-outlook .wm-filter,
.wm-skin-outlook .wm-reader-meta,
.wm-skin-outlook .wm-reader-subject {
    font-family: var(--wm-ol-font);
}

/* ── Layout shell ── */
.wm-skin-outlook .wm {
    background: var(--wm-ol-page);
}
.wm-skin-outlook .wm-sidebar {
    background: var(--wm-ol-page);
    border-right: 1px solid var(--wm-ol-border);
    width: 230px;
    min-width: 230px;
}

/* ── App rail (outlook-only) ──
   Fixed left strip on every portal page when the Outlook skin is on.
   The PHP include skips emitting the markup entirely on default-skin pages,
   but we keep `display: none` here as a belt-and-braces guard in case the
   nav element ever lands in the DOM (e.g. via a cached fragment).
   Padding-left only applies when the html element carries the skin class,
   so default-skin pages have no left gutter. */
.wm-app-rail { display: none !important; }
.wm-skin-outlook .wm-app-rail { display: flex !important; }
.wm-skin-outlook { padding-left: 48px; }
.wm-skin-outlook .wm-app-rail {
    flex-direction: column;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 48px;
    background: var(--wm-ol-page);
    border-right: 1px solid var(--wm-ol-border);
    padding: 4px 0 8px;
    gap: 2px;
    z-index: 200;  /* above .fh-header (sticky z-index:100) */
}
.wm-app-rail-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--wm-ol-radius);
    color: var(--wm-ol-text-muted);
    text-decoration: none;
    font-size: 20px;
}
.wm-app-rail-btn:hover {
    background: var(--wm-ol-hover);
    color: var(--wm-ol-text);
    text-decoration: none;
}
.wm-app-rail-active {
    background: var(--wm-ol-accent-bg);
    color: var(--wm-ol-accent) !important;
}
.wm-app-rail-active:hover { background: var(--wm-ol-accent-bg); }
.wm-app-rail-disabled {
    opacity: 0.55;
    cursor: default;
}
.wm-app-rail-disabled:hover { background: transparent; color: var(--wm-ol-text-muted); }
.wm-app-rail-spacer { flex: 1; }
/* Hide the rail on anything narrower than a roomy laptop. Most 13-14"
   laptops report ~1280-1366 CSS pixels; on those the rail + header chrome
   (logo, account tabs, mail/bell icons, avatar dropdown) ends up cramped.
   Below this we suppress the rail entirely and zero out body padding so
   the header reclaims the full width. The in-header mail icon still
   serves as the Mail entry point at small sizes. */
@media (max-width: 1280px) {
    .wm-skin-outlook { padding-left: 0; }
    .wm-skin-outlook .wm-app-rail { display: none !important; }
}
.wm-skin-outlook .wm-list-pane {
    border-right: 1px solid var(--wm-ol-border);
    background: var(--wm-ol-surface);
}
.wm-skin-outlook .wm-reader {
    border-left: 1px solid var(--wm-ol-border);
    background: var(--wm-ol-surface);
}

/* ── Compose button ── */
.wm-skin-outlook .wm-compose-btn {
    background: var(--wm-ol-accent);
    color: #fff;
    border-radius: var(--wm-ol-radius);
    margin: 10px;
    padding: 9px 12px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: var(--wm-ol-shadow);
    justify-content: flex-start;
    gap: 10px;
}
.wm-skin-outlook .wm-compose-btn:hover { background: var(--wm-ol-accent-hover); }
.wm-skin-outlook .wm-compose-btn:active { background: var(--wm-ol-accent-pressed); }
.wm-skin-outlook .wm-compose-btn .mdi { font-size: 16px; }

/* ── Folder tree ── */
.wm-skin-outlook .wm-folders { padding: 4px 6px 12px; }
.wm-skin-outlook .wm-folder {
    border-radius: var(--wm-ol-radius);
    padding: 6px 10px;
    font-size: 13px;
    color: var(--wm-ol-text);
    gap: 10px;
}
.wm-skin-outlook .wm-folder:hover { background: var(--wm-ol-hover); }
.wm-skin-outlook .wm-folder.active {
    background: var(--wm-ol-selected);
    color: var(--wm-ol-accent);
    font-weight: 600;
    border-left: 3px solid var(--wm-ol-accent);
    padding-left: 7px;
}
.wm-skin-outlook .wm-folder-icon { color: var(--wm-ol-accent); font-size: 17px; }
.wm-skin-outlook .wm-folder.active .wm-folder-icon { color: var(--wm-ol-accent); }
.wm-skin-outlook .wm-folder-count {
    background: transparent;
    color: var(--wm-ol-accent);
    font-weight: 600;
    padding: 0;
    font-size: 12px;
}
.wm-skin-outlook .wm-folder.active .wm-folder-count {
    background: transparent;
    color: var(--wm-ol-accent);
}

/* ── List header / search ── */
.wm-skin-outlook .wm-list-header {
    background: var(--wm-ol-surface);
    border-bottom: 1px solid var(--wm-ol-border);
    padding: 10px 14px;
}
.wm-skin-outlook .wm-search {
    background-color: var(--wm-ol-hover);
    border: 1px solid transparent;
    border-radius: var(--wm-ol-radius);
    font-size: 13px;
    padding: 6px 10px 6px 32px;
}
.wm-skin-outlook .wm-search:focus {
    background-color: var(--wm-ol-surface);
    border-color: var(--wm-ol-accent);
    box-shadow: 0 0 0 1px var(--wm-ol-accent);
}
.wm-skin-outlook .wm-search-all {
    background: var(--wm-ol-hover);
    border: 1px solid var(--wm-ol-border);
    color: var(--wm-ol-text-muted);
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-search-all:hover {
    background: var(--wm-ol-accent-bg);
    color: var(--wm-ol-accent);
    border-color: var(--wm-ol-accent);
}

/* Re-skin the All/Unread/Read filter pills to match the Outlook palette. */
.wm-skin-outlook .wm-filter {
    background: var(--wm-ol-surface);
    border-bottom: 1px solid var(--wm-ol-border);
    padding: 4px 14px;
}
.wm-skin-outlook .wm-filter-btn {
    border-radius: var(--wm-ol-radius);
    color: var(--wm-ol-text-muted);
    border-color: var(--wm-ol-border);
}
.wm-skin-outlook .wm-filter-btn:hover { background: var(--wm-ol-hover); color: var(--wm-ol-text); }
.wm-skin-outlook .wm-filter-btn.active {
    background: var(--wm-ol-accent);
    color: #fff;
    border-color: var(--wm-ol-accent);
}

/* ── Bulk action bar ── */
.wm-skin-outlook .wm-bulk {
    background: var(--wm-ol-accent-bg);
    border-bottom: 1px solid var(--wm-ol-accent);
    color: var(--wm-ol-accent);
}
.wm-skin-outlook .wm-bulk button {
    background: var(--wm-ol-surface);
    border: 1px solid var(--wm-ol-border-strong);
    color: var(--wm-ol-accent);
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-bulk button:hover { background: var(--wm-ol-accent-bg-soft); border-color: var(--wm-ol-accent); }

/* ── Message rows ── */
.wm-skin-outlook .wm-list { background: var(--wm-ol-surface); }
.wm-skin-outlook .wm-msg-row {
    padding: 10px 14px;
    border-bottom: 1px solid var(--wm-ol-border);
    gap: 10px;
    min-height: 64px;
    border-left: 3px solid transparent;
}
.wm-skin-outlook .wm-msg-row:hover { background: var(--wm-ol-hover); }
.wm-skin-outlook .wm-msg-row.unread {
    border-left-color: var(--wm-ol-accent);
}
.wm-skin-outlook .wm-msg-row.unread .wm-msg-from,
.wm-skin-outlook .wm-msg-row.unread .wm-msg-subject { color: var(--wm-ol-accent); }
.wm-skin-outlook .wm-msg-row.active {
    background: var(--wm-ol-selected);
}
.wm-skin-outlook .wm-msg-row.selected { background: var(--wm-ol-accent-bg); }
.wm-skin-outlook .wm-msg-cb { accent-color: var(--wm-ol-accent); }
.wm-skin-outlook .wm-msg-from { font-size: 13px; color: var(--wm-ol-text); font-weight: 600; }
.wm-skin-outlook .wm-msg-subject { font-size: 13px; color: var(--wm-ol-text-muted); margin-top: 1px; }
.wm-skin-outlook .wm-msg-snippet { font-size: 12px; color: var(--wm-ol-text-soft); }
.wm-skin-outlook .wm-msg-date { font-size: 11px; color: var(--wm-ol-text-soft); }
.wm-skin-outlook .wm-msg-star.flagged { color: #C19C00; }
.wm-skin-outlook .wm-msg-answered { color: var(--wm-ol-accent); }
.wm-skin-outlook .wm-thread-badge { background: var(--wm-ol-border); color: var(--wm-ol-text-muted); }
.wm-skin-outlook .wm-msg-row.unread .wm-thread-badge,
.wm-skin-outlook .wm-msg-row.active .wm-thread-badge { background: var(--wm-ol-accent); color: #fff; }

/* Avatars - Outlook uses square-rounded tiles */
.wm-skin-outlook .wm-avatar { border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .wm-avatar-img { border-radius: var(--wm-ol-radius); }

/* ── Reading pane (ribbon-style command bar + body) ── */
.wm-skin-outlook .wm-reader-head {
    padding: 14px 18px 12px;
    border-bottom: 1px solid var(--wm-ol-border);
    background: var(--wm-ol-surface);
}
.wm-skin-outlook .wm-reader-subject {
    font-size: 20px;
    font-weight: 600;
    color: var(--wm-ol-text);
    margin-bottom: 10px;
    line-height: 1.3;
}
.wm-skin-outlook .wm-reader-meta { color: var(--wm-ol-text-muted); font-size: 12px; }
.wm-skin-outlook .wm-reader-meta strong { color: var(--wm-ol-text); }
.wm-skin-outlook .wm-reader-actions { gap: 4px; margin-top: 10px; }
.wm-skin-outlook .wm-reader-actions button {
    background: transparent;
    border: 1px solid transparent;
    color: var(--wm-ol-text);
    border-radius: var(--wm-ol-radius);
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 500;
}
.wm-skin-outlook .wm-reader-actions button:hover {
    background: var(--wm-ol-accent-bg-soft);
    border-color: transparent;
    color: var(--wm-ol-accent);
}
.wm-skin-outlook .wm-reader-actions .mdi { color: var(--wm-ol-accent); font-size: 17px; }

/* Top ribbon - make it visually a "command bar" */
.wm-skin-outlook .wm-reader-actions-top {
    margin: 0 -18px 12px;
    padding: 6px 18px 10px;
    border-bottom: 1px solid var(--wm-ol-border);
    background: var(--wm-ol-page);
    gap: 2px;
}
.wm-skin-outlook .wm-reader-actions-top button {
    background: transparent;
    border: 1px solid transparent;
    color: var(--wm-ol-text);
    padding: 5px 10px;
    font-size: 12px;
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-reader-actions-top button:hover {
    background: var(--wm-ol-accent-bg-soft);
    border-color: var(--wm-ol-border);
    color: var(--wm-ol-accent);
}
.wm-skin-outlook .wm-reader-actions-top .mdi { color: var(--wm-ol-accent); }

.wm-skin-outlook .wm-reader-body { padding: 18px 22px; }
.wm-skin-outlook .wm-reader-body .wm-html-body { color: var(--wm-ol-text); line-height: 1.55; }
.wm-skin-outlook .wm-reader-body .wm-html-body a { color: var(--wm-ol-accent); }

/* ── Conversation cards ── */
.wm-skin-outlook .wm-conv-card {
    background: var(--wm-ol-surface);
    border: 1px solid var(--wm-ol-border);
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-conv-card.expanded { box-shadow: var(--wm-ol-shadow); }
.wm-skin-outlook .wm-conv-card.unseen { border-left: 3px solid var(--wm-ol-accent); }
.wm-skin-outlook .wm-conv-card.current .wm-conv-card-head { background: var(--wm-ol-accent-bg-soft); }

/* ── Attachments ── */
.wm-skin-outlook .wm-att {
    background: var(--wm-ol-page);
    border: 1px solid var(--wm-ol-border);
    color: var(--wm-ol-text);
}
.wm-skin-outlook .wm-att:hover { background: var(--wm-ol-accent-bg-soft); border-color: var(--wm-ol-accent); }

/* ── Quick reply ── */
.wm-skin-outlook .wm-quick-reply { background: var(--wm-ol-page); border-top: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-qr-input:focus { border-color: var(--wm-ol-accent); box-shadow: 0 0 0 1px var(--wm-ol-accent); }
.wm-skin-outlook .wm-qr-send {
    background: var(--wm-ol-accent);
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-qr-send:hover { background: var(--wm-ol-accent-hover); }

/* ── Compose ── */
.wm-skin-outlook .wm-compose {
    border-radius: var(--wm-ol-radius) var(--wm-ol-radius) 0 0;
    box-shadow: 0 -8px 28px rgba(0,0,0,0.18);
}
.wm-skin-outlook .wm-compose-head { background: var(--wm-ol-page); border-bottom: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-compose-field { border-bottom: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-compose-field label { color: var(--wm-ol-text-muted); font-weight: 600; font-size: 12px; }
.wm-skin-outlook .wm-compose-footer { background: var(--wm-ol-page); border-top: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-compose-send {
    background: var(--wm-ol-accent);
    border-radius: var(--wm-ol-radius);
    padding: 7px 18px;
}
.wm-skin-outlook .wm-compose-send:hover { background: var(--wm-ol-accent-hover); }

/* ── Settings modal ── */
.wm-skin-outlook .wm-settings { border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .wm-settings-head { background: var(--wm-ol-page); border-bottom: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-settings-foot { background: var(--wm-ol-page); border-top: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-settings-foot button:last-child { background: var(--wm-ol-accent) !important; }
.wm-skin-outlook .wm-settings-foot button:last-child:hover { background: var(--wm-ol-accent-hover) !important; }

/* ── Account tabs (browser-tab strip) ── */
.wm-skin-outlook .wm-account-tabs {
    background: var(--wm-ol-page);
    border-bottom: 1px solid var(--wm-ol-border);
}
.wm-skin-outlook .wm-account-tab {
    background: transparent;
    border: 1px solid transparent;
    border-bottom: none;
    color: var(--wm-ol-text-muted);
}
.wm-skin-outlook .wm-account-tab:hover {
    background: var(--wm-ol-hover);
    color: var(--wm-ol-text);
}
.wm-skin-outlook .wm-account-tab-active {
    background: var(--wm-ol-surface);
    border-color: var(--wm-ol-border);
    color: var(--wm-ol-accent);
    font-weight: 600;
}
.wm-skin-outlook .wm-account-tab-add { border-color: var(--wm-ol-border-strong); color: var(--wm-ol-text-muted); }

/* ── Spinner / loading ── */
.wm-skin-outlook .wm-spinner { border-top-color: var(--wm-ol-accent); }

/* ── Toast / undo ── */
.wm-skin-outlook .wm-toast { background: var(--wm-ol-text); border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .wm-toast-undo { color: #9DDBFF; }

/* ── Search overlay / modals ── */
.wm-skin-outlook .wm-search-modal { border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .wm-search-modal-head .mdi { color: var(--wm-ol-accent); }
.wm-skin-outlook .wm-search-modal-fill { background: var(--wm-ol-accent); }
.wm-skin-outlook .wm-thread-modal { border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .wm-thread-head { background: var(--wm-ol-page); }
.wm-skin-outlook .wm-thread-tools button:hover {
    background: var(--wm-ol-accent-bg-soft);
    border-color: var(--wm-ol-accent);
    color: var(--wm-ol-accent);
}

/* ── Pre-send modal ── */
.wm-skin-outlook .wm-presend-modal { border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .wm-presend-btn-send {
    background: var(--wm-ol-accent);
    border-color: var(--wm-ol-accent);
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-presend-btn-send:hover { background: var(--wm-ol-accent-hover); border-color: var(--wm-ol-accent-hover); }

/* ── Pre-send fix button ── */
.wm-skin-outlook .wm-presend-fix-btn {
    background: var(--wm-ol-accent);
    border-radius: var(--wm-ol-radius);
}
.wm-skin-outlook .wm-presend-fix-btn:hover:not(:disabled) { background: var(--wm-ol-accent-hover); }

/* ── Pager ── */
.wm-skin-outlook .wm-pager { background: var(--wm-ol-surface); border-top: 1px solid var(--wm-ol-border); }
.wm-skin-outlook .wm-pager button { border-radius: var(--wm-ol-radius); }

/* ── Bell notif panel ── */
.wm-skin-outlook .wm-bell-panel { border-radius: var(--wm-ol-radius); border-color: var(--wm-ol-border); }
.wm-skin-outlook .wm-bell-head { background: var(--wm-ol-page); }
.wm-skin-outlook .wm-send-notif { border-radius: var(--wm-ol-radius); }

/* ── Skin picker (in Settings - visible regardless of active skin so user
   can switch back) ── */
.wm-skin-picker {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.wm-skin-card {
    flex: 1 1 140px;
    min-width: 140px;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    padding: 10px;
    cursor: pointer;
    background: #fff;
    transition: border-color .12s, transform .08s;
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
    text-align: left;
}
.wm-skin-card:hover { border-color: #94a3b8; }
.wm-skin-card.active { border-color: #1e3a8a; box-shadow: 0 0 0 1px #1e3a8a; }
.wm-skin-outlook .wm-skin-card.active { border-color: var(--wm-ol-accent); box-shadow: 0 0 0 1px var(--wm-ol-accent); }
.wm-skin-thumb {
    height: 64px;
    border-radius: 4px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    position: relative;
    overflow: hidden;
}
.wm-skin-thumb-default {
    background: linear-gradient(90deg, #1e3a8a 0 30%, #e0e7ff 30% 35%, #fff 35%);
}
.wm-skin-thumb-default::after {
    content: ""; position: absolute; left: 32%; top: 8px; right: 8px; height: 4px; background: #cbd5e1; border-radius: 2px;
    box-shadow: 0 8px 0 #e2e8f0, 0 16px 0 #e2e8f0, 0 24px 0 #e2e8f0, 0 32px 0 #e2e8f0;
}
.wm-skin-thumb-outlook {
    background: linear-gradient(90deg, #FAF9F8 0 32%, #FFF 32%);
}
.wm-skin-thumb-outlook::before {
    content: ""; position: absolute; left: 0; right: 0; top: 0; height: 10px; background: #0F6CBD;
}
.wm-skin-thumb-outlook::after {
    content: ""; position: absolute; left: 36%; top: 18px; right: 8px; height: 4px; background: #C8C6C4; border-radius: 2px;
    box-shadow: 0 8px 0 #EDEBE9, 0 16px 0 #EDEBE9, 0 24px 0 #EDEBE9, 0 32px 0 #EDEBE9;
}
.wm-skin-card-label { font-size: 12px; font-weight: 600; color: #334155; }
.wm-skin-card-desc  { font-size: 11px; color: #94a3b8; line-height: 1.35; }


/* ── Portal header (Freedom Cloud .fh-header) - recoloured for Outlook ──
   Scoped to .wm-skin-outlook so it only repaints when the user is on
   webmail with the Outlook skin selected. Other pages keep the portal brand. */
.wm-skin-outlook .fh-header {
    background: var(--wm-ol-accent);
    border-bottom: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 1.6px 3.6px rgba(0,0,0,0.13);
}
.wm-skin-outlook .fh-header-inner { height: 48px; min-width: 0; }
.wm-skin-outlook .fh-header .logo { height: 28px; max-width: 100%; }
/* Logo never gets pushed off-screen on narrow viewports - the flex item
   shrinks before the header-menu (icons + avatar) does. */
.wm-skin-outlook .fh-header-inner > a:first-child { min-width: 0; flex-shrink: 1; overflow: hidden; }
.wm-skin-outlook .fh-header-menu { flex-shrink: 0; }
.wm-skin-outlook .fh-menu-trigger { border-radius: var(--wm-ol-radius); padding: 4px 8px; }
.wm-skin-outlook .fh-menu-trigger:hover { background: rgba(255,255,255,0.15); }
.wm-skin-outlook .fh-menu-avatar {
    border-radius: var(--wm-ol-radius);
    width: 28px;
    height: 28px;
    background: rgba(255,255,255,0.2);
    border: none;
    font-size: 11px;
}
.wm-skin-outlook .fh-menu-avatar img { border-radius: var(--wm-ol-radius); }
.wm-skin-outlook .fh-menu-chevron { color: rgba(255,255,255,0.75); }

/* Dropdown card – square the Outlook way, blue hover accent */
.wm-skin-outlook .fh-menu-dropdown {
    border-radius: var(--wm-ol-radius);
    border-color: var(--wm-ol-border);
    box-shadow: var(--wm-ol-shadow);
}
.wm-skin-outlook .fh-menu-header {
    background: var(--wm-ol-page);
    border-bottom: 1px solid var(--wm-ol-border);
}
.wm-skin-outlook .fh-menu-name { color: var(--wm-ol-text); }
.wm-skin-outlook .fh-menu-email { color: var(--wm-ol-text-soft); }
.wm-skin-outlook .fh-menu-dropdown a { color: var(--wm-ol-text); }
.wm-skin-outlook .fh-menu-dropdown a:hover {
    background: var(--wm-ol-accent-bg-soft);
    color: var(--wm-ol-accent);
}
.wm-skin-outlook .fh-menu-dropdown a:hover .mdi { color: var(--wm-ol-accent); }
.wm-skin-outlook .fh-menu-divider { border-top-color: var(--wm-ol-border); }

/* Calendar peek - tighter radius, Outlook blue accent on the header chrome */
.wm-skin-outlook .wm-invite-card {
    border-radius: var(--wm-ol-radius);
    border-color: var(--wm-ol-border);
    background: var(--wm-ol-accent-bg-soft);
}
.wm-skin-outlook .wm-invite-head { color: var(--wm-ol-accent); }
.wm-skin-outlook .wm-invite-btn { border-radius: var(--wm-ol-radius); }

/* Mail icon + bell already inherit the white-on-blue look; just tweak the
   unread badge so it pops against the new bg. */
.wm-skin-outlook #fh-mail-badge,
.wm-skin-outlook .wm-bell-badge {
    box-shadow: 0 0 0 1.5px var(--wm-ol-accent);
}

/* Account tabs strip sits directly under the header - line it up with the
   recoloured header so it doesn't look like a separate stripe. */
.wm-skin-outlook .wm-account-tabs {
    background: var(--wm-ol-accent);
    border-bottom: 1px solid rgba(0,0,0,0.1);
    padding: 6px 8px 0;
}
.wm-skin-outlook .wm-account-tab {
    background: rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.85);
    border-color: transparent;
    border-radius: var(--wm-ol-radius) var(--wm-ol-radius) 0 0;
}
.wm-skin-outlook .wm-account-tab:hover {
    background: rgba(255,255,255,0.22);
    color: #fff;
}
.wm-skin-outlook .wm-account-tab-active {
    background: var(--wm-ol-surface);
    color: var(--wm-ol-accent);
    border-color: var(--wm-ol-border);
}
.wm-skin-outlook .wm-account-tab-add {
    background: transparent;
    border: 1px dashed rgba(255,255,255,0.5);
    color: rgba(255,255,255,0.8);
}
.wm-skin-outlook .wm-account-tab-add:hover {
    background: rgba(255,255,255,0.12);
    color: #fff;
    border-color: rgba(255,255,255,0.85);
}

/* ── Date group headers (outlook-only) ──
   Injected client-side between message rows by WM._applyOutlookGroupingAndActions().
   Hidden in default skin. Sticky so the bucket label stays visible while
   scrolling through that bucket's messages. */
.wm-date-group { display: none; }
.wm-skin-outlook .wm-date-group {
    display: block;
    padding: 8px 14px 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--wm-ol-text-muted);
    background: var(--wm-ol-surface);
    border-bottom: 1px solid var(--wm-ol-border);
    letter-spacing: 0.4px;
    position: sticky;
    top: 0;
    z-index: 2;
}
.wm-skin-outlook .wm-date-group:first-child { padding-top: 6px; }

/* ── Done button on row hover (outlook-only) ──
   A circle-check appended to every row by _applyOutlookGroupingAndActions().
   Click = archive immediately (no two-step "flag then complete"). */
.wm-msg-done { display: none; }
.wm-skin-outlook .wm-msg-done {
    display: none;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1.5px solid var(--wm-ol-border-strong);
    background: var(--wm-ol-surface);
    color: var(--wm-ol-text-muted);
    align-items: center;
    justify-content: center;
    font-size: 18px;
    cursor: pointer;
    line-height: 1;
    padding: 0;
}
.wm-skin-outlook .wm-msg-row:hover .wm-msg-done { display: flex; }
.wm-skin-outlook .wm-msg-done:hover {
    background: #107C10;
    border-color: #107C10;
    color: #fff;
}

/* Pin button - sits to the left of the Done button (right side of row),
   stays visible when the row is pinned, hover-only when unpinned. */
.wm-msg-pin { display: none; }
.wm-skin-outlook .wm-msg-pin {
    display: none;
    position: absolute;
    right: 44px; /* leaves room for the Done button at right:10px */
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1.5px solid var(--wm-ol-border-strong);
    background: var(--wm-ol-surface);
    color: var(--wm-ol-text-muted);
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}
.wm-skin-outlook .wm-msg-pin .mdi { font-size: 14px; line-height: 1; }
.wm-skin-outlook .wm-msg-row:hover .wm-msg-pin { display: flex; }
.wm-skin-outlook .wm-msg-pin:hover {
    background: var(--wm-ol-accent-bg-soft);
    color: var(--wm-ol-accent);
    border-color: var(--wm-ol-accent);
}
/* Pinned state - always visible (not just on hover) and tinted */
.wm-skin-outlook .wm-msg-pin-active {
    display: flex;
    background: var(--wm-ol-accent);
    border-color: var(--wm-ol-accent);
    color: #fff;
    transform: translateY(-50%) rotate(45deg);
}
.wm-skin-outlook .wm-msg-pin-active:hover {
    background: var(--wm-ol-accent-hover);
    border-color: var(--wm-ol-accent-hover);
    color: #fff;
}

/* "Pinned" group header sits above the lifted pinned rows */
.wm-skin-outlook .wm-date-group-pinned {
    color: var(--wm-ol-accent);
    display: flex;
    align-items: center;
    gap: 6px;
}
.wm-skin-outlook .wm-date-group-pinned .mdi { font-size: 13px; transform: rotate(45deg); }
.wm-skin-outlook .wm-msg-pinned { background: rgba(15,108,189,0.04); }
.wm-skin-outlook .wm-msg-pinned:hover { background: var(--wm-ol-hover); }

/* Header height drop (60 to 48) means the webmail layout's
   height: calc(100vh - 60px) is now 12px short.  Compensate. */
.wm-skin-outlook .wm { height: calc(100vh - 48px); }
.wm-skin-outlook .wm.wm-with-tabs { height: calc(100vh - 48px - 36px); }
.wm-skin-outlook .wm-bell-panel { top: 48px; }
.wm-skin-outlook .wm-reader { top: 48px; }
@media (max-width: 768px) {
    .wm-skin-outlook .wm-reader { top: 48px; }
    .wm-skin-outlook .wm-sidebar { top: 48px; }
    .wm-skin-outlook .wm.wm-with-tabs { height: calc(100vh - 48px - 32px); }
}

/* ════════════════════════════════════════════════════════════════
   PORTAL-WIDE OUTLOOK OVERRIDES
   Applied to every page (dashboard, profile, admin, etc.) when the
   skin class is on <html>. Repaints buttons, forms, cards, breadcrumb,
   typography, etc. with the Fluent palette so the portal stays
   visually consistent with webmail/calendar/contacts.
   ════════════════════════════════════════════════════════════════ */
.wm-skin-outlook body { font-family: var(--wm-ol-font); color: var(--wm-ol-text); }

/* Portal action button */
.wm-skin-outlook .fh-btn {
    background: var(--wm-ol-accent);
    border-radius: var(--wm-ol-radius);
    font-family: var(--wm-ol-font);
    font-weight: 600;
    box-shadow: none;
    padding: 8px 18px;
}
.wm-skin-outlook .fh-btn:hover {
    background: var(--wm-ol-accent-hover);
    box-shadow: var(--wm-ol-shadow);
}
.wm-skin-outlook .fh-btn-sm { border-radius: var(--wm-ol-radius); }

/* Cards / panels */
.wm-skin-outlook .fh-card {
    border-radius: var(--wm-ol-radius);
    border-color: var(--wm-ol-border);
    box-shadow: var(--wm-ol-shadow);
}
.wm-skin-outlook .fh-card-title { color: var(--wm-ol-text); font-family: var(--wm-ol-font); }

/* Breadcrumb / page chrome */
.wm-skin-outlook .fh-breadcrumb a { color: var(--wm-ol-text-muted); }
.wm-skin-outlook .fh-breadcrumb a:hover { color: var(--wm-ol-accent); }
.wm-skin-outlook .fh-breadcrumb-current { color: var(--wm-ol-text); }
.wm-skin-outlook .fh-page-title { color: var(--wm-ol-text); font-family: var(--wm-ol-font); }
.wm-skin-outlook .fh-page-subtitle { color: var(--wm-ol-text-muted); }

/* Form fields - Fluent-style flat input with a blue 1px focus ring */
.wm-skin-outlook .fh-form-group label {
    color: var(--wm-ol-text-muted);
    font-family: var(--wm-ol-font);
}
.wm-skin-outlook .fh-form-group input[type="text"],
.wm-skin-outlook .fh-form-group input[type="email"],
.wm-skin-outlook .fh-form-group input[type="password"],
.wm-skin-outlook .fh-form-group input[type="tel"],
.wm-skin-outlook .fh-form-group input[type="date"],
.wm-skin-outlook .fh-form-group input[type="number"],
.wm-skin-outlook .fh-form-group select,
.wm-skin-outlook .fh-form-group textarea {
    border-radius: var(--wm-ol-radius);
    border-color: var(--wm-ol-border-strong);
    font-family: var(--wm-ol-font);
    color: var(--wm-ol-text);
}
.wm-skin-outlook .fh-form-group input:focus,
.wm-skin-outlook .fh-form-group select:focus,
.wm-skin-outlook .fh-form-group textarea:focus {
    border-color: var(--wm-ol-accent);
    box-shadow: 0 0 0 1px var(--wm-ol-accent);
}

/* Tables (admin/reports) */
.wm-skin-outlook .fh-card .fh-table thead th {
    background: var(--wm-ol-page);
    color: var(--wm-ol-text-muted);
    border-color: var(--wm-ol-border);
    font-family: var(--wm-ol-font);
}
.wm-skin-outlook .fh-table tbody td { border-color: var(--wm-ol-border); }
.wm-skin-outlook .fh-table tbody tr:hover td { background: var(--wm-ol-hover); }

/* Table search input (used on admin pages) */
.wm-skin-outlook .fh-table-search input {
    border-radius: var(--wm-ol-radius);
    border-color: var(--wm-ol-border-strong);
}
.wm-skin-outlook .fh-table-search input:focus {
    border-color: var(--wm-ol-accent);
    box-shadow: 0 0 0 1px var(--wm-ol-accent);
}

/* Repurposed page-level headers (dashboard widgets, reports) */
.wm-skin-outlook .fh-rep-stat-num,
.wm-skin-outlook .fh-rep-stat-label,
.wm-skin-outlook .fh-rep-desc { font-family: var(--wm-ol-font); }
.wm-skin-outlook .fh-rep-desc { color: var(--wm-ol-text-muted); }

/* Links that derive colour from --fh-primary should pick up Outlook blue.
   Most admin pages use this token so the override sweeps through. */
.wm-skin-outlook { --fh-primary: var(--wm-ol-accent); --fh-secondary: var(--wm-ol-accent-hover); }
