/* MSH Life OS — Frontend Styles */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500&family=Cormorant+Garamond:wght@400;500&display=swap');

/* Root reset — forces all text inside the plugin to be legible
   regardless of what the theme sets */
#msh-life-os,
#msh-life-os * {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    color: inherit;
}

#msh-life-os {
    font-family: 'Archivo', Helvetica, Arial, sans-serif;
    font-size: 14px;
    line-height: 1.5;
    color: #f0f0f0 !important;
    background: #0a0f1e;
    border-radius: 10px;
    min-height: 70vh;
    padding: 28px 24px 60px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Every text element gets an explicit colour so theme styles cannot bleed in */
#msh-life-os h1,
#msh-life-os h2,
#msh-life-os h3,
#msh-life-os p,
#msh-life-os span,
#msh-life-os div,
#msh-life-os button,
#msh-life-os input,
#msh-life-os select,
#msh-life-os textarea,
#msh-life-os label,
#msh-life-os a {
    font-family: 'Archivo', Helvetica, Arial, sans-serif;
    color: #f0f0f0;
}

/* Cormorant override for display headings */
#msh-life-os .msh-los-title,
#msh-life-os .msh-los-wizard-title,
#msh-life-os .msh-los-pillar-name,
#msh-life-os .msh-los-metric-val,
#msh-life-os .msh-los-modal-title,
#msh-life-os .msh-los-settings-section-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
}

.msh-los-wrap {
    max-width: 860px;
    margin: 0 auto;
    padding: 2rem 0;
    min-height: 400px;
}

/* Loading state */
.msh-los-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 300px;
    gap: 1rem;
    color: rgba(240,240,240,0.5);
    font-size: 14px;
}

.msh-los-spinner {
    width: 28px;
    height: 28px;
    border: 2px solid rgba(240,240,240,0.15);
    border-top-color: rgba(240,240,240,0.6);
    border-radius: 50%;
    animation: msh-spin 0.7s linear infinite;
}

@keyframes msh-spin {
    to { transform: rotate(360deg); }
}

/* Login notice */
.msh-los-login-notice {
    padding: 1rem;
    color: rgba(240,240,240,0.6);
    font-size: 14px;
}

.msh-los-login-notice a {
    color: #c9973a;
    text-decoration: none;
}

/* Top bar */
.msh-los-top-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
    gap: 10px;
}

.msh-los-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px;
    font-weight: 500;
    color: #f0f0f0;
    letter-spacing: 0.01em;
}

.msh-los-top-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

/* Backlog button */
.msh-los-backlog-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 500;
    border: 1px solid rgba(240,240,240,0.2);
    border-radius: 6px;
    cursor: pointer;
    background: rgba(240,240,240,0.06);
    color: #f0f0f0;
    font-family: 'Archivo', sans-serif;
    transition: background 0.15s;
}

.msh-los-backlog-btn:hover {
    background: rgba(240,240,240,0.1);
}

.msh-los-backlog-badge {
    background: #e24b4a;
    color: #fff;
    font-size: 10px;
    font-weight: 500;
    border-radius: 8px;
    padding: 1px 6px;
    min-width: 18px;
    text-align: center;
}

/* Period tabs */
.msh-los-period-tabs {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.msh-los-period-tab {
    padding: 5px 12px;
    font-size: 12px;
    font-family: 'Archivo', sans-serif;
    border: 0.5px solid rgba(240,240,240,0.2);
    border-radius: 6px;
    cursor: pointer;
    background: transparent;
    color: rgba(240,240,240,0.5);
    transition: all 0.15s;
}

.msh-los-period-tab:hover {
    color: rgba(240,240,240,0.8);
    border-color: rgba(240,240,240,0.35);
}

.msh-los-period-tab.active {
    background: rgba(240,240,240,0.1);
    color: #f0f0f0;
    border-color: rgba(240,240,240,0.4);
}

/* Metrics row */
.msh-los-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 1.25rem;
}

.msh-los-metric {
    background: rgba(240,240,240,0.04);
    border: 0.5px solid rgba(240,240,240,0.1);
    border-radius: 8px;
    padding: 12px 14px;
}

.msh-los-metric-label {
    font-size: 10px;
    color: rgba(240,240,240,0.4);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
}

.msh-los-metric-val {
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px;
    font-weight: 500;
    color: #f0f0f0;
}

.msh-los-metric-sub {
    font-size: 11px;
    color: rgba(240,240,240,0.35);
    margin-top: 2px;
}

/* Overdue banner */
.msh-los-overdue-banner {
    background: rgba(186,117,23,0.12);
    border: 0.5px solid rgba(186,117,23,0.35);
    border-radius: 8px;
    padding: 9px 13px;
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #c9973a;
}

.msh-los-overdue-banner.hidden {
    display: none;
}

/* Pillar cards */
.msh-los-pillar-card {
    background: rgba(240,240,240,0.03);
    border: 0.5px solid rgba(240,240,240,0.1);
    border-radius: 10px;
    margin-bottom: 8px;
    overflow: hidden;
    transition: border-color 0.15s;
}

.msh-los-pillar-card:hover {
    border-color: rgba(240,240,240,0.18);
}

.msh-los-pillar-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    cursor: pointer;
    user-select: none;
}

.msh-los-pillar-accent {
    width: 3px;
    height: 34px;
    border-radius: 2px;
    flex-shrink: 0;
}

.msh-los-pillar-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 16px;
    font-weight: 500;
    color: #f0f0f0;
    flex: 1;
    letter-spacing: 0.01em;
}

.msh-los-pillar-meta {
    font-size: 11px;
    color: rgba(240,240,240,0.35);
    margin-right: 8px;
}

.msh-los-pillar-chevron {
    font-size: 10px;
    color: rgba(240,240,240,0.3);
    transition: transform 0.2s;
}

.msh-los-pillar-chevron.open {
    transform: rotate(180deg);
}

.msh-los-pillar-bar {
    height: 2px;
    background: rgba(240,240,240,0.08);
    margin: 0 14px 10px;
    border-radius: 1px;
}

.msh-los-pillar-bar-fill {
    height: 100%;
    border-radius: 1px;
    transition: width 0.4s ease;
}

/* Pillar body */
.msh-los-pillar-body {
    padding: 0 14px 12px;
    border-top: 0.5px solid rgba(240,240,240,0.07);
    display: none;
}

.msh-los-pillar-body.open {
    display: block;
}

.msh-los-section-title {
    font-size: 10px;
    font-weight: 500;
    color: rgba(240,240,240,0.3);
    text-transform: uppercase;
    letter-spacing: 0.07em;
    padding: 10px 0 6px;
}

/* Goals */
.msh-los-goal-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    border-bottom: 0.5px solid rgba(240,240,240,0.06);
    flex-wrap: wrap;
}

.msh-los-goal-item:last-child {
    border-bottom: none;
}

.msh-los-goal-text {
    font-size: 13px;
    color: #f0f0f0;
    flex: 1;
    min-width: 140px;
}

.msh-los-goal-date {
    font-size: 11px;
    color: rgba(240,240,240,0.3);
}

/* Status badges */
.msh-los-status-badge {
    font-size: 10px;
    padding: 2px 9px;
    border-radius: 10px;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.15s;
    font-family: 'Archivo', sans-serif;
}

.msh-los-status-badge:hover {
    opacity: 0.8;
}

.msh-los-status-badge.s-track    { background: rgba(106,158,114,0.2); color: #6a9e72; border: 0.5px solid rgba(106,158,114,0.3); }
.msh-los-status-badge.s-risk     { background: rgba(201,151,58,0.2);  color: #c9973a; border: 0.5px solid rgba(201,151,58,0.3); }
.msh-los-status-badge.s-plan     { background: rgba(74,127,165,0.2);  color: #4a7fa5; border: 0.5px solid rgba(74,127,165,0.3); }
.msh-los-status-badge.s-prog     { background: rgba(127,119,221,0.2); color: #7f77dd; border: 0.5px solid rgba(127,119,221,0.3); }
.msh-los-status-badge.s-done     { background: rgba(42,157,143,0.2);  color: #2a9d8f; border: 0.5px solid rgba(42,157,143,0.3); }

/* Status dropdown */
.msh-los-status-wrap {
    position: relative;
}

.msh-los-status-menu {
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    background: #0f1829;
    border: 0.5px solid rgba(240,240,240,0.15);
    border-radius: 8px;
    padding: 4px;
    z-index: 100;
    display: none;
    min-width: 130px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}

.msh-los-status-menu.open {
    display: block;
}

.msh-los-status-option {
    font-size: 12px;
    padding: 6px 10px;
    cursor: pointer;
    border-radius: 4px;
    color: rgba(240,240,240,0.7);
    font-family: 'Archivo', sans-serif;
    transition: background 0.1s;
}

.msh-los-status-option:hover {
    background: rgba(240,240,240,0.07);
    color: #f0f0f0;
}

/* Stale goal nudge */
.msh-los-stale-nudge {
    font-size: 11px;
    color: rgba(201,151,58,0.7);
    font-style: italic;
    padding: 3px 0 5px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.msh-los-stale-dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #c9973a;
    flex-shrink: 0;
}

/* Tasks */
.msh-los-task-item {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 7px 0;
    border-bottom: 0.5px solid rgba(240,240,240,0.06);
}

.msh-los-task-item:last-child {
    border-bottom: none;
}

.msh-los-task-check {
    width: 16px;
    height: 16px;
    border-radius: 4px;
    border: 1.5px solid rgba(240,240,240,0.25);
    cursor: pointer;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
    background: transparent;
}

.msh-los-task-check:hover {
    border-color: rgba(240,240,240,0.5);
}

.msh-los-task-check.done {
    background: rgba(240,240,240,0.15);
    border-color: rgba(240,240,240,0.3);
}

.msh-los-task-check.done::after {
    content: '';
    display: block;
    width: 8px;
    height: 5px;
    border-left: 1.5px solid #f0f0f0;
    border-bottom: 1.5px solid #f0f0f0;
    transform: rotate(-45deg) translate(1px, -1px);
}

.msh-los-task-label {
    font-size: 13px;
    color: #f0f0f0;
    flex: 1;
}

.msh-los-task-label.done {
    color: rgba(240,240,240,0.3);
    text-decoration: line-through;
}

.msh-los-priority-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    flex-shrink: 0;
}

.msh-los-priority-dot.high { background: #e24b4a; }
.msh-los-priority-dot.med  { background: #c9973a; }
.msh-los-priority-dot.low  { background: rgba(240,240,240,0.2); }

/* Journal prompt */
.msh-los-journal-prompt {
    background: rgba(127,119,221,0.07);
    border-left: 2px solid #7f77dd;
    border-radius: 0 8px 8px 0;
    padding: 12px 14px;
    margin-top: 8px;
    display: none;
}

.msh-los-journal-prompt.show {
    display: block;
}

.msh-los-journal-q {
    font-size: 13px;
    color: rgba(240,240,240,0.8);
    margin-bottom: 8px;
    font-style: italic;
}

.msh-los-journal-input {
    width: 100%;
    font-size: 13px;
    font-family: 'Archivo', sans-serif;
    padding: 8px 10px;
    border: 0.5px solid rgba(240,240,240,0.15);
    border-radius: 6px;
    background: rgba(240,240,240,0.04);
    color: #f0f0f0;
    resize: vertical;
    min-height: 72px;
}

.msh-los-journal-input:focus {
    outline: none;
    border-color: rgba(127,119,221,0.5);
}

.msh-los-journal-save {
    margin-top: 8px;
    padding: 5px 14px;
    font-size: 11px;
    font-family: 'Archivo', sans-serif;
    border: 0.5px solid rgba(240,240,240,0.2);
    border-radius: 6px;
    cursor: pointer;
    background: transparent;
    color: rgba(240,240,240,0.5);
    transition: all 0.15s;
}

.msh-los-journal-save:hover {
    background: rgba(240,240,240,0.07);
    color: #f0f0f0;
}

/* Post toast */
.msh-los-post-toast {
    background: rgba(42,157,143,0.08);
    border: 0.5px solid rgba(42,157,143,0.3);
    border-radius: 10px;
    padding: 14px 16px;
    margin-top: 1rem;
    display: none;
}

.msh-los-post-toast.show {
    display: block;
}

.msh-los-post-toast-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 15px;
    font-weight: 500;
    color: #f0f0f0;
    margin-bottom: 4px;
}

.msh-los-post-toast-sub {
    font-size: 12px;
    color: rgba(240,240,240,0.5);
    margin-bottom: 10px;
}

.msh-los-post-actions {
    display: flex;
    gap: 8px;
}

.msh-los-btn-post {
    padding: 6px 16px;
    font-size: 12px;
    font-family: 'Archivo', sans-serif;
    border: 0.5px solid rgba(42,157,143,0.4);
    border-radius: 6px;
    cursor: pointer;
    background: rgba(42,157,143,0.15);
    color: #2a9d8f;
    transition: all 0.15s;
}

.msh-los-btn-post:hover {
    background: rgba(42,157,143,0.25);
}

.msh-los-btn-skip {
    padding: 6px 16px;
    font-size: 12px;
    font-family: 'Archivo', sans-serif;
    border: 0.5px solid rgba(240,240,240,0.15);
    border-radius: 6px;
    cursor: pointer;
    background: transparent;
    color: rgba(240,240,240,0.4);
    transition: all 0.15s;
}

.msh-los-btn-skip:hover {
    color: rgba(240,240,240,0.7);
}

/* Empty state */
.msh-los-empty {
    font-size: 12px;
    color: rgba(240,240,240,0.3);
    font-style: italic;
    padding: 6px 0;
}

/* Footer note */
.msh-los-footer-note {
    font-size: 11px;
    color: rgba(240,240,240,0.25);
    text-align: center;
    padding: 1.25rem 0 0.5rem;
}

.msh-los-footer-note a {
    color: rgba(240,240,240,0.45);
    text-decoration: underline;
    cursor: pointer;
}

.msh-los-footer-note a:hover {
    color: rgba(240,240,240,0.7);
}

/* Backlog view */
.msh-los-back-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-family: 'Archivo', sans-serif;
    color: rgba(240,240,240,0.45);
    cursor: pointer;
    margin-bottom: 1.25rem;
    background: none;
    border: none;
    padding: 0;
    transition: color 0.15s;
}

.msh-los-back-btn:hover {
    color: rgba(240,240,240,0.8);
}

.msh-los-backlog-card {
    background: rgba(240,240,240,0.03);
    border: 0.5px solid rgba(240,240,240,0.1);
    border-radius: 10px;
    margin-bottom: 8px;
    padding: 13px 15px;
}

.msh-los-backlog-pillar-label {
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 8px;
    font-family: 'Archivo', sans-serif;
}

.msh-los-backlog-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    border-bottom: 0.5px solid rgba(240,240,240,0.06);
    flex-wrap: wrap;
}

.msh-los-backlog-item:last-child {
    border-bottom: none;
}

.msh-los-backlog-item-text {
    font-size: 13px;
    color: #f0f0f0;
    flex: 1;
    min-width: 120px;
}

.msh-los-backlog-due {
    font-size: 11px;
    color: rgba(240,240,240,0.3);
}

.msh-los-backlog-due.overdue {
    color: #e24b4a;
}

.msh-los-blocked-tag {
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 8px;
    background: rgba(240,240,240,0.06);
    color: rgba(240,240,240,0.4);
    border: 0.5px solid rgba(240,240,240,0.1);
}

/* Responsive */
@media (max-width: 600px) {
    .msh-los-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .msh-los-period-tabs {
        gap: 4px;
    }
    .msh-los-period-tab {
        padding: 4px 9px;
        font-size: 11px;
    }
}

/* ── Wizard ─────────────────────────────────────────────────────────────── */
.msh-los-wizard { max-width: 680px; margin: 0 auto; padding: 1.5rem 0; }
.msh-los-wizard-step { display: none; }
.msh-los-wizard-step.active { display: block; }
.msh-los-wizard-header { margin-bottom: 1.5rem; }
.msh-los-wizard-step-label { font-size: 11px; color: rgba(240,240,240,0.3); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px; }
.msh-los-wizard-title { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 400; color: #f0f0f0; margin-bottom: 6px; }
.msh-los-wizard-sub { font-size: 13px; color: rgba(240,240,240,0.5); }
.msh-los-pillar-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; margin-bottom: 1.5rem; }
.msh-los-pillar-option { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 0.5px solid rgba(240,240,240,0.1); border-radius: 8px; cursor: pointer; transition: all 0.15s; background: rgba(240,240,240,0.02); }
.msh-los-pillar-option:hover { border-color: rgba(240,240,240,0.25); background: rgba(240,240,240,0.04); }
.msh-los-pillar-option.selected { border-color: rgba(240,240,240,0.35); background: rgba(240,240,240,0.07); }
.msh-los-pillar-option-accent { width: 3px; height: 28px; border-radius: 2px; flex-shrink: 0; }
.msh-los-pillar-option-label { font-size: 12px; color: #f0f0f0; flex: 1; }
.msh-los-pillar-option-check { width: 14px; height: 14px; border-radius: 3px; border: 1px solid rgba(240,240,240,0.2); flex-shrink: 0; transition: all 0.15s; }
.msh-los-pillar-option.selected .msh-los-pillar-option-check { background: rgba(240,240,240,0.8); border-color: rgba(240,240,240,0.8); }
.msh-los-wizard-actions { display: flex; gap: 10px; margin-top: 1.5rem; }
.msh-los-wizard-pillar-section { margin-bottom: 1.5rem; }
.msh-los-wizard-pillar-label { font-family: 'Cormorant Garamond', serif; font-size: 16px; margin-bottom: 8px; font-weight: 500; }
.msh-los-wizard-cadence-section { margin-bottom: 1rem; }
.msh-los-wizard-cadence-label { font-size: 11px; color: rgba(240,240,240,0.35); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
.msh-los-wizard-goal-row, .msh-los-wizard-task-row { display: flex; gap: 8px; margin-bottom: 6px; flex-wrap: wrap; }
.msh-los-wizard-input { flex: 1; min-width: 140px; padding: 8px 10px; font-size: 13px; font-family: 'Archivo', sans-serif; border: 0.5px solid rgba(240,240,240,0.15); border-radius: 6px; background: rgba(240,240,240,0.04); color: #f0f0f0; }
.msh-los-wizard-input:focus { outline: none; border-color: rgba(240,240,240,0.35); }
.msh-los-wizard-date { padding: 8px 10px; font-size: 13px; font-family: 'Archivo', sans-serif; border: 0.5px solid rgba(240,240,240,0.15); border-radius: 6px; background: rgba(240,240,240,0.04); color: rgba(240,240,240,0.6); }
.msh-los-wizard-priority { padding: 8px 10px; font-size: 12px; font-family: 'Archivo', sans-serif; border: 0.5px solid rgba(240,240,240,0.15); border-radius: 6px; background: rgba(10,15,30,0.8); color: rgba(240,240,240,0.7); }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.msh-los-btn-primary { padding: 10px 24px; font-size: 13px; font-family: 'Archivo', sans-serif; font-weight: 500; border: 0.5px solid rgba(240,240,240,0.3); border-radius: 6px; cursor: pointer; background: rgba(240,240,240,0.1); color: #f0f0f0; transition: all 0.15s; }
.msh-los-btn-primary:hover:not(:disabled) { background: rgba(240,240,240,0.18); }
.msh-los-btn-primary:disabled { opacity: 0.3; cursor: not-allowed; }
.msh-los-btn-ghost { padding: 10px 20px; font-size: 13px; font-family: 'Archivo', sans-serif; border: 0.5px solid rgba(240,240,240,0.15); border-radius: 6px; cursor: pointer; background: transparent; color: rgba(240,240,240,0.5); transition: all 0.15s; }
.msh-los-btn-ghost:hover { color: rgba(240,240,240,0.8); border-color: rgba(240,240,240,0.3); }
.msh-los-btn-primary-sm { padding: 5px 14px; font-size: 12px; font-family: 'Archivo', sans-serif; border: 0.5px solid rgba(240,240,240,0.25); border-radius: 5px; cursor: pointer; background: rgba(240,240,240,0.08); color: #f0f0f0; transition: all 0.15s; }
.msh-los-btn-primary-sm:hover { background: rgba(240,240,240,0.15); }
.msh-los-btn-ghost-sm { padding: 5px 12px; font-size: 12px; font-family: 'Archivo', sans-serif; border: 0.5px solid rgba(240,240,240,0.12); border-radius: 5px; cursor: pointer; background: transparent; color: rgba(240,240,240,0.4); }
.msh-los-btn-add { font-size: 12px; font-family: 'Archivo', sans-serif; color: rgba(240,240,240,0.35); background: none; border: none; cursor: pointer; padding: 4px 0; transition: color 0.15s; margin-top: 4px; }
.msh-los-btn-add:hover { color: rgba(240,240,240,0.7); }
.msh-los-icon-btn { width: 32px; height: 32px; font-size: 15px; border: 0.5px solid rgba(240,240,240,0.15); border-radius: 6px; cursor: pointer; background: transparent; color: rgba(240,240,240,0.4); display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.msh-los-icon-btn:hover { color: rgba(240,240,240,0.8); border-color: rgba(240,240,240,0.3); }

/* ── Row actions ─────────────────────────────────────────────────────────── */
.msh-los-row-action { width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-size: 14px; color: rgba(240,240,240,0.2); cursor: pointer; border-radius: 3px; flex-shrink: 0; transition: all 0.15s; }
.msh-los-row-action:hover { color: rgba(240,240,240,0.7); background: rgba(240,240,240,0.07); }

/* ── Inline form ─────────────────────────────────────────────────────────── */
.msh-los-inline-form { background: rgba(240,240,240,0.03); border: 0.5px solid rgba(240,240,240,0.1); border-radius: 8px; padding: 12px; margin: 8px 0; display: flex; flex-direction: column; gap: 8px; }
.msh-los-inline-actions { display: flex; gap: 8px; }

/* ── Settings ────────────────────────────────────────────────────────────── */
.msh-los-settings-section { }
.msh-los-settings-section-title { font-family: 'Cormorant Garamond', serif; font-size: 16px; font-weight: 500; color: #f0f0f0; margin-bottom: 6px; }
.msh-los-settings-desc { font-size: 13px; color: rgba(240,240,240,0.45); margin-bottom: 1rem; line-height: 1.5; }

/* Toggle switch */
.msh-los-toggle-label { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.msh-los-toggle-input { display: none; }
.msh-los-toggle-track { width: 36px; height: 20px; background: rgba(240,240,240,0.1); border-radius: 10px; border: 0.5px solid rgba(240,240,240,0.2); position: relative; transition: background 0.2s; flex-shrink: 0; }
.msh-los-toggle-input:checked + .msh-los-toggle-track { background: rgba(42,157,143,0.4); border-color: rgba(42,157,143,0.5); }
.msh-los-toggle-thumb { width: 14px; height: 14px; background: rgba(240,240,240,0.6); border-radius: 50%; position: absolute; top: 2px; left: 2px; transition: transform 0.2s, background 0.2s; }
.msh-los-toggle-input:checked + .msh-los-toggle-track .msh-los-toggle-thumb { transform: translateX(16px); background: #2a9d8f; }
.msh-los-toggle-text { font-size: 13px; color: rgba(240,240,240,0.6); }

/* ── Modal ───────────────────────────────────────────────────────────────── */
.msh-los-modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.6); z-index: 1000; display: flex; align-items: center; justify-content: center; }
.msh-los-modal { background: #0f1829; border: 0.5px solid rgba(240,240,240,0.15); border-radius: 12px; padding: 1.5rem; width: 100%; max-width: 400px; display: flex; flex-direction: column; gap: 10px; }
.msh-los-modal-title { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 400; color: #f0f0f0; }

/* ── Journal entry cards ─────────────────────────────────────────────────── */
.msh-los-journal-entry { background: rgba(240,240,240,0.02); border: 0.5px solid rgba(240,240,240,0.08); border-radius: 8px; padding: 14px; margin-bottom: 10px; }
.msh-los-journal-entry-meta { font-size: 11px; color: rgba(240,240,240,0.3); margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.05em; }
.msh-los-journal-entry-prompt { font-size: 12px; color: rgba(127,119,221,0.7); font-style: italic; margin-bottom: 8px; }
.msh-los-journal-entry-text { font-size: 14px; color: rgba(240,240,240,0.7); line-height: 1.6; white-space: pre-wrap; }

/* ── Specificity overrides — theme bleed protection ──────────────────────── */
#msh-life-os .msh-los-metric-label        { color: rgba(240,240,240,0.4) !important; }
#msh-life-os .msh-los-metric-sub          { color: rgba(240,240,240,0.35) !important; }
#msh-life-os .msh-los-metric-val          { color: #f0f0f0 !important; }
#msh-life-os .msh-los-pillar-name         { color: #f0f0f0 !important; }
#msh-life-os .msh-los-pillar-meta         { color: rgba(240,240,240,0.35) !important; }
#msh-life-os .msh-los-pillar-chevron      { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-section-title       { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-goal-text           { color: #f0f0f0 !important; }
#msh-life-os .msh-los-goal-date           { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-task-label          { color: #f0f0f0 !important; }
#msh-life-os .msh-los-task-label.done     { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-empty               { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-stale-nudge         { color: rgba(201,151,58,0.7) !important; }
#msh-life-os .msh-los-footer-note         { color: rgba(240,240,240,0.25) !important; }
#msh-life-os .msh-los-footer-note a       { color: rgba(240,240,240,0.45) !important; }
#msh-life-os .msh-los-period-tab          { color: rgba(240,240,240,0.5) !important; }
#msh-life-os .msh-los-period-tab.active   { color: #f0f0f0 !important; }
#msh-life-os .msh-los-overdue-banner      { color: #c9973a !important; }
#msh-life-os .msh-los-backlog-btn         { color: #f0f0f0 !important; }
#msh-life-os .msh-los-wizard-title        { color: #f0f0f0 !important; }
#msh-life-os .msh-los-wizard-sub          { color: rgba(240,240,240,0.5) !important; }
#msh-life-os .msh-los-wizard-step-label   { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-wizard-pillar-label { color: inherit !important; }
#msh-life-os .msh-los-wizard-cadence-label{ color: rgba(240,240,240,0.35) !important; }
#msh-life-os .msh-los-pillar-option-label { color: #f0f0f0 !important; }
#msh-life-os .msh-los-settings-desc       { color: rgba(240,240,240,0.45) !important; }
#msh-life-os .msh-los-settings-section-title { color: #f0f0f0 !important; }
#msh-life-os .msh-los-toggle-text         { color: rgba(240,240,240,0.6) !important; }
#msh-life-os .msh-los-backlog-item-text   { color: #f0f0f0 !important; }
#msh-life-os .msh-los-backlog-due         { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-backlog-due.overdue { color: #e24b4a !important; }
#msh-life-os .msh-los-backlog-pillar-label{ color: inherit !important; }
#msh-life-os .msh-los-blocked-tag         { color: rgba(240,240,240,0.4) !important; }
#msh-life-os .msh-los-back-btn            { color: rgba(240,240,240,0.45) !important; }
#msh-life-os .msh-los-journal-q           { color: rgba(240,240,240,0.8) !important; }
#msh-life-os .msh-los-journal-entry-meta  { color: rgba(240,240,240,0.3) !important; }
#msh-life-os .msh-los-journal-entry-prompt{ color: rgba(127,119,221,0.7) !important; }
#msh-life-os .msh-los-journal-entry-text  { color: rgba(240,240,240,0.7) !important; }
#msh-life-os .msh-los-post-toast-title    { color: #f0f0f0 !important; }
#msh-life-os .msh-los-post-toast-sub      { color: rgba(240,240,240,0.5) !important; }
#msh-life-os .msh-los-btn-primary         { color: #f0f0f0 !important; }
#msh-life-os .msh-los-btn-ghost           { color: rgba(240,240,240,0.5) !important; }
#msh-life-os .msh-los-btn-primary-sm      { color: #f0f0f0 !important; }
#msh-life-os .msh-los-btn-ghost-sm        { color: rgba(240,240,240,0.4) !important; }
#msh-life-os .msh-los-btn-add             { color: rgba(240,240,240,0.35) !important; }
#msh-life-os .msh-los-btn-post            { color: #2a9d8f !important; }
#msh-life-os .msh-los-btn-skip            { color: rgba(240,240,240,0.4) !important; }
#msh-life-os .msh-los-wizard-input        { color: #f0f0f0 !important; }
#msh-life-os .msh-los-wizard-date         { color: rgba(240,240,240,0.6) !important; }
#msh-life-os .msh-los-wizard-priority     { color: rgba(240,240,240,0.7) !important; }
#msh-life-os .msh-los-journal-input       { color: #f0f0f0 !important; }
#msh-life-os .msh-los-modal-title         { color: #f0f0f0 !important; }
#msh-life-os .msh-los-status-option       { color: rgba(240,240,240,0.7) !important; }


/* ══════════════════════════════════════════════════════════════════════════
   THEME OVERRIDE LAYER
   style6.css and other theme stylesheets load AFTER our CSS and strip all
   padding/margin back to 0. This block re-applies every spacing rule with
   !important so nothing can override it.
   ══════════════════════════════════════════════════════════════════════════ */

/* Root */
#msh-life-os {
    margin: 0 auto !important;
    padding: 28px 24px 60px !important;
    max-width: 900px !important;
    width: 100% !important;
}

/* Top bar */
#msh-life-os .msh-los-top-bar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 1.25rem !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-title {
    font-size: 22px !important;
    font-weight: 500 !important;
    margin: 0 !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-top-actions {
    display: flex !important;
    gap: 8px !important;
    align-items: center !important;
}

/* Period tabs */
#msh-life-os .msh-los-period-tabs {
    display: flex !important;
    gap: 5px !important;
    flex-wrap: wrap !important;
    margin-bottom: 1.25rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-period-tab {
    padding: 5px 12px !important;
    margin: 0 !important;
    font-size: 12px !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    line-height: 1.4 !important;
}

/* Metrics */
#msh-life-os .msh-los-metrics {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-bottom: 1.25rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-metric {
    padding: 12px 14px !important;
    margin: 0 !important;
    border-radius: 8px !important;
}

#msh-life-os .msh-los-metric-label {
    margin-bottom: 4px !important;
    padding: 0 !important;
    display: block !important;
}

#msh-life-os .msh-los-metric-val {
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
}

#msh-life-os .msh-los-metric-sub {
    margin-top: 2px !important;
    padding: 0 !important;
    display: block !important;
}

/* Overdue banner */
#msh-life-os .msh-los-overdue-banner {
    padding: 9px 13px !important;
    margin-bottom: 1.25rem !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

#msh-life-os .msh-los-overdue-banner.hidden {
    display: none !important;
}

/* Pillar cards */
#msh-life-os .msh-los-pillar-card {
    margin-bottom: 8px !important;
    padding: 0 !important;
    border-radius: 10px !important;
    overflow: hidden !important;
}

#msh-life-os .msh-los-pillar-header {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    margin: 0 !important;
    cursor: pointer !important;
}

#msh-life-os .msh-los-pillar-accent {
    width: 3px !important;
    height: 34px !important;
    border-radius: 2px !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-pillar-name {
    flex: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 16px !important;
}

#msh-life-os .msh-los-pillar-meta {
    margin: 0 0 0 auto !important;
    padding: 0 !important;
    margin-right: 8px !important;
}

#msh-life-os .msh-los-pillar-chevron {
    padding: 0 !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
}

#msh-life-os .msh-los-pillar-bar {
    height: 2px !important;
    margin: 0 14px 10px !important;
    padding: 0 !important;
    border-radius: 1px !important;
}

#msh-life-os .msh-los-pillar-bar-fill {
    height: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 1px !important;
}

#msh-life-os .msh-los-pillar-body {
    padding: 0 14px 14px !important;
    margin: 0 !important;
    display: none !important;
}

#msh-life-os .msh-los-pillar-body.open {
    display: block !important;
}

#msh-life-os .msh-los-section-title {
    display: block !important;
    padding: 10px 0 6px !important;
    margin: 0 !important;
    font-size: 10px !important;
    letter-spacing: 0.07em !important;
}

/* Goals */
#msh-life-os .msh-los-goal-item {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 7px 0 !important;
    margin: 0 !important;
    flex-wrap: wrap !important;
    border-bottom: 0.5px solid rgba(240,240,240,0.06) !important;
}

#msh-life-os .msh-los-goal-text {
    flex: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-goal-date {
    padding: 0 !important;
    margin: 0 !important;
    font-size: 11px !important;
}

#msh-life-os .msh-los-status-wrap {
    position: relative !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-status-badge {
    padding: 2px 9px !important;
    margin: 0 !important;
    border-radius: 10px !important;
    font-size: 10px !important;
    cursor: pointer !important;
}

#msh-life-os .msh-los-stale-nudge {
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    padding: 3px 0 5px !important;
    margin: 0 !important;
    width: 100% !important;
    font-size: 11px !important;
}

/* Tasks */
#msh-life-os .msh-los-task-item {
    display: flex !important;
    align-items: center !important;
    gap: 9px !important;
    padding: 7px 0 !important;
    margin: 0 !important;
    border-bottom: 0.5px solid rgba(240,240,240,0.06) !important;
}

#msh-life-os .msh-los-task-check {
    width: 16px !important;
    height: 16px !important;
    border-radius: 4px !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#msh-life-os .msh-los-task-label {
    flex: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-priority-dot {
    width: 5px !important;
    height: 5px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-empty {
    padding: 6px 0 !important;
    margin: 0 !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-btn-add {
    display: block !important;
    padding: 6px 0 !important;
    margin: 4px 0 0 !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-row-action {
    width: 18px !important;
    height: 18px !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 3px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Footer */
#msh-life-os .msh-los-footer-note {
    padding: 1.25rem 0 0.5rem !important;
    margin: 0 !important;
    text-align: center !important;
    font-size: 11px !important;
}

/* Backlog button */
#msh-life-os .msh-los-backlog-btn {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 6px 14px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-backlog-badge {
    padding: 1px 6px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    font-size: 10px !important;
}

#msh-life-os .msh-los-icon-btn {
    width: 32px !important;
    height: 32px !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 15px !important;
    cursor: pointer !important;
}

/* Post toast */
#msh-life-os .msh-los-post-toast {
    padding: 14px 16px !important;
    margin-top: 1rem !important;
    border-radius: 10px !important;
}

#msh-life-os .msh-los-post-toast-title {
    margin-bottom: 4px !important;
    padding: 0 !important;
    font-size: 15px !important;
}

#msh-life-os .msh-los-post-toast-sub {
    margin-bottom: 10px !important;
    padding: 0 !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-post-actions {
    display: flex !important;
    gap: 8px !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Buttons */
#msh-life-os .msh-los-btn-primary {
    padding: 10px 24px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-btn-ghost {
    padding: 10px 20px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-btn-primary-sm {
    padding: 5px 14px !important;
    margin: 0 !important;
    border-radius: 5px !important;
    cursor: pointer !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-btn-ghost-sm {
    padding: 5px 12px !important;
    margin: 0 !important;
    border-radius: 5px !important;
    cursor: pointer !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-btn-post {
    padding: 6px 16px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-btn-skip {
    padding: 6px 16px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 12px !important;
}

/* Back button */
#msh-life-os .msh-los-back-btn {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 0 !important;
    margin-bottom: 1.25rem !important;
    font-size: 12px !important;
    cursor: pointer !important;
    background: none !important;
    border: none !important;
}

/* Inline form */
#msh-life-os .msh-los-inline-form {
    padding: 12px !important;
    margin: 8px 0 !important;
    border-radius: 8px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

#msh-life-os .msh-los-inline-actions {
    display: flex !important;
    gap: 8px !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Wizard */
#msh-life-os .msh-los-wizard {
    max-width: 680px !important;
    margin: 0 auto !important;
    padding: 1.5rem 0 !important;
}

#msh-life-os .msh-los-wizard-header {
    margin-bottom: 1.5rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-wizard-step-label {
    margin-bottom: 6px !important;
    padding: 0 !important;
    display: block !important;
}

#msh-life-os .msh-los-wizard-title {
    margin-bottom: 6px !important;
    padding: 0 !important;
    font-size: 24px !important;
}

#msh-life-os .msh-los-wizard-sub {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-pillar-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
    gap: 8px !important;
    margin-bottom: 1.5rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-pillar-option {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px 12px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
}

#msh-life-os .msh-los-pillar-option-accent {
    width: 3px !important;
    height: 28px !important;
    border-radius: 2px !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-pillar-option-label {
    flex: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-pillar-option-check {
    width: 14px !important;
    height: 14px !important;
    border-radius: 3px !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-wizard-actions {
    display: flex !important;
    gap: 10px !important;
    margin-top: 1.5rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-wizard-pillar-section {
    margin-bottom: 1.5rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-wizard-pillar-label {
    margin-bottom: 8px !important;
    padding: 0 !important;
    font-size: 16px !important;
    display: block !important;
}

#msh-life-os .msh-los-wizard-cadence-section {
    margin-bottom: 1rem !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-wizard-cadence-label {
    margin-bottom: 6px !important;
    padding: 0 !important;
    display: block !important;
}

#msh-life-os .msh-los-wizard-goal-row,
#msh-life-os .msh-los-wizard-task-row {
    display: flex !important;
    gap: 8px !important;
    margin-bottom: 6px !important;
    padding: 0 !important;
    flex-wrap: wrap !important;
}

#msh-life-os .msh-los-wizard-input {
    padding: 8px 10px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    flex: 1 !important;
    min-width: 140px !important;
}

#msh-life-os .msh-los-wizard-date {
    padding: 8px 10px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-wizard-priority {
    padding: 8px 10px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    font-size: 12px !important;
}

/* Settings */
#msh-life-os .msh-los-settings-section {
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-settings-section-title {
    margin-bottom: 6px !important;
    padding: 0 !important;
    font-size: 16px !important;
}

#msh-life-os .msh-los-settings-desc {
    margin-bottom: 1rem !important;
    padding: 0 !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
}

#msh-life-os .msh-los-toggle-label {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 0 !important;
    margin: 0 !important;
    cursor: pointer !important;
}

#msh-life-os .msh-los-toggle-track {
    width: 36px !important;
    height: 20px !important;
    border-radius: 10px !important;
    flex-shrink: 0 !important;
    position: relative !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-toggle-thumb {
    width: 14px !important;
    height: 14px !important;
    border-radius: 50% !important;
    position: absolute !important;
    top: 2px !important;
    left: 2px !important;
    padding: 0 !important;
    margin: 0 !important;
}

#msh-life-os .msh-los-toggle-text {
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
}

/* Backlog view */
#msh-life-os .msh-los-backlog-card {
    padding: 13px 15px !important;
    margin-bottom: 8px !important;
    border-radius: 10px !important;
}

#msh-life-os .msh-los-backlog-pillar-label {
    margin-bottom: 8px !important;
    padding: 0 !important;
    display: block !important;
    font-size: 10px !important;
}

#msh-life-os .msh-los-backlog-item {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 0 !important;
    margin: 0 !important;
    flex-wrap: wrap !important;
    border-bottom: 0.5px solid rgba(240,240,240,0.06) !important;
}

#msh-life-os .msh-los-backlog-item-text {
    flex: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
    min-width: 120px !important;
}

#msh-life-os .msh-los-backlog-due {
    padding: 0 !important;
    margin: 0 !important;
    font-size: 11px !important;
}

#msh-life-os .msh-los-blocked-tag {
    padding: 2px 8px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    font-size: 10px !important;
}

/* Journal */
#msh-life-os .msh-los-journal-prompt {
    padding: 12px 14px !important;
    margin-top: 8px !important;
    border-radius: 0 8px 8px 0 !important;
}

#msh-life-os .msh-los-journal-q {
    margin-bottom: 8px !important;
    padding: 0 !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-journal-input {
    width: 100% !important;
    padding: 8px 10px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    min-height: 72px !important;
    resize: vertical !important;
}

#msh-life-os .msh-los-journal-save {
    padding: 5px 14px !important;
    margin-top: 8px !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 11px !important;
}

#msh-life-os .msh-los-journal-entry {
    padding: 14px !important;
    margin-bottom: 10px !important;
    border-radius: 8px !important;
}

#msh-life-os .msh-los-journal-entry-meta {
    margin-bottom: 4px !important;
    padding: 0 !important;
    font-size: 11px !important;
}

#msh-life-os .msh-los-journal-entry-prompt {
    margin-bottom: 8px !important;
    padding: 0 !important;
    font-size: 12px !important;
}

#msh-life-os .msh-los-journal-entry-text {
    padding: 0 !important;
    margin: 0 !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
}

/* Modal */
#msh-life-os .msh-los-modal {
    padding: 1.5rem !important;
    border-radius: 12px !important;
}

#msh-life-os .msh-los-modal-title {
    margin: 0 0 10px !important;
    padding: 0 !important;
    font-size: 18px !important;
}

/* Responsive */
@media (max-width: 600px) {
    #msh-life-os .msh-los-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    #msh-life-os .msh-los-period-tab {
        padding: 4px 9px !important;
        font-size: 11px !important;
    }
}

/* Centre the plugin within WordPress content area */
.entry-content #msh-life-os,
.page-content #msh-life-os,
.wp-block-post-content #msh-life-os,
article #msh-life-os {
    margin-left: auto !important;
    margin-right: auto !important;
    display: block !important;
}


/* ══════════════════════════════════════════════════════════════════════════
   VISUAL REFRESH LAYER
   Gold top border, tinted pillar cards, coloured metrics, gold active tab,
   pillar names in accent colour, gold backlog button.
   ══════════════════════════════════════════════════════════════════════════ */

/* Gold top border on wrapper */
#msh-life-os {
    border-top: 2px solid #c9973a !important;
}

/* Active period tab — gold fill */
#msh-life-os .msh-los-period-tab.active {
    background: #c9973a !important;
    border-color: #c9973a !important;
    color: #0a0f1e !important;
    font-weight: 500 !important;
}

/* Backlog button — gold tint */
#msh-life-os .msh-los-backlog-btn {
    border-color: rgba(201,151,58,0.35) !important;
    background: rgba(201,151,58,0.08) !important;
    color: #c9973a !important;
}

#msh-life-os .msh-los-backlog-btn:hover {
    background: rgba(201,151,58,0.15) !important;
}

/* Streak metric — gold */
#msh-life-os .msh-los-metric:nth-child(3) {
    background: rgba(201,151,58,0.1) !important;
    border-color: rgba(201,151,58,0.25) !important;
}

#msh-life-os .msh-los-metric:nth-child(3) .msh-los-metric-val {
    color: #c9973a !important;
}

/* Active goals metric — teal */
#msh-life-os .msh-los-metric:nth-child(4) {
    background: rgba(42,157,143,0.1) !important;
    border-color: rgba(42,157,143,0.25) !important;
}

#msh-life-os .msh-los-metric:nth-child(4) .msh-los-metric-val {
    color: #2a9d8f !important;
}

/* Pillar card tinted backgrounds per pillar */
#msh-life-os .msh-los-pillar-card[data-pillar="mind"] {
    background: rgba(127,119,221,0.07) !important;
    border-color: rgba(127,119,221,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="health"] {
    background: rgba(106,158,114,0.07) !important;
    border-color: rgba(106,158,114,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="learning"] {
    background: rgba(74,154,58,0.07) !important;
    border-color: rgba(74,154,58,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="experience"] {
    background: rgba(212,83,126,0.07) !important;
    border-color: rgba(212,83,126,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="rel_personal"] {
    background: rgba(42,157,143,0.07) !important;
    border-color: rgba(42,157,143,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="rel_professional"] {
    background: rgba(26,125,111,0.07) !important;
    border-color: rgba(26,125,111,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="career"] {
    background: rgba(74,127,165,0.07) !important;
    border-color: rgba(74,127,165,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="biz_admin"] {
    background: rgba(45,95,130,0.07) !important;
    border-color: rgba(45,95,130,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="biz_ops"] {
    background: rgba(58,111,149,0.07) !important;
    border-color: rgba(58,111,149,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="biz_growth"] {
    background: rgba(90,143,181,0.07) !important;
    border-color: rgba(90,143,181,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="fin_cashflow"] {
    background: rgba(201,151,58,0.07) !important;
    border-color: rgba(201,151,58,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="fin_wealth"] {
    background: rgba(160,120,40,0.07) !important;
    border-color: rgba(160,120,40,0.15) !important;
}
#msh-life-os .msh-los-pillar-card[data-pillar="legacy"] {
    background: rgba(186,117,23,0.07) !important;
    border-color: rgba(186,117,23,0.15) !important;
}

/* Pillar names in their accent colour — applied via inline style in JS,
   but we also set a base so it reads well against the tinted card */
#msh-life-os .msh-los-pillar-card[data-pillar="mind"]             .msh-los-pillar-name { color: #9f9be8 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="health"]           .msh-los-pillar-name { color: #7ab88a !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="learning"]         .msh-los-pillar-name { color: #7ac46a !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="experience"]       .msh-los-pillar-name { color: #e07aa0 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="rel_personal"]     .msh-los-pillar-name { color: #4ab8ac !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="rel_professional"] .msh-los-pillar-name { color: #3a9e92 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="career"]           .msh-los-pillar-name { color: #6aa3c8 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="biz_admin"]        .msh-los-pillar-name { color: #5a8fb5 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="biz_ops"]          .msh-los-pillar-name { color: #6a9fc5 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="biz_growth"]       .msh-los-pillar-name { color: #7ab3d4 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="fin_cashflow"]     .msh-los-pillar-name { color: #d4a84a !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="fin_wealth"]       .msh-los-pillar-name { color: #b89040 !important; }
#msh-life-os .msh-los-pillar-card[data-pillar="legacy"]           .msh-los-pillar-name { color: #c9973a !important; }

/* Cormorant for pillar names so they feel premium */
#msh-life-os .msh-los-pillar-name {
    font-family: 'Cormorant Garamond', Georgia, serif !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    letter-spacing: 0.01em !important;
}

/* Title also gets serif treatment */
#msh-life-os .msh-los-title {
    font-family: 'Cormorant Garamond', Georgia, serif !important;
    font-size: 24px !important;
    font-weight: 400 !important;
    color: #f5f0e8 !important;
    letter-spacing: 0.01em !important;
}

/* Metric vals use serif too — feels more considered */
#msh-life-os .msh-los-metric-val {
    font-family: 'Cormorant Garamond', Georgia, serif !important;
    font-size: 26px !important;
    font-weight: 400 !important;
}

/* ── Reflections metric card ─────────────────────────────────────────────── */
#msh-life-os .msh-los-metrics {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
}

#msh-life-os .msh-los-metric-journal {
    background: rgba(127,119,221,0.1) !important;
    border-color: rgba(127,119,221,0.25) !important;
    cursor: pointer !important;
    transition: background 0.15s !important;
}

#msh-life-os .msh-los-metric-journal:hover {
    background: rgba(127,119,221,0.18) !important;
}

#msh-life-os .msh-los-metric-journal .msh-los-metric-val {
    color: #9f9be8 !important;
}

#msh-life-os .msh-los-metric-journal .msh-los-metric-sub {
    color: rgba(159,155,232,0.6) !important;
}

@media (max-width: 860px) {
    #msh-life-os .msh-los-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 480px) {
    #msh-life-os .msh-los-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* ── Wizard Step 3 — template checkboxes ─────────────────────────────────── */
#msh-life-os .msh-los-tpl-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    margin-bottom: 8px !important;
}

#msh-life-os .msh-los-tpl-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 10px !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: background 0.12s !important;
    color: rgba(255,255,255,0.88) !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
}

#msh-life-os .msh-los-tpl-row:hover {
    background: rgba(255,255,255,0.06) !important;
}

#msh-life-os .msh-los-tpl-row input[type="checkbox"] {
    flex-shrink: 0 !important;
    width: 15px !important;
    height: 15px !important;
    accent-color: #7f77dd !important;
    cursor: pointer !important;
}

#msh-life-os .msh-los-tpl-title {
    flex: 1 !important;
}

#msh-life-os .msh-los-community-badge {
    font-size: 13px !important;
    opacity: 0.75 !important;
    flex-shrink: 0 !important;
    title: attr(title) !important;
}

#msh-life-os .msh-los-tpl-custom-row {
    margin-top: 4px !important;
    margin-bottom: 8px !important;
    padding-left: 2px !important;
}

#msh-life-os .msh-los-tpl-custom-row .msh-los-wizard-input {
    font-style: italic !important;
    font-size: 12px !important;
    opacity: 0.75 !important;
    padding: 5px 10px !important;
}

#msh-life-os .msh-los-tpl-custom-row .msh-los-wizard-input:focus {
    opacity: 1 !important;
    font-style: normal !important;
}

#msh-life-os .msh-los-wizard-loading {
    color: rgba(255,255,255,0.5) !important;
    font-style: italic !important;
    padding: 16px 0 !important;
    text-align: center !important;
}

/* ── Dashboard — inline task title editing ───────────────────────────────── */
#msh-life-os .msh-los-task-label-editable {
    cursor: text !important;
    flex: 1 !important;
}

#msh-life-os .msh-los-task-label-editable:hover:not(.done) {
    color: #fff !important;
    text-decoration: underline dotted rgba(255,255,255,0.3) !important;
}

#msh-life-os .msh-los-task-edit-input {
    background: rgba(255,255,255,0.08) !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    border-radius: 4px !important;
    color: #fff !important;
    font-size: 13px !important;
    padding: 3px 8px !important;
    width: calc(100% - 120px) !important;
    min-width: 120px !important;
    outline: none !important;
}

#msh-life-os .msh-los-task-edit-input:focus {
    border-color: rgba(127,119,221,0.6) !important;
    background: rgba(127,119,221,0.1) !important;
}

#msh-life-os .msh-los-task-edit-actions {
    display: inline-flex !important;
    gap: 6px !important;
    margin-left: 8px !important;
    vertical-align: middle !important;
}

/* ── Templates panel ─────────────────────────────────────────────────────── */
#msh-life-os .msh-los-templates-actions {
    margin-top: 24px !important;
    padding-top: 20px !important;
    border-top: 1px solid rgba(255,255,255,0.08) !important;
    display: flex !important;
    gap: 12px !important;
    align-items: center !important;
}

#msh-life-os #los-browse-templates {
    cursor: pointer !important;
    color: rgba(255,255,255,0.45) !important;
    text-decoration: none !important;
    font-size: 12px !important;
    transition: color 0.15s !important;
}

#msh-life-os #los-browse-templates:hover {
    color: rgba(255,255,255,0.75) !important;
    text-decoration: underline !important;
}

/* ── Input colour fix — force dark bg/light text on all inputs ───────────── */
/* Theme stylesheets can override background/color on inputs. These rules    */
/* lock the dark treatment across all Life OS form elements.                 */
#msh-life-os input[type="text"],
#msh-life-os input[type="date"],
#msh-life-os input[type="number"],
#msh-life-os input[type="email"],
#msh-life-os textarea,
#msh-life-os select {
    background: rgba(255,255,255,0.06) !important;
    color: #f0f0f0 !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    border-radius: 6px !important;
    font-family: 'Archivo', sans-serif !important;
}

#msh-life-os input[type="text"]:focus,
#msh-life-os input[type="date"]:focus,
#msh-life-os input[type="number"]:focus,
#msh-life-os input[type="email"]:focus,
#msh-life-os textarea:focus,
#msh-life-os select:focus {
    background: rgba(255,255,255,0.09) !important;
    border-color: rgba(255,255,255,0.35) !important;
    color: #ffffff !important;
    outline: none !important;
}

/* Placeholder text */
#msh-life-os input::placeholder,
#msh-life-os textarea::placeholder {
    color: rgba(240,240,240,0.35) !important;
    font-style: italic !important;
}

/* Select option items — browsers are inconsistent here */
#msh-life-os select option {
    background: #0a0f1e !important;
    color: #f0f0f0 !important;
}

/* ── Goals view ──────────────────────────────────────────────────────────── */
#msh-life-os .msh-los-goals-filters {
    display: flex !important;
    gap: 10px !important;
    margin-bottom: 20px !important;
    flex-wrap: wrap !important;
}

#msh-life-os .msh-los-goals-filters select {
    min-width: 150px !important;
    padding: 7px 12px !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-goals-pillar-section {
    margin-bottom: 24px !important;
}

#msh-life-os .msh-los-goals-pillar-heading {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    margin-bottom: 10px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
}

#msh-life-os .msh-los-pillar-accent-dot {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
    display: inline-block !important;
}

#msh-life-os .msh-los-goals-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px 12px !important;
    border-radius: 7px !important;
    background: rgba(255,255,255,0.03) !important;
    margin-bottom: 6px !important;
    position: relative !important;
}

#msh-life-os .msh-los-goals-row:hover {
    background: rgba(255,255,255,0.055) !important;
}

#msh-life-os .msh-los-goals-row-title {
    flex: 1 !important;
    font-size: 13px !important;
    color: rgba(255,255,255,0.88) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}

#msh-life-os .msh-los-goals-stale-dot {
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: #c9973a !important;
    flex-shrink: 0 !important;
    display: inline-block !important;
    cursor: help !important;
}

#msh-life-os .msh-los-goals-date {
    font-size: 11px !important;
    color: rgba(255,255,255,0.4) !important;
    margin-left: 4px !important;
}

#msh-life-os .msh-los-goals-status-badge {
    cursor: pointer !important;
    flex-shrink: 0 !important;
}

/* Goals metric card — clickable like journal card */
#msh-life-os .msh-los-metric-goals {
    background: rgba(74,127,165,0.1) !important;
    border-color: rgba(74,127,165,0.25) !important;
    cursor: pointer !important;
    transition: background 0.15s !important;
}

#msh-life-os .msh-los-metric-goals:hover {
    background: rgba(74,127,165,0.18) !important;
}

#msh-life-os .msh-los-metric-goals .msh-los-metric-val {
    color: #6aafd4 !important;
}

/* ── Settings — pillar action row ────────────────────────────────────────── */
#msh-life-os .msh-los-settings-pillar-actions {
    display: flex !important;
    gap: 12px !important;
    align-items: center !important;
    margin-top: 1rem !important;
    flex-wrap: wrap !important;
}

/* ── Button working/loading state ────────────────────────────────────────── */
#msh-life-os .msh-los-btn-working,
#msh-life-os .msh-los-btn-working:hover {
    background: #4a4a5a !important;
    border-color: #4a4a5a !important;
    color: rgba(255,255,255,0.5) !important;
    cursor: not-allowed !important;
    animation: msh-los-pulse 1.4s ease-in-out infinite !important;
}

@keyframes msh-los-pulse {
    0%   { opacity: 1; }
    50%  { opacity: 0.6; }
    100% { opacity: 1; }
}

/* ── Reflection form ─────────────────────────────────────────────────────── */
#msh-life-os .msh-los-reflection-form {
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: 10px !important;
    padding: 18px !important;
    margin: 12px 0 !important;
}

#msh-life-os .msh-los-reflection-inline {
    margin: 10px 0 !important;
}

#msh-life-os .msh-los-rf-scales {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    margin-bottom: 16px !important;
}

#msh-life-os .msh-los-rf-scale-row {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

#msh-life-os .msh-los-rf-scale-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,0.6) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

#msh-life-os .msh-los-rf-scale-anchors {
    display: flex !important;
    justify-content: space-between !important;
    font-size: 10px !important;
    color: rgba(255,255,255,0.35) !important;
    padding: 0 2px !important;
}

#msh-life-os .msh-los-rf-scale-btns {
    display: flex !important;
    gap: 4px !important;
    flex-wrap: wrap !important;
}

#msh-life-os .msh-los-rf-scale-btn {
    width: 32px !important;
    height: 32px !important;
    border-radius: 6px !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    background: rgba(255,255,255,0.05) !important;
    color: rgba(255,255,255,0.6) !important;
    font-size: 12px !important;
    font-family: 'Archivo', sans-serif !important;
    cursor: pointer !important;
    transition: all 0.12s !important;
    padding: 0 !important;
}

#msh-life-os .msh-los-rf-scale-btn:hover {
    background: rgba(255,255,255,0.12) !important;
    color: #fff !important;
    border-color: rgba(255,255,255,0.3) !important;
}

#msh-life-os .msh-los-rf-scale-btn.selected {
    background: #7f77dd !important;
    border-color: #7f77dd !important;
    color: #fff !important;
    font-weight: 600 !important;
}

#msh-life-os .msh-los-rf-text-row {
    margin-bottom: 12px !important;
}

#msh-life-os .msh-los-rf-text-label {
    display: block !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,0.6) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 6px !important;
}

#msh-life-os .msh-los-rf-optional {
    font-weight: 400 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: rgba(255,255,255,0.3) !important;
    font-size: 11px !important;
}

#msh-life-os .msh-los-rf-actions {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    margin-top: 14px !important;
    padding-top: 14px !important;
    border-top: 1px solid rgba(255,255,255,0.06) !important;
}

/* ── Reflection trigger note ─────────────────────────────────────────────── */
#msh-life-os .msh-los-reflection-trigger-note {
    font-size: 11px !important;
    color: rgba(255,255,255,0.35) !important;
    margin: 4px 0 16px !important;
    line-height: 1.5 !important;
}

#msh-life-os .msh-los-reflection-trigger-note em {
    color: rgba(255,255,255,0.55) !important;
    font-style: normal !important;
    font-weight: 600 !important;
}

/* ── Reflection history cards ────────────────────────────────────────────── */
#msh-life-os .msh-los-journal-entry {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    border-radius: 10px !important;
    padding: 16px !important;
    margin-bottom: 12px !important;
}

#msh-life-os .msh-los-journal-entry-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 10px !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

#msh-life-os .msh-los-entry-chips {
    display: flex !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}

#msh-life-os .msh-los-entry-chip {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid var(--chip-color, rgba(255,255,255,0.15)) !important;
    border-radius: 20px !important;
    padding: 2px 8px !important;
    font-size: 11px !important;
}

#msh-life-os .msh-los-chip-label {
    color: rgba(255,255,255,0.5) !important;
}

#msh-life-os .msh-los-chip-val {
    color: var(--chip-color, rgba(255,255,255,0.8)) !important;
    font-weight: 600 !important;
}

#msh-life-os .msh-los-entry-what-mattered {
    font-size: 13px !important;
    color: rgba(255,255,255,0.75) !important;
    margin-bottom: 10px !important;
    padding: 8px 10px !important;
    background: rgba(255,255,255,0.04) !important;
    border-left: 2px solid rgba(201,151,58,0.5) !important;
    border-radius: 0 4px 4px 0 !important;
}

#msh-life-os .msh-los-entry-wm-label {
    color: rgba(255,255,255,0.4) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    margin-right: 4px !important;
}

#msh-life-os .msh-los-journal-entry-prompt {
    font-size: 12px !important;
    color: rgba(255,255,255,0.4) !important;
    font-style: italic !important;
    margin-bottom: 6px !important;
}

#msh-life-os .msh-los-journal-entry-text {
    font-size: 13px !important;
    color: rgba(255,255,255,0.75) !important;
    line-height: 1.6 !important;
    white-space: pre-wrap !important;
}

/* Write area spacing */
#msh-life-os #los-journal-write-area {
    margin-bottom: 16px !important;
}

/* ── Backlog priority filter ─────────────────────────────────────────────── */
#msh-life-os .msh-los-backlog-filters {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 16px !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

#msh-life-os .msh-los-backlog-pri-filters {
    display: flex !important;
    gap: 6px !important;
}

#msh-life-os .msh-los-pri-filter {
    padding: 4px 12px !important;
    border-radius: 20px !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    background: transparent !important;
    color: rgba(255,255,255,0.5) !important;
    font-size: 12px !important;
    font-family: 'Archivo', sans-serif !important;
    cursor: pointer !important;
    transition: all 0.12s !important;
}

#msh-life-os .msh-los-pri-filter:hover {
    border-color: rgba(255,255,255,0.3) !important;
    color: rgba(255,255,255,0.8) !important;
}

#msh-life-os .msh-los-pri-filter.active {
    background: rgba(127,119,221,0.2) !important;
    border-color: #7f77dd !important;
    color: #9f9be8 !important;
}

#msh-life-os .msh-los-completed-toggle {
    font-size: 12px !important;
    color: rgba(255,255,255,0.4) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

#msh-life-os .msh-los-completed-toggle:hover {
    color: rgba(255,255,255,0.65) !important;
}

/* ── Backlog item — completion state ─────────────────────────────────────── */
#msh-life-os .msh-los-backlog-complete-btn {
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    border: 1.5px solid rgba(255,255,255,0.25) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 10px !important;
    color: rgba(255,255,255,0.3) !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    transition: all 0.12s !important;
}

#msh-life-os .msh-los-backlog-complete-btn:hover {
    border-color: #6a9e72 !important;
    color: #6a9e72 !important;
    background: rgba(106,158,114,0.1) !important;
}

#msh-life-os .msh-los-backlog-done-icon {
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    background: rgba(106,158,114,0.2) !important;
    border: 1.5px solid #6a9e72 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 10px !important;
    color: #6a9e72 !important;
    flex-shrink: 0 !important;
}

#msh-life-os .msh-los-backlog-item.completed {
    opacity: 0.55 !important;
}

#msh-life-os .msh-los-backlog-item-text.done {
    text-decoration: line-through !important;
    color: rgba(255,255,255,0.35) !important;
}

#msh-life-os .msh-los-backlog-completed-at {
    font-size: 10px !important;
    color: rgba(255,255,255,0.3) !important;
    margin-left: auto !important;
}

/* ── Event reflection panel ──────────────────────────────────────────────── */
#msh-life-os .msh-los-event-reflection {
    background: rgba(127,119,221,0.07) !important;
    border: 1px solid rgba(127,119,221,0.25) !important;
    border-radius: 10px !important;
    padding: 16px !important;
    margin: 12px 0 !important;
}

#msh-life-os .msh-los-event-reflection-header {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
}

#msh-life-os .msh-los-event-reflection-icon {
    font-size: 18px !important;
    flex-shrink: 0 !important;
}

#msh-life-os .msh-los-event-reflection-title {
    flex: 1 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,0.85) !important;
}

#msh-life-os .msh-los-event-reflection-skip {
    flex-shrink: 0 !important;
    font-size: 11px !important;
    color: rgba(255,255,255,0.35) !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    padding: 2px 8px !important;
}

#msh-life-os .msh-los-event-reflection-skip:hover {
    color: rgba(255,255,255,0.6) !important;
}

/* Floating event reflection area (goal achievement from dashboard) */
#los-event-reflection-area {
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    width: 380px !important;
    max-width: calc(100vw - 48px) !important;
    z-index: 9999 !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.4) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

/* ── Backlog item body layout ────────────────────────────────────────────── */
#msh-life-os .msh-los-backlog-item {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    padding: 10px 12px !important;
    border-radius: 7px !important;
    background: rgba(255,255,255,0.03) !important;
    margin-bottom: 6px !important;
}

#msh-life-os .msh-los-backlog-item-body {
    flex: 1 !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
}

#msh-life-os .msh-los-backlog-item-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
    margin-top: 2px !important;
}

#msh-life-os .msh-los-backlog-edit-btn {
    color: rgba(255,255,255,0.3) !important;
    cursor: pointer !important;
    font-size: 13px !important;
    padding: 2px 4px !important;
    transition: color 0.12s !important;
    flex-shrink: 0 !important;
}

#msh-life-os .msh-los-backlog-edit-btn:hover {
    color: rgba(255,255,255,0.7) !important;
}

/* ── Email toggles — settings panel ─────────────────────────────────────── */
#msh-life-os .msh-los-email-toggles {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    margin-top: 12px !important;
}

#msh-life-os .msh-los-toggle-sub {
    font-size: 11px !important;
    color: rgba(255,255,255,0.35) !important;
    font-weight: 400 !important;
    display: block !important;
    margin-top: 1px !important;
}

/* ── Snapshot metric card ────────────────────────────────────────────────── */
#msh-life-os .msh-los-metric-snapshot {
    background: rgba(201,151,58,0.08) !important;
    border-color: rgba(201,151,58,0.2) !important;
    cursor: pointer !important;
    transition: background 0.15s !important;
}

#msh-life-os .msh-los-metric-snapshot:hover {
    background: rgba(201,151,58,0.15) !important;
}

#msh-life-os .msh-los-metric-snapshot .msh-los-metric-val {
    color: #c9973a !important;
}

#msh-life-os .msh-los-metric-snapshot .msh-los-metric-sub {
    color: rgba(201,151,58,0.6) !important;
}

/* ── Snapshot view ───────────────────────────────────────────────────────── */
#msh-life-os .msh-los-snapshot-metrics {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0,1fr)) !important;
    gap: 10px !important;
    margin-bottom: 24px !important;
}

#msh-life-os .msh-los-snapshot-metric-card {
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    border-radius: 8px !important;
    padding: 14px !important;
}

#msh-life-os .msh-los-snapshot-metric-label {
    font-size: 11px !important;
    color: rgba(255,255,255,0.4) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    margin-bottom: 6px !important;
}

#msh-life-os .msh-los-snapshot-metric-val {
    font-size: 22px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    margin-bottom: 4px !important;
}

#msh-life-os .msh-los-snapshot-metric-sub {
    font-size: 11px !important;
    color: rgba(255,255,255,0.3) !important;
}

#msh-life-os .msh-los-snapshot-section {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    border-radius: 10px !important;
    padding: 16px !important;
    margin-bottom: 16px !important;
}

#msh-life-os .msh-los-snapshot-section-title {
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    color: rgba(255,255,255,0.35) !important;
    margin-bottom: 14px !important;
}

#msh-life-os .msh-los-snapshot-bar-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
}

#msh-life-os .msh-los-snapshot-bar-label {
    width: 120px !important;
    flex-shrink: 0 !important;
    font-size: 12px !important;
    color: rgba(255,255,255,0.6) !important;
}

#msh-life-os .msh-los-snapshot-bar-track {
    flex: 1 !important;
    height: 7px !important;
    background: rgba(255,255,255,0.08) !important;
    border-radius: 4px !important;
    overflow: hidden !important;
}

#msh-life-os .msh-los-snapshot-bar-fill {
    height: 100% !important;
    border-radius: 4px !important;
    min-width: 2px !important;
    transition: width 0.4s ease !important;
}

#msh-life-os .msh-los-snapshot-bar-val {
    width: 44px !important;
    flex-shrink: 0 !important;
    font-size: 12px !important;
    color: rgba(255,255,255,0.4) !important;
    text-align: right !important;
}

#msh-life-os .msh-los-snapshot-row2 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}

#msh-life-os .msh-los-snapshot-chart-wrap {
    position: relative !important;
    height: 160px !important;
    margin-bottom: 8px !important;
}

#msh-life-os .msh-los-snapshot-chart-legend {
    font-size: 11px !important;
    color: rgba(255,255,255,0.4) !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

#msh-life-os .msh-los-sn-dot {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    display: inline-block !important;
    flex-shrink: 0 !important;
}

#msh-life-os .msh-los-snapshot-ach-item {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    padding: 8px 0 !important;
    border-bottom: 0.5px solid rgba(255,255,255,0.06) !important;
}

#msh-life-os .msh-los-snapshot-ach-item:last-child {
    border-bottom: none !important;
}

#msh-life-os .msh-los-snapshot-ach-dot {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
    margin-top: 4px !important;
}

#msh-life-os .msh-los-snapshot-ach-title {
    font-size: 13px !important;
    color: rgba(255,255,255,0.8) !important;
    line-height: 1.4 !important;
}

#msh-life-os .msh-los-snapshot-ach-meta {
    font-size: 11px !important;
    color: rgba(255,255,255,0.35) !important;
    margin-top: 2px !important;
}

@media (max-width: 600px) {
    #msh-life-os .msh-los-snapshot-metrics {
        grid-template-columns: repeat(2, minmax(0,1fr)) !important;
    }
    #msh-life-os .msh-los-snapshot-row2 {
        grid-template-columns: 1fr !important;
    }
}

/* ── Goal focus flag ─────────────────────────────────────────────────────── */
#msh-life-os .msh-los-focus-btn {
    background: transparent !important;
    border: none !important;
    color: rgba(255,255,255,0.2) !important;
    font-size: 14px !important;
    cursor: pointer !important;
    padding: 2px 4px !important;
    flex-shrink: 0 !important;
    transition: color 0.12s !important;
    line-height: 1 !important;
}

#msh-life-os .msh-los-focus-btn:hover {
    color: rgba(255,255,255,0.6) !important;
}

#msh-life-os .msh-los-focus-btn.focused {
    color: #c9973a !important;
}

/* Focused goal row — dashboard pillar card */
#msh-life-os .msh-los-goal-item.msh-los-goal-focused {
    background: rgba(201,151,58,0.06) !important;
    border-left: 2px solid rgba(201,151,58,0.4) !important;
    border-radius: 0 6px 6px 0 !important;
    padding-left: 10px !important;
    margin-left: -2px !important;
}

#msh-life-os .msh-los-goal-focus-icon {
    color: #c9973a !important;
    font-size: 13px !important;
    margin-right: 4px !important;
    flex-shrink: 0 !important;
}

/* Focused goal row — goals view */
#msh-life-os .msh-los-goals-row.msh-los-goal-focused {
    background: rgba(201,151,58,0.06) !important;
    border-left: 2px solid rgba(201,151,58,0.35) !important;
    border-radius: 0 7px 7px 0 !important;
    margin-left: -2px !important;
    padding-left: 10px !important;
}

/* Goals view filter row — focus button */
#msh-life-os #gf-focus {
    font-size: 12px !important;
    padding: 5px 12px !important;
}

/* ── Reflection saved confirmation ───────────────────────────────────────── */
#msh-life-os .msh-los-reflection-saved-note {
    margin: 0 !important;
    font-size: 13px !important;
    color: #6a9e72 !important;
    padding: 6px 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

/* ── Achieved goals — pillar card ────────────────────────────────────────── */
#msh-life-os .msh-los-show-achieved-btn {
    background: transparent !important;
    border: none !important;
    color: rgba(255,255,255,0.3) !important;
    font-size: 11px !important;
    cursor: pointer !important;
    padding: 4px 0 !important;
    display: block !important;
    margin-top: 2px !important;
    transition: color 0.12s !important;
}

#msh-life-os .msh-los-show-achieved-btn:hover {
    color: rgba(255,255,255,0.55) !important;
}

#msh-life-os .msh-los-goal-item.msh-los-goal-achieved {
    opacity: 0.5 !important;
}

#msh-life-os .msh-los-goal-item .achieved-text,
#msh-life-os .msh-los-goals-row-title.achieved-text {
    text-decoration: line-through !important;
    color: rgba(255,255,255,0.4) !important;
}

/* ── Achieved goals — goals view row ─────────────────────────────────────── */
#msh-life-os .msh-los-goals-row.msh-los-goal-achieved-row {
    opacity: 0.55 !important;
}

#msh-life-os .msh-los-goal-achieved-tick {
    color: #6a9e72 !important;
    font-size: 13px !important;
    flex-shrink: 0 !important;
    margin-right: 2px !important;
}

/* ── Goals view achieved window selector ─────────────────────────────────── */
#msh-life-os #gf-achieved-window {
    font-size: 12px !important;
}

/* ── Snapshot — hierarchical sub-cadence sections ────────────────────────── */
#msh-life-os .msh-los-snapshot-day-grid {
    display: grid !important;
    grid-template-columns: repeat(7, minmax(0,1fr)) !important;
    gap: 6px !important;
}

#msh-life-os .msh-los-snapshot-day {
    border: 0.5px solid rgba(255,255,255,0.08) !important;
    border-radius: var(--border-radius-md, 8px) !important;
    padding: 10px 6px !important;
    text-align: center !important;
}

#msh-life-os .msh-los-snapshot-day.today {
    border-color: #7f77dd !important;
}

#msh-life-os .msh-los-sn-day-name {
    font-size: 10px !important;
    color: rgba(255,255,255,0.35) !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    margin-bottom: 6px !important;
}

#msh-life-os .msh-los-snapshot-day.today .msh-los-sn-day-name {
    color: #7f77dd !important;
}

#msh-life-os .msh-los-sn-day-pct {
    font-size: 16px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    margin-bottom: 4px !important;
}

#msh-life-os .msh-los-sn-day-done {
    font-size: 10px !important;
    color: rgba(255,255,255,0.3) !important;
}

#msh-life-os .msh-los-snapshot-week-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 9px 12px !important;
    border-radius: 7px !important;
    background: rgba(255,255,255,0.03) !important;
    margin-bottom: 7px !important;
}

#msh-life-os .msh-los-snapshot-week-label {
    width: 100px !important;
    flex-shrink: 0 !important;
    font-size: 12px !important;
    color: rgba(255,255,255,0.55) !important;
}

#msh-life-os .msh-los-snapshot-week-pct {
    width: 36px !important;
    flex-shrink: 0 !important;
    font-size: 12px !important;
    color: rgba(255,255,255,0.4) !important;
    text-align: right !important;
}

#msh-life-os .msh-los-snapshot-week-mood {
    width: 58px !important;
    flex-shrink: 0 !important;
    font-size: 11px !important;
    color: rgba(255,255,255,0.35) !important;
    text-align: right !important;
}

/* ── Bulk import UI ──────────────────────────────────────────────────────── */
#msh-life-os .msh-los-import-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    margin-top: 12px !important;
}

#msh-life-os .msh-los-file-label {
    cursor: pointer !important;
    display: inline-block !important;
}

/* ── Wizard tip ──────────────────────────────────────────────────────────── */
#msh-life-os .msh-los-wizard-tip {
    background: rgba(201,151,58,0.08) !important;
    border: 0.5px solid rgba(201,151,58,0.2) !important;
    border-radius: 7px !important;
    padding: 10px 14px !important;
    font-size: 12px !important;
    color: rgba(201,151,58,0.85) !important;
    margin: 10px 0 16px !important;
    line-height: 1.5 !important;
}

/* ── Goal inline edit ────────────────────────────────────────────────────── */
#msh-life-os .msh-los-goals-row-title {
    display: flex !important;
    align-items: center !important;
    flex: 1 !important;
    gap: 6px !important;
    min-width: 0 !important;
    cursor: text !important;
}

#msh-life-os .msh-los-goal-edit-input {
    flex: 1 !important;
    min-width: 0 !important;
    font-size: 13px !important;
}

#msh-life-os .msh-los-goal-edit-date {
    font-size: 12px !important;
}
