
:root {
    --charcoal: #5B5B5B;
    --orange: #F49D0B;
    --orange-dark: #D98200;
    --orange-soft: #FFF3E1;
    --ink: #1A1F2B;
    --ink-soft: #475064;
    --bg: #F6F4F0;
    --white: #FFFFFF;
    --border: #E4DED5;
    --line: #EEE8E0;
    --muted: #747D8E;
    --danger: #B42318;
    --success: #247A3B;
    --shadow: 0 8px 24px rgba(22, 24, 29, 0.055);
    --shadow-soft: 0 2px 10px rgba(22, 24, 29, 0.04);
}

* { box-sizing: border-box; }

html, body { margin: 0; }

body {
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color: var(--ink);
    background: var(--bg);
    font-size: 14px;
    line-height: 1.42;
}

a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }

.app-shell { display: flex; min-height: 100vh; }

.sidebar {
    width: 218px;
    background: rgba(255,255,255,0.92);
    border-right: 1px solid var(--border);
    padding: 20px 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.brand {
    align-items: center; padding: 0 10px 8px; }

.brand img {
    width: 176px;
    max-width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}

.nav { display: flex; flex-direction: column; gap: 5px; }

.nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 11px;
    color: var(--ink-soft);
    font-weight: 600;
    font-size: 13.5px;
    transition: all .16s ease;
}

.nav-link:hover { background: var(--orange-soft); color: var(--ink); }

.nav-link.active {
    background: #FCEBD3;
    color: var(--orange-dark);
    box-shadow: inset 0 0 0 1px rgba(244,157,11,0.14);
}

.nav-icon { width: 18px; height: 18px; flex: 0 0 18px; }

.sidebar-footer { margin-top: auto; padding: 0 8px; }

.sidebar-collapse-btn {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 9px;
    border: 0;
    background: transparent;
    color: var(--muted);
    padding: 8px 6px;
    border-radius: 10px;
    font-size: 13px;
}

.collapse-arrow {
    width: 22px;
    height: 22px;
    border-radius: 999px;
    border: 1px solid var(--border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--white);
}

.main {
    flex: 1;
    padding: 16px 20px 26px;
    min-width: 0;
}

.topbar-card {
    background: rgba(255,255,255,0.9);
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: var(--shadow-soft);
    min-height: 54px;
    padding: 8px 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.topbar-left, .topbar-right { display: flex; align-items: center; gap: 12px; }

.firm-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--charcoal);
    font-weight: 600;
    font-size: 13px;
}

.firm-chip::after {
    content: "";
    width: 1px;
    height: 24px;
    background: var(--line);
    margin-left: 8px;
}

.micro-icon { width: 16px; height: 16px; }
.tiny-icon { width: 14px; height: 14px; }

.icon-button {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-soft);
}

.user-menu {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--ink);
    font-weight: 600;
    font-size: 13px;
}

.avatar-circle {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: #F0EFED;
    color: var(--charcoal);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
}

.user-name { white-space: nowrap; }

.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin: 4px auto 14px;
    max-width: 1180px;
}

.page-header-left { min-width: 0; }

.page-header-right {
    display: flex;
    gap: 9px;
    align-items: center;
    flex-wrap: wrap;
}

.page-title {
    margin: 0;
    font-size: 22px;
    line-height: 1.18;
    letter-spacing: -0.01em;
    font-weight: 700;
}

.page-subtitle {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 13px;
}

.eyebrow {
    font-size: 10.5px;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--muted);
    font-weight: 700;
    margin: 0 0 4px;
}

h1, h2, h3 { margin: 0; }
h2 { font-size: 18px; }
h3 { font-size: 15px; }

.card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px;
    box-shadow: var(--shadow-soft);
}

.form-panel {
    max-width: 1180px;
    margin: 0 auto;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--shadow);
    overflow: hidden;
}

.form-section {
    padding: 18px 20px 20px;
    border-bottom: 1px solid var(--line);
}

.form-section:last-child { border-bottom: 0; }

.form-section-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
}

.section-icon-wrap {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: var(--orange-soft);
    color: var(--orange-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 28px;
}

.section-icon { width: 14px; height: 14px; }

.section-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--ink);
}

.grid { display: grid; gap: 14px; }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.metric { font-size: 28px; font-weight: 800; margin-bottom: 2px; }
.metric-label { color: var(--muted); font-size: 13px; }

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 38px;
    padding: 8px 13px;
    border-radius: 10px;
    border: 1px solid transparent;
    font-weight: 700;
    cursor: pointer;
    font-size: 13px;
    transition: all .16s ease;
}

.btn-primary {
    background: var(--orange);
    color: #fff;
    box-shadow: 0 5px 14px rgba(244,157,11,0.18);
}

.btn-primary:hover { background: var(--orange-dark); }

.btn-secondary {
    background: var(--white);
    color: var(--ink);
    border-color: var(--border);
}

.btn-danger { background: #FEE4E2; color: var(--danger); }
.btn-icon { width: 15px; height: 15px; }

.table-wrap { overflow-x: auto; }

table { width: 100%; border-collapse: collapse; }

th, td {
    text-align: left;
    padding: 11px 9px;
    border-bottom: 1px solid var(--line);
    vertical-align: top;
}

th {
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .055em;
    font-weight: 700;
}

td { font-size: 13.5px; }
tr:hover td { background: #FCFAF8; }

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
}

.form-grid-3 {
    display: grid;
    grid-template-columns: 2fr 1.25fr 1fr;
    gap: 12px 14px;
}

.form-grid-4 {
    display: grid;
    grid-template-columns: 1.35fr 1fr 0.9fr 0.9fr;
    gap: 12px 14px;
}

.form-grid .full,
.form-grid-3 .full,
.form-grid-4 .full { grid-column: 1 / -1; }

label {
    display: block;
    font-weight: 600;
    font-size: 12.5px;
    margin-bottom: 5px;
    color: var(--ink-soft);
}

.field-required::after { content: " *"; color: var(--orange-dark); }

input, select, textarea {
    width: 100%;
    border: 1px solid #DED8CF;
    border-radius: 9px;
    padding: 8px 10px;
    min-height: 37px;
    background: var(--white);
    color: var(--ink);
    font-size: 13.5px;
    transition: border-color .16s ease, box-shadow .16s ease;
}

input::placeholder, textarea::placeholder { color: #A3A9B4; }

input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: rgba(244,157,11,0.82);
    box-shadow: 0 0 0 3px rgba(244,157,11,0.13);
}

textarea { min-height: 78px; resize: vertical; }

.actions {
    display: flex;
    gap: 9px;
    align-items: center;
    margin-top: 14px;
}

.badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 700;
    background: #EFEFEF;
    color: var(--charcoal);
}

.badge-active, .badge-completed { background: #E7F6EC; color: var(--success); }
.badge-inactive, .badge-overdue, .badge-former-client { background: #FEE4E2; color: var(--danger); }
.badge-prospect, .badge-in-progress { background: #FFF2D7; color: #8A5600; }

.alert {
    max-width: 1180px;
    margin: 0 auto 14px;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--white);
    font-size: 13px;
}

.alert-error { border-color: #F5B5AF; color: var(--danger); }
.alert-success { border-color: #BFE6CA; color: var(--success); }

.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px;
    background: radial-gradient(circle at top right, rgba(244,157,11,0.12), transparent 24%), linear-gradient(180deg, #f7f5f1 0%, #f1eee8 100%);
}

.login-card {
    width: 100%;
    max-width: 420px;
    background: rgba(255,255,255,0.96);
    border: 1px solid var(--border);
    border-radius: 18px;
    box-shadow: 0 12px 36px rgba(24,24,24,0.08);
    padding: 26px;
}

.login-logo { max-width: 300px; width: 100%; height: auto; margin-bottom: 22px; object-fit: contain; }

.detail-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 14px;
}

.subtle { color: var(--muted); }
.section { margin-top: 18px; }

.record-shell {
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-width: 1180px;
    margin: 0 auto;
}

.profile-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--shadow);
    overflow: hidden;
}

.profile-top {
    padding: 20px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    border-bottom: 1px solid var(--line);
}

.profile-name-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.profile-avatar {
    width: 46px;
    height: 46px;
    border-radius: 999px;
    background: var(--orange-soft);
    color: var(--orange-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 17px;
}

.profile-name {
    font-size: 22px;
    line-height: 1.2;
    font-weight: 700;
}

.profile-meta {
    margin-top: 4px;
    color: var(--muted);
    font-size: 13px;
}

.profile-actions { display: flex; gap: 9px; align-items: flex-start; }

.info-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    border-bottom: 1px solid var(--line);
}

.info-item {
    padding: 14px 18px;
    border-right: 1px solid var(--line);
}

.info-item:last-child { border-right: 0; }

.info-label {
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .055em;
    margin-bottom: 5px;
}

.info-value {
    color: var(--ink);
    font-size: 13.5px;
    font-weight: 600;
}

.profile-section {
    padding: 18px 20px;
    border-bottom: 1px solid var(--line);
}

.profile-section:last-child { border-bottom: 0; }

.profile-section-title {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 10px;
}

.content-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.search-form {
    display: flex;
    gap: 9px;
    align-items: center;
    flex: 1;
}

@media (max-width: 1180px) {
    .grid-4, .grid-3, .grid-2, .form-grid-3, .form-grid-4, .content-grid, .info-grid {
        grid-template-columns: 1fr;
    }
    .info-item { border-right: 0; border-bottom: 1px solid var(--line); }
    .info-item:last-child { border-bottom: 0; }
}

@media (max-width: 900px) {
    .app-shell { display: block; }
    .sidebar {
        width: 100%;
        position: static;
        border-right: 0;
        border-bottom: 1px solid var(--border);
    }
    .nav { flex-direction: row; flex-wrap: wrap; }
    .main { padding: 14px; }
    .topbar-card, .page-header, .detail-header, .topbar-right, .page-header-right, .search-form, .form-grid, .grid-4, .grid-3, .grid-2, .profile-top, .profile-actions {
        display: block;
    }
    .page-header-right, .topbar-right, .search-form, .actions, .profile-actions {
        margin-top: 10px;
    }
    .page-header-right > *, .search-form > *, .actions > *, .profile-actions > * {
        width: 100%;
        margin-bottom: 8px;
    }
}


/* Full-width layout repair: do not center CRM record pages */
.main {
    padding-left: 22px;
    padding-right: 22px;
}

.page-header,
.form-panel,
.record-shell,
.alert {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
}

.page-header {
    margin-top: 2px;
}

.form-panel,
.profile-card,
.card {
    width: 100%;
}

.content-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

/* Prevent awkward fake date display for empty database dates */
.info-value:empty::after {
    content: "—";
    color: var(--muted);
}


/* Household rollup timeline */
.timeline-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.timeline-item {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr) 110px;
    gap: 14px;
    align-items: center;
    padding: 11px 0;
    border-bottom: 1px solid var(--line);
}

.timeline-item:last-child {
    border-bottom: 0;
}

.timeline-type {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    min-width: 54px;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    background: #F1F2F4;
    color: var(--ink-soft);
}

.timeline-type.note {
    background: #FFF3E1;
    color: var(--orange-dark);
}

.timeline-type.task {
    background: #EAF2FF;
    color: #285C9D;
}

.timeline-main {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.timeline-main strong {
    color: var(--ink);
    font-size: 13.5px;
}

.timeline-main span,
.timeline-date {
    color: var(--muted);
    font-size: 12.5px;
}

.timeline-date {
    text-align: right;
}

@media (max-width: 900px) {
    .timeline-item {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .timeline-date {
        text-align: left;
    }
}


/* Inline note form on person record */
.quick-note-form {
    border: 1px solid var(--line);
    background: #FCFAF7;
    border-radius: 12px;
    padding: 14px;
    margin-bottom: 14px;
}

.quick-note-form .alert {
    margin: 0 0 12px;
    max-width: none;
}


/* Quick-create person modal/dropdown helper */
.quick-create-row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.quick-create-row select {
    flex: 1;
    min-width: 0;
}

.mini-link-button {
    border: 1px solid var(--border);
    background: #fff;
    color: var(--orange-dark);
    border-radius: 9px;
    padding: 8px 10px;
    min-height: 37px;
    font-size: 12.5px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
}

.mini-link-button:hover {
    background: var(--orange-soft);
}

.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(24, 24, 24, 0.36);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 22px;
}

.modal-backdrop[hidden] {
    display: none;
}

.modal-card {
    width: 100%;
    max-width: 560px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: 0 18px 50px rgba(18, 18, 18, 0.18);
    padding: 18px;
}

.modal-header {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}

.modal-close {
    width: 34px;
    height: 34px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: #fff;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
}

.modal-error {
    max-width: none;
    margin: 12px 0 0;
}

@media (max-width: 700px) {
    .quick-create-row {
        flex-direction: column;
        align-items: stretch;
    }
}


/* Sticky left navigation and global search */
.sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}

.topbar-card {
    position: sticky;
    top: 12px;
    z-index: 100;
}

.topbar-left {
    flex: 1;
    min-width: 0;
}

.global-search-form {
    flex: 1;
    max-width: 720px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.global-search-form input {
    min-height: 36px;
    border-radius: 999px;
    padding-left: 15px;
    background: #fff;
}

.global-search-form button {
    min-height: 36px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--white);
    color: var(--ink);
    font-size: 12.5px;
    font-weight: 700;
    cursor: pointer;
}

.search-page-form {
    display: flex;
    gap: 10px;
    align-items: center;
}

.search-page-form input {
    flex: 1;
}

.search-results-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

@media (max-width: 1000px) {
    .global-search-form {
        max-width: none;
    }

    .search-results-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .sidebar,
    .topbar-card {
        position: static;
        height: auto;
    }

    .global-search-form,
    .search-page-form {
        display: block;
    }

    .global-search-form button,
    .search-page-form button {
        margin-top: 8px;
        width: 100%;
    }
}


/* Inline field editing */
.inline-editable {
    cursor: pointer;
    border-radius: 7px;
    padding: 2px 4px;
    margin: -2px -4px;
    transition: background .15s ease, box-shadow .15s ease;
}

.inline-editable:hover {
    background: var(--orange-soft);
    box-shadow: inset 0 0 0 1px rgba(244,157,11,0.18);
}

.inline-edit-form {
    display: flex;
    gap: 6px;
    align-items: flex-start;
}

.inline-edit-form input,
.inline-edit-form select,
.inline-edit-form textarea {
    min-height: 32px;
    padding: 6px 8px;
    font-size: 13px;
}

.inline-edit-form textarea {
    min-height: 70px;
}

.inline-save-btn,
.inline-cancel-btn {
    min-height: 32px;
    border-radius: 8px;
    border: 1px solid var(--border);
    padding: 5px 8px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
}

.inline-save-btn {
    background: var(--orange);
    color: #fff;
    border-color: var(--orange);
}

.inline-cancel-btn {
    background: #fff;
    color: var(--ink);
}


/* Visual vertical timeline */
.visual-timeline {
    position: relative;
    padding: 4px 0 4px 0;
}

.visual-timeline::before {
    content: "";
    position: absolute;
    left: 9px;
    top: 12px;
    bottom: 12px;
    width: 2px;
    background: var(--line);
}

.visual-timeline-item {
    position: relative;
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 10px;
    padding: 8px 0;
    color: inherit;
}

.visual-timeline-marker {
    width: 20px;
    height: 20px;
    border-radius: 999px;
    background: #EEF1F5;
    border: 4px solid #fff;
    box-shadow: 0 0 0 1px var(--border);
    z-index: 1;
    margin-top: 3px;
}

.visual-timeline-marker.note {
    background: var(--orange);
    box-shadow: 0 0 0 1px rgba(244,157,11,.35), 0 0 0 5px var(--orange-soft);
}

.visual-timeline-marker.task {
    background: #4B78B7;
    box-shadow: 0 0 0 1px rgba(75,120,183,.35), 0 0 0 5px #EDF4FF;
}

.visual-timeline-content {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px 12px;
    background: #fff;
    transition: background .15s ease, border-color .15s ease;
}

.visual-timeline-item:hover .visual-timeline-content {
    background: #FCFAF7;
    border-color: var(--border);
}

.visual-timeline-top {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 3px;
}

.visual-timeline-type {
    color: var(--orange-dark);
    text-transform: uppercase;
    letter-spacing: .06em;
    font-size: 10.5px;
    font-weight: 800;
}

.visual-timeline-date {
    color: var(--muted);
    font-size: 12px;
    white-space: nowrap;
}

.visual-timeline-title {
    font-weight: 700;
    font-size: 13.5px;
    color: var(--ink);
}

.visual-timeline-meta {
    margin-top: 2px;
    color: var(--muted);
    font-size: 12.5px;
}

.timeline-list {
    display: none;
}


/* Global live search suggestions */
.global-search-form {
    position: relative;
}

.global-search-suggestions {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 8px);
    z-index: 250;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 18px 42px rgba(18, 18, 18, 0.14);
    overflow: hidden;
    max-height: 460px;
    overflow-y: auto;
}

.search-suggestion-item {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 10px;
    padding: 11px 13px;
    border-bottom: 1px solid var(--line);
    align-items: start;
}

.search-suggestion-item:hover {
    background: #FCFAF7;
}

.search-suggestion-type {
    font-size: 10.5px;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--orange-dark);
}

.search-suggestion-main {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.search-suggestion-main strong {
    font-size: 13.5px;
    color: var(--ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-suggestion-main small {
    font-size: 12.5px;
    color: var(--muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-suggestion-footer,
.search-suggestion-empty {
    display: block;
    padding: 11px 13px;
    font-size: 13px;
    color: var(--ink-soft);
    background: #FCFAF7;
}

.search-suggestion-footer {
    font-weight: 700;
    color: var(--orange-dark);
}

@media (max-width: 900px) {
    .global-search-suggestions {
        position: static;
        margin-top: 8px;
    }

    .search-suggestion-item {
        grid-template-columns: 1fr;
        gap: 3px;
    }
}


/* Refinements: inline edit focus/cancel, field masks, PII reveal */
.inline-edit-form input:focus,
.inline-edit-form select:focus,
.inline-edit-form textarea:focus {
    box-shadow: none;
    outline: 2px solid rgba(244,157,11,0.42);
    outline-offset: 1px;
}

.inline-edit-form {
    position: relative;
    z-index: 1;
}

.sensitive-field {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    border-radius: 7px;
    padding: 2px 4px;
    margin: -2px -4px;
}

.sensitive-field:hover {
    background: var(--orange-soft);
    box-shadow: inset 0 0 0 1px rgba(244,157,11,0.18);
}

.sensitive-value {
    min-width: 72px;
}

.sensitive-toggle {
    width: 26px;
    height: 26px;
    border: 1px solid var(--border);
    background: #fff;
    color: var(--ink-soft);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.sensitive-toggle:hover {
    color: var(--orange-dark);
    background: var(--orange-soft);
}

.sensitive-field .inline-edit-form {
    min-width: 260px;
}


/* Brand subtitle under advisorIQ logo */
.brand-subtitle {
    margin-top: 6px;
    width: 100%;
    text-align: center;
    color: var(--charcoal);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.24em;
    line-height: 1;
    text-transform: lowercase;
    opacity: 0.95;
}

/* Fix inline-edit orange edge/glow while hovering Save/Cancel */
.inline-editable.is-editing,
.inline-editable.is-editing:hover,
.sensitive-field.is-editing,
.sensitive-field.is-editing:hover {
    background: transparent !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.inline-editable.is-editing {
    display: block;
}

.inline-editable.is-editing .inline-edit-form {
    width: 100%;
}

.inline-editable.is-editing .inline-edit-form input,
.inline-editable.is-editing .inline-edit-form select,
.inline-editable.is-editing .inline-edit-form textarea {
    width: min(320px, 100%);
}

.inline-edit-form button {
    flex: 0 0 auto;
}


/* Final logo subtitle styling */
.brand-subtitle {
    text-align: center !important;
    color: var(--charcoal) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: 0.02em !important;
    text-transform: lowercase !important;
    line-height: 1 !important;
    margin-top: 6px !important;
}


/* Compact record detail headers */
.compact-record-header {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    min-height: auto;
    padding: 2px 0 6px;
    margin: 0 0 12px;
}

.compact-record-header .page-header-left {
    display: none !important;
}

.compact-record-header .page-header-right {
    margin-left: auto;
    display: flex;
    gap: 10px;
    align-items: center;
}

.record-shell > .compact-record-header + .profile-card,
.record-shell > .compact-record-header + .card {
    margin-top: 0;
}


/* Final logo subtitle: spaced lowercase */
.brand-subtitle {
    width: 100% !important;
    text-align: center !important;
    color: var(--charcoal) !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    letter-spacing: 0.08em !important;
    text-transform: lowercase !important;
    line-height: 1 !important;
    margin-top: 6px !important;
}


/* Filters and saved views */
.filters-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.6fr) minmax(160px, .8fr) minmax(160px, .8fr) auto;
    gap: 12px;
    align-items: end;
}

.filter-actions {
    display: flex;
    gap: 8px;
}

.saved-view-row {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    display: flex;
    gap: 14px;
    align-items: center;
    flex-wrap: wrap;
}

.saved-view-form {
    display: flex;
    gap: 8px;
    align-items: center;
}

.saved-view-form input {
    min-width: 220px;
}

.saved-view-links {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.saved-view-links a {
    padding: 6px 9px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: #fff;
    color: var(--ink-soft);
    font-size: 12.5px;
    font-weight: 700;
}

@media (max-width: 1000px) {
    .filters-grid,
    .saved-view-row,
    .saved-view-form {
        display: block;
    }

    .filter-actions,
    .saved-view-form {
        margin-top: 10px;
    }
}


/* Customize cards */
.quick-link-card {
    display: block;
    padding: 22px 22px 20px;
    border-radius: 18px;
    transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease, background .14s ease;
}
.quick-link-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 30px rgba(18,18,18,0.06);
    background: #FCFAF7;
}
.quick-link-title {
    font-size: 18px;
    font-weight: 800;
    color: var(--ink);
    margin-bottom: 8px;
}
.quick-link-text {
    font-size: 13.5px;
    color: var(--muted);
    line-height: 1.55;
}

/* Better filter toolbar */
.filter-toolbar-card {
    padding: 18px;
}
.filter-toolbar {
    display: grid;
    grid-template-columns: minmax(250px, 1.7fr) minmax(170px, .8fr) minmax(170px, .8fr) auto;
    gap: 12px;
    align-items: end;
}
.filter-item {
    min-width: 0;
}
.filter-item-search {
    min-width: 0;
}
.filter-item label,
.saved-view-inline-form label {
    display: block;
    margin: 0 0 6px;
    font-size: 11px;
    letter-spacing: .06em;
    text-transform: uppercase;
    font-weight: 800;
    color: var(--muted);
}
.filter-toolbar-actions {
    display: flex;
    gap: 8px;
    align-items: flex-end;
    justify-content: flex-end;
}
.saved-view-bar {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.saved-view-inline-form {
    display: flex;
    gap: 8px;
    align-items: center;
}
.saved-view-inline-form input {
    max-width: 280px;
}
.saved-view-pill-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.saved-view-pill {
    padding: 7px 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--border);
    color: var(--ink-soft);
    font-size: 12.5px;
    font-weight: 700;
    transition: background .14s ease, border-color .14s ease, color .14s ease;
}
.saved-view-pill:hover {
    background: #FCFAF7;
    border-color: rgba(244,157,11,.35);
}
.saved-view-pill.active {
    background: var(--orange-soft);
    border-color: rgba(244,157,11,.35);
    color: var(--orange-dark);
}
.compact-toolbar .filter-toolbar {
    grid-template-columns: minmax(250px, 1fr) auto;
}

@media (max-width: 1024px) {
    .filter-toolbar,
    .compact-toolbar .filter-toolbar {
        grid-template-columns: 1fr;
    }
    .filter-toolbar-actions,
    .saved-view-inline-form {
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}


/* Softer admin/customize cards */
.quick-link-card {
    padding: 20px 22px;
}
.quick-link-title {
    font-size: 15px !important;
    line-height: 1.25;
    font-weight: 700 !important;
    letter-spacing: -0.005em;
    color: var(--ink);
    margin-bottom: 8px;
}
.quick-link-text {
    font-size: 13px;
    line-height: 1.45;
    color: var(--muted);
}

/* Advanced filters hidden by default */
.advanced-filter-card {
    padding: 16px;
}
.advanced-filter-card.is-hidden {
    display: none;
}
.advanced-filter-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    padding-bottom: 13px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 13px;
}
.advanced-filter-header h2 {
    font-size: 15px;
    font-weight: 700;
}
.advanced-filter-header p {
    margin: 4px 0 0;
}
.advanced-filter-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.filter-builder-rows {
    display: flex;
    flex-direction: column;
    gap: 9px;
}
.filter-builder-row {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(150px, .75fr) minmax(180px, 1fr) auto;
    gap: 9px;
    align-items: center;
}
.filter-builder-row select,
.filter-builder-row input {
    min-height: 36px;
}
.remove-filter-row {
    min-height: 36px;
    border: 1px solid var(--border);
    border-radius: 9px;
    background: #fff;
    color: var(--ink-soft);
    font-size: 12.5px;
    font-weight: 700;
    padding: 7px 10px;
    cursor: pointer;
}
.remove-filter-row:hover {
    background: #FCFAF7;
}
.saved-view-bar {
    margin-top: 14px;
    padding-top: 14px;
}
.saved-view-inline-form {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}
.saved-view-inline-form input {
    max-width: 280px;
}
.saved-view-pill-row {
    margin-top: 10px;
}

@media (max-width: 1050px) {
    .advanced-filter-header,
    .filter-builder-row {
        display: block;
    }
    .advanced-filter-actions,
    .filter-builder-row > * {
        margin-top: 8px;
        width: 100%;
    }
}


/* Permissions / impersonation */
.impersonation-banner {
    margin: 0 0 14px;
    padding: 10px 14px;
    border: 1px solid rgba(244,157,11,.35);
    background: var(--orange-soft);
    color: var(--ink);
    border-radius: 12px;
    font-size: 13px;
    font-weight: 700;
}
.impersonation-banner a {
    margin-left: 10px;
    color: var(--orange-dark);
    text-decoration: underline;
}
.check-row {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-right: 16px;
    font-weight: 700;
}
.check-row input,
td input[type="checkbox"] {
    width: auto;
    min-height: auto;
}


/* Compact inner cards for contact/address blocks */
.mini-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 14px 16px;
    background: #fff;
}
.address-block {
    line-height: 1.7;
}


/* Topbar should cover scrolled content cleanly */
.topbar-card {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: #fff !important;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 10px 22px rgba(22, 24, 29, 0.08);
}

.main {
    padding-top: 10px;
}

/* User dropdown */
.user-menu-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.user-menu {
    border: 0;
    background: transparent;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--ink);
    font-weight: 600;
    font-size: 13px;
    padding: 3px 4px;
    border-radius: 12px;
}

.user-menu:hover,
.user-menu[aria-expanded="true"] {
    background: #F7F4EF;
}

.user-dropdown {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: 220px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 18px 42px rgba(22, 24, 29, 0.14);
    padding: 8px;
    z-index: 2000;
}

.user-dropdown-header {
    padding: 9px 10px 10px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 6px;
}

.user-dropdown-header strong,
.user-dropdown-header span {
    display: block;
}

.user-dropdown-header span {
    color: var(--muted);
    font-size: 12px;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-dropdown a {
    display: block;
    padding: 9px 10px;
    border-radius: 10px;
    color: var(--ink-soft);
    font-size: 13px;
    font-weight: 700;
}

.user-dropdown a:hover {
    background: var(--orange-soft);
    color: var(--ink);
}


/* Collapsible relationship add panels */
.relationship-add-panels {
    margin-top: 12px;
}
.relationship-add-panels:empty {
    display: none;
}
.collapsible-panel[hidden] {
    display: none !important;
}
.collapsible-panel .detail-header {
    margin-bottom: 10px;
}


/* Record ownership and split activity timeline */
.record-meta-section {
    margin-top: 16px;
}

.activity-split-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
    gap: 18px;
    align-items: start;
}

.audit-timeline {
    position: relative;
    display: grid;
    gap: 12px;
}

.audit-item {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
}

.audit-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--orange);
    margin-top: 5px;
    box-shadow: 0 0 0 4px var(--orange-soft);
}

.audit-content {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px 12px;
    background: #fff;
}

.audit-change {
    display: flex;
    gap: 7px;
    align-items: center;
    flex-wrap: wrap;
    margin: 6px 0;
    color: var(--ink-soft);
    font-size: 12px;
}

.audit-change span:first-child,
.audit-change span:last-child {
    background: #F7F4EF;
    border-radius: 8px;
    padding: 3px 6px;
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.empty-state.compact {
    padding: 14px;
    min-height: auto;
}

@media (max-width: 1000px) {
    .activity-split-grid {
        grid-template-columns: 1fr;
    }
}


/* Signup */
.signup-card {
    max-width: 560px;
}
.signup-card .form-grid {
    gap: 12px;
}


/* Usage / overage banner */
.usage-banner {
    background: #FFF3E1;
    border: 1px solid rgba(244,157,11,0.35);
    color: var(--ink);
    border-radius: 14px;
    padding: 10px 14px;
    margin-bottom: 12px;
    box-shadow: var(--shadow-soft);
    font-size: 13px;
}


/* Reference CRM record layout */
body {
    background: #FAFAF9;
}

.sidebar {
    width: 248px;
    background: #fff;
    padding: 30px 16px 18px;
    border-right: 1px solid #ECEFF3;
}

.brand {
    text-align: center;
    padding: 0 8px 36px;
}

.brand img {
    width: 162px;
    margin: 0 auto;
}

.brand-subtitle {
    width: 100% !important;
    text-align: center !important;
    color: var(--charcoal) !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    letter-spacing: 0.32em !important;
    text-transform: lowercase !important;
    line-height: 1 !important;
    margin-top: 10px !important;
}

.nav {
    gap: 10px;
}

.nav-link {
    min-height: 50px;
    padding: 13px 14px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 760;
    color: #2E3A4F;
}

.nav-link.active {
    background: #FFF0DA;
    color: var(--orange-dark);
    box-shadow: inset 0 0 0 1px rgba(244,157,11,0.24);
}

.nav-icon {
    width: 19px;
    height: 19px;
}

.main {
    padding: 0;
    background: #FAFAF9;
}

.topbar-card {
    min-height: 70px;
    border-radius: 0;
    border: 0;
    border-bottom: 1px solid #ECEFF3;
    box-shadow: none;
    margin: 0;
    padding: 12px 34px;
    background: #fff !important;
}

.topbar-left {
    flex: 1;
}

.firm-chip {
    display: none;
}

.global-search-form {
    width: 560px;
    max-width: 60vw;
}

.global-search-form input {
    height: 46px;
    border-radius: 12px;
    background: #fff;
    border-color: #DCE2EA;
    box-shadow: 0 2px 8px rgba(28, 35, 49, 0.035);
}

.global-search-form button {
    display: none;
}

.icon-button {
    position: relative;
    border: 0;
    color: #233048;
    font-weight: 800;
}



.record-shell.crm-record-page {
    max-width: 980px;
    margin: 0 auto;
    padding: 34px 0 44px;
}

.crm-record-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 22px;
}

.crm-record-actions-right {
    display: flex;
    gap: 10px;
}

.crm-back-btn {
    gap: 8px;
}



.crm-card {
    background: #fff;
    border: 1px solid #E1E5EA;
    border-radius: 14px;
    box-shadow: 0 2px 9px rgba(31, 42, 68, 0.08);
}

.crm-profile-card {
    padding: 28px 30px;
}

.crm-profile-grid {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr) 238px;
    gap: 30px;
    align-items: start;
}

.crm-person-avatar {
    width: 132px;
    height: 132px;
    border-radius: 999px;
    background: linear-gradient(135deg, #F2F4F7, #E4E8EE);
    color: #9AA4B2;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 38px;
    font-weight: 900;
    border: 1px solid #E3E7ED;
}

.crm-record-name {
    margin: 10px 0 2px;
    font-size: 30px;
    letter-spacing: -0.04em;
    line-height: 1.08;
    font-weight: 850;
    color: #172033;
}

.crm-record-type {
    color: #425066;
    font-size: 16px;
    margin-top: 4px;
}

.crm-status-row {
    margin-top: 12px;
}

.crm-status-row .badge,
.crm-related-person em {
    background: #DDF5DF;
    color: #218637;
    border: 0;
}

.crm-contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 26px 46px;
    margin-top: 34px;
}

.crm-info-line {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 13px;
    align-items: start;
}

.crm-info-icon {
    color: #536076;
    margin-top: 2px;
}

.crm-info-label {
    color: #344055;
    font-size: 12px;
    font-weight: 850;
    margin-bottom: 6px;
}

.crm-info-value {
    color: #2C374B;
    font-size: 13px;
    line-height: 1.5;
    font-weight: 500;
}

.crm-link,
.crm-info-value.crm-link,
.crm-info-value .crm-link {
    color: #0B5FCC;
    font-weight: 700;
}

.crm-record-meta {
    border-left: 1px solid #E1E5EA;
    padding-left: 34px;
    margin-top: 138px;
    display: grid;
    gap: 18px;
}

.crm-meta-user {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #2C374B;
    font-size: 13px;
    font-weight: 650;
}

.crm-mini-avatar {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: #ECEFF3;
    color: #516071;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 900;
}

.crm-section-card {
    margin-top: 20px;
    padding: 18px 22px;
}

.crm-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}

.crm-section-title-wrap {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}

.crm-section-title-wrap h2 {
    font-size: 18px;
    letter-spacing: -0.02em;
    color: #172033;
}

.crm-section-icon {
    color: var(--orange);
}

.crm-count-pill {
    min-width: 24px;
    height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: #EEF0F3;
    color: #5F6B7B;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 850;
}

.crm-relationship-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}

.crm-related-person {
    min-height: 76px;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 10px 18px;
    border-right: 1px solid #E5E8ED;
}

.crm-related-person:last-child {
    border-right: 0;
}

.crm-related-avatar {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    background: #ECEFF3;
    color: #475467;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 850;
}

.crm-related-person strong,
.crm-preview-item strong {
    display: block;
    color: #273247;
    font-size: 13px;
    margin-bottom: 3px;
}

.crm-related-person small,
.crm-preview-item span,
.crm-preview-item small {
    display: block;
    color: #667085;
    font-size: 12px;
    line-height: 1.4;
}

.crm-related-person em {
    display: inline-flex;
    margin-top: 6px;
    font-style: normal;
    font-size: 10px;
    font-weight: 900;
    padding: 3px 8px;
    border-radius: 999px;
}

.crm-two-preview {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}

.crm-preview-item {
    padding: 12px 22px;
    min-height: 76px;
    border-right: 1px solid #E5E8ED;
}

.crm-preview-item:last-child {
    border-right: 0;
}

.crm-task-preview .crm-preview-item strong {
    display: flex;
    align-items: center;
    gap: 10px;
}

.crm-task-circle {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 1.7px solid #AEB7C4;
    display: inline-block;
}

.crm-record-page > .card,
.crm-record-page .content-grid {
    display: none;
}

.activity-split-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}

.activity-split-grid > div {
    padding: 6px 22px 14px;
}

.activity-split-grid > div:first-child {
    border-right: 1px solid #E5E8ED;
}

.audit-timeline,
.timeline-list,
.visual-timeline {
    box-shadow: none !important;
}

.audit-content,
.timeline-content,
.visual-timeline-item {
    border: 0 !important;
    box-shadow: none !important;
    padding-top: 5px !important;
    padding-bottom: 8px !important;
}

.audit-dot {
    background: #98A2B3 !important;
    box-shadow: none !important;
}

.timeline-dot,
.visual-timeline-dot {
    background: var(--orange) !important;
}

@media (max-width: 1180px) {
    .record-shell.crm-record-page {
        max-width: calc(100vw - 300px);
    }
    .crm-profile-grid {
        grid-template-columns: 120px 1fr;
    }
    .crm-record-meta {
        grid-column: 1 / -1;
        margin-top: 12px;
        padding-left: 0;
        border-left: 0;
        border-top: 1px solid #E1E5EA;
        padding-top: 16px;
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .sidebar {
        width: 218px;
    }
    .record-shell.crm-record-page {
        max-width: calc(100vw - 250px);
        padding-left: 14px;
        padding-right: 14px;
    }
    .crm-profile-grid,
    .crm-contact-grid,
    .crm-relationship-row,
    .crm-two-preview,
    .activity-split-grid {
        grid-template-columns: 1fr;
    }
    .crm-related-person,
    .crm-preview-item,
    .activity-split-grid > div:first-child {
        border-right: 0;
        border-bottom: 1px solid #E5E8ED;
    }
}


/* Person page layout correction - closer to the approved reference */
:root {
    --app-bg-soft: #FBFBFA;
    --app-border-soft: #E6EAF0;
    --app-text-main: #172033;
    --app-text-soft: #4A5568;
}

body {
    background: var(--app-bg-soft) !important;
    font-weight: 400 !important;
}

.sidebar {
    width: 248px !important;
    background: #fff !important;
    border-right: 1px solid var(--app-border-soft) !important;
    padding: 26px 16px 18px !important;
}

.brand {
    padding: 0 8px 34px !important;
}

.brand img {
    width: 166px !important;
    margin: 0 auto !important;
}

.nav {
    gap: 8px !important;
}

.nav-link {
    min-height: 50px !important;
    padding: 13px 14px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #2E3A4F !important;
}

.nav-link span {
    font-weight: 600 !important;
}

.nav-link.active {
    background: #FFF0DA !important;
    color: var(--orange-dark) !important;
    box-shadow: inset 0 0 0 1px rgba(244,157,11,0.24) !important;
}

.nav-link.active span {
    color: var(--orange-dark) !important;
}

.nav-icon {
    width: 18px !important;
    height: 18px !important;
}

.main {
    background: var(--app-bg-soft) !important;
    padding: 0 !important;
}

.topbar-card {
    height: 70px !important;
    min-height: 70px !important;
    padding: 12px 34px !important;
    border-radius: 0 !important;
    border: 0 !important;
    border-bottom: 1px solid var(--app-border-soft) !important;
    box-shadow: none !important;
    margin: 0 !important;
}

.global-search-form {
    width: min(760px, 62vw) !important;
}

.global-search-form input {
    height: 46px !important;
    border-radius: 13px !important;
    border: 1px solid #D9E0EA !important;
    box-shadow: 0 2px 8px rgba(28,35,49,0.035) !important;
    color: #3B4658 !important;
}

.user-menu,
.user-menu span,
.user-name {
    font-weight: 600 !important;
    color: #172033 !important;
}

/* IMPORTANT: left-align the record area instead of centering it and creating a huge blank gap */
.record-shell.crm-record-page {
    width: auto !important;
    max-width: 1280px !important;
    margin: 0 34px !important;
    padding: 34px 0 44px !important;
}

.crm-record-actions {
    margin-bottom: 22px !important;
}

.btn {
    font-weight: 600 !important;
    border-radius: 12px !important;
}

.btn-primary {
    background: #F28C00 !important;
    border-color: #F28C00 !important;
}

/* Main profile card */
.crm-card {
    border: 1px solid #E1E6ED !important;
    border-radius: 14px !important;
    box-shadow: 0 2px 8px rgba(31,42,68,0.07) !important;
}

.crm-profile-card {
    padding: 24px 28px !important;
}

.crm-profile-grid {
    grid-template-columns: 128px minmax(520px, 1fr) 265px !important;
    gap: 28px !important;
    align-items: start !important;
}

.crm-person-avatar {
    width: 110px !important;
    height: 110px !important;
    font-size: 34px !important;
    font-weight: 700 !important;
    color: #8A94A6 !important;
    background: #ECEFF3 !important;
    border: 1px solid #E1E6ED !important;
    margin-left: 0 !important;
}

.crm-record-name {
    margin: 4px 0 2px !important;
    font-size: 27px !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    color: var(--app-text-main) !important;
}

.crm-record-name span {
    font-weight: 700 !important;
}

.crm-record-type {
    font-size: 15px !important;
    font-weight: 400 !important;
    color: #344055 !important;
}

.crm-status-row {
    margin-top: 10px !important;
}

.badge,
.crm-status-row .badge,
.crm-related-person em {
    font-weight: 650 !important;
    font-size: 11px !important;
    padding: 4px 10px !important;
    border-radius: 999px !important;
    background: #DFF5E2 !important;
    color: #207A35 !important;
}

.crm-contact-grid {
    margin-top: 28px !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr) !important;
    gap: 24px 44px !important;
}

.crm-info-line {
    grid-template-columns: 22px minmax(0, 1fr) !important;
    gap: 12px !important;
}

.crm-info-label {
    font-size: 11.5px !important;
    font-weight: 650 !important;
    color: #303B4E !important;
    margin-bottom: 5px !important;
}

.crm-info-value {
    font-size: 13px !important;
    font-weight: 400 !important;
    color: #2C374B !important;
}

.crm-link,
.crm-info-value.crm-link,
.crm-info-value .crm-link {
    color: #0B63D1 !important;
    font-weight: 600 !important;
}

.crm-record-meta {
    margin-top: 104px !important;
    padding-left: 28px !important;
    border-left: 1px solid #E1E6ED !important;
    gap: 17px !important;
}

.crm-meta-user {
    font-size: 13px !important;
    font-weight: 400 !important;
}

.crm-mini-avatar {
    width: 28px !important;
    height: 28px !important;
    font-size: 11px !important;
    font-weight: 650 !important;
}

/* Section cards */
.crm-section-card {
    margin-top: 18px !important;
    padding: 17px 20px !important;
}

.crm-section-title-wrap {
    gap: 11px !important;
}

.crm-section-title-wrap h2 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--app-text-main) !important;
}

.crm-count-pill {
    min-width: 24px !important;
    height: 22px !important;
    font-size: 12px !important;
    font-weight: 650 !important;
    background: #EEF1F5 !important;
    color: #667085 !important;
}

.crm-relationship-row {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    min-height: 72px !important;
}

.crm-related-person {
    padding: 8px 18px !important;
    min-height: 70px !important;
}

.crm-related-person strong,
.crm-preview-item strong {
    font-size: 13px !important;
    font-weight: 650 !important;
    color: #273247 !important;
}

.crm-related-person small,
.crm-preview-item span,
.crm-preview-item small {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: #667085 !important;
}

.crm-related-avatar {
    width: 40px !important;
    height: 40px !important;
    font-weight: 650 !important;
}

.crm-two-preview {
    min-height: 66px !important;
}

.crm-preview-item {
    padding: 10px 20px !important;
    min-height: 66px !important;
}

.crm-task-circle {
    width: 18px !important;
    height: 18px !important;
}

/* Split lower timeline */
.activity-split-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 0 !important;
}

.activity-split-grid > div {
    padding: 6px 20px 14px !important;
}

.profile-section-title {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #172033 !important;
}

.audit-content,
.timeline-content,
.visual-timeline-item {
    font-size: 12.5px !important;
}

.audit-content strong,
.timeline-content strong,
.visual-timeline-item strong {
    font-weight: 650 !important;
}

/* Keep form panels hidden unless opened; avoid the old chunky relationship form look */
.relationship-add-panels {
    margin-top: 10px !important;
}
.collapsible-panel[hidden] {
    display: none !important;
}

/* Do not hide non-person detail pages globally */
.crm-record-page > .card,
.crm-record-page .content-grid {
    display: none;
}

@media (max-width: 1280px) {
    .record-shell.crm-record-page {
        margin: 0 24px !important;
        max-width: calc(100vw - 296px) !important;
    }
    .crm-profile-grid {
        grid-template-columns: 110px minmax(430px, 1fr) 240px !important;
        gap: 22px !important;
    }
}


/* FINAL person-record information order correction */
.record-shell.crm-record-page {
    max-width: 1280px !important;
    margin: 0 34px !important;
}

/* The previous mockup pass hid generic .card sections. The activity timeline uses a section too, so force it visible. */
.crm-record-page > .crm-card,
.crm-record-page > .crm-activity-card,
.crm-record-page .crm-notes-tasks-grid {
    display: block !important;
}

.crm-record-page > .card:not(.crm-card) {
    display: none !important;
}

/* Better advisor information order:
   1 profile/contact/owner
   2 relationships
   3 notes + tasks side-by-side
   4 client interactions + record updates */
.crm-notes-tasks-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 20px;
    margin-top: 20px;
}

.crm-notes-tasks-grid .crm-section-card {
    margin-top: 0 !important;
    min-height: 150px;
}

.crm-notes-tasks-grid .crm-two-preview {
    grid-template-columns: 1fr !important;
}

.crm-notes-tasks-grid .crm-preview-item {
    border-right: 0 !important;
    border-bottom: 1px solid #E5E8ED;
}

.crm-notes-tasks-grid .crm-preview-item:last-child {
    border-bottom: 0;
}

.crm-activity-card {
    margin-top: 20px !important;
    padding: 0 !important;
    overflow: hidden;
}

.crm-activity-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
}

.crm-activity-panel {
    padding: 18px 22px 20px;
}

.crm-activity-panel:first-child {
    border-right: 1px solid #E5E8ED;
}

.crm-activity-panel .crm-section-header {
    margin-bottom: 16px;
}

.crm-activity-panel .crm-section-title-wrap h2 {
    font-size: 18px !important;
    font-weight: 700 !important;
}

.crm-activity-panel .btn {
    padding: 7px 12px !important;
    font-size: 12px !important;
}

.crm-activity-panel .visual-timeline,
.crm-activity-panel .audit-timeline {
    display: grid;
    gap: 12px;
}

.crm-activity-panel .audit-item {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 10px;
}

.crm-activity-panel .audit-content {
    border: 0 !important;
    padding: 2px 0 10px !important;
}

.crm-activity-panel .audit-content strong {
    display: block;
    font-size: 13px;
    color: #273247;
    margin-bottom: 3px;
}

.crm-activity-panel .audit-content .subtle {
    font-size: 12px;
}

.crm-activity-panel .audit-dot {
    width: 8px !important;
    height: 8px !important;
    margin-top: 6px !important;
    background: #98A2B3 !important;
}

.crm-activity-panel:first-child .visual-timeline-dot,
.crm-activity-panel:first-child .timeline-dot {
    background: var(--orange) !important;
}

.crm-activity-card .empty-state.compact {
    padding: 10px 0 !important;
}

@media (max-width: 1000px) {
    .crm-notes-tasks-grid,
    .crm-activity-grid {
        grid-template-columns: 1fr !important;
    }

    .crm-activity-panel:first-child {
        border-right: 0;
        border-bottom: 1px solid #E5E8ED;
    }
}


/* =========================================================
   EXACT crmIQ Essentials person page layout
   This final layer overrides the earlier experimental layout.
   ========================================================= */

body {
    background: #FBFBFA !important;
    color: #172033 !important;
    font-weight: 400 !important;
}

.app-shell {
    background: #FBFBFA !important;
}

.sidebar {
    width: 248px !important;
    background: #fff !important;
    border-right: 1px solid #E6EAF0 !important;
    padding: 28px 16px 18px !important;
}

.brand {
    text-align: center !important;
    padding: 0 8px 34px !important;
}

.brand img {
    width: 166px !important;
    margin: 0 auto !important;
}

.brand-subtitle {
    text-align: center !important;
    color: #4F5663 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.42em !important;
    margin-top: 11px !important;
}

.nav {
    gap: 8px !important;
}

.nav-link {
    min-height: 50px !important;
    padding: 13px 14px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 560 !important;
    color: #2C374B !important;
}

.nav-link span {
    font-weight: 560 !important;
}

.nav-link.active {
    background: #FFF0DA !important;
    color: #D98200 !important;
    box-shadow: inset 0 0 0 1px rgba(244,157,11,0.24) !important;
}

.nav-link.active span,
.nav-link.active svg {
    color: #D98200 !important;
}

.nav-icon {
    width: 18px !important;
    height: 18px !important;
}

.main {
    background: #FBFBFA !important;
    padding: 0 !important;
    min-width: 0 !important;
}

.topbar-card {
    height: 70px !important;
    min-height: 70px !important;
    margin: 0 !important;
    padding: 12px 34px !important;
    border: 0 !important;
    border-bottom: 1px solid #E6EAF0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #fff !important;
}

.firm-chip {
    display: none !important;
}

.global-search-form {
    width: min(760px, 62vw) !important;
}

.global-search-form input {
    height: 46px !important;
    border-radius: 13px !important;
    border: 1px solid #D9E0EA !important;
    background: #fff !important;
    box-shadow: 0 2px 8px rgba(28,35,49,0.035) !important;
    color: #364153 !important;
}

.global-search-form button {
    display: none !important;
}

.user-menu,
.user-menu span,
.user-name {
    font-weight: 560 !important;
    color: #172033 !important;
}

.aiq-person-page {
    max-width: 1280px !important;
    margin: 0 34px !important;
    padding: 32px 0 44px !important;
}

.aiq-action-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 20px !important;
}

.aiq-action-right {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
}

.aiq-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    border-radius: 12px !important;
    padding: 9px 14px !important;
    border: 1px solid #DCE2EA !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    background: #fff !important;
    color: #273247 !important;
    text-decoration: none !important;
}

.aiq-btn-orange {
    background: #F28C00 !important;
    border-color: #F28C00 !important;
    color: #fff !important;
}

.aiq-btn-orange svg,
.aiq-btn-orange span {
    color: #fff !important;
}



.aiq-card {
    background: #fff !important;
    border: 1px solid #E1E6ED !important;
    border-radius: 14px !important;
    box-shadow: 0 2px 8px rgba(31,42,68,0.07) !important;
}

/* Profile card */
.aiq-profile-card {
    padding: 24px 28px !important;
}

.aiq-profile-layout {
    display: grid !important;
    grid-template-columns: 136px minmax(0, 1fr) 268px !important;
    gap: 28px !important;
    align-items: start !important;
}

.aiq-avatar {
    width: 112px !important;
    height: 112px !important;
    border-radius: 999px !important;
    background: #ECEFF3 !important;
    border: 1px solid #E1E6ED !important;
    color: #8A94A6 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 34px !important;
    font-weight: 700 !important;
}

.aiq-name-row h1 {
    margin: 4px 0 2px !important;
    color: #172033 !important;
    font-size: 27px !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    line-height: 1.08 !important;
}

.aiq-name-row h1 span {
    font-weight: 700 !important;
}

.aiq-client-type {
    font-size: 15px !important;
    color: #344055 !important;
    margin-top: 4px !important;
}

.aiq-badge-wrap {
    margin-top: 10px !important;
}

.aiq-badge-wrap .badge,
.aiq-related-item em {
    background: #DFF5E2 !important;
    color: #207A35 !important;
    border: 0 !important;
    font-size: 11px !important;
    font-weight: 650 !important;
    padding: 4px 10px !important;
    border-radius: 999px !important;
}

.aiq-contact-matrix {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.04fr) !important;
    gap: 24px 44px !important;
    margin-top: 28px !important;
}

.aiq-contact-item {
    display: grid !important;
    grid-template-columns: 22px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
}

.aiq-contact-icon,
.aiq-title-icon {
    color: #F28C00 !important;
}

.aiq-contact-icon {
    color: #536076 !important;
    margin-top: 2px !important;
}

.aiq-label {
    font-size: 11.5px !important;
    color: #303B4E !important;
    font-weight: 650 !important;
    margin-bottom: 5px !important;
}

.aiq-value {
    font-size: 13px !important;
    color: #2C374B !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
}

.aiq-link,
.aiq-value.aiq-link,
.aiq-value .aiq-link {
    color: #0B63D1 !important;
    font-weight: 600 !important;
}

.aiq-meta-panel {
    border-left: 1px solid #E1E6ED !important;
    padding-left: 28px !important;
    margin-top: 78px !important;
    display: grid !important;
    gap: 17px !important;
}

.aiq-meta-user {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 13px !important;
    color: #2C374B !important;
    font-weight: 400 !important;
}

.aiq-mini-avatar {
    width: 28px !important;
    height: 28px !important;
    border-radius: 999px !important;
    background: #ECEFF3 !important;
    color: #516071 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 11px !important;
    font-weight: 650 !important;
}

/* Cards below profile */
.aiq-summary-card {
    margin-top: 18px !important;
    padding: 17px 20px !important;
}

.aiq-card-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin-bottom: 14px !important;
}

.aiq-title {
    display: inline-flex !important;
    align-items: center !important;
    gap: 11px !important;
}

.aiq-title h2 {
    margin: 0 !important;
    color: #172033 !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em !important;
}

.aiq-count {
    min-width: 24px !important;
    height: 22px !important;
    padding: 0 8px !important;
    border-radius: 999px !important;
    background: #EEF1F5 !important;
    color: #667085 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 12px !important;
    font-weight: 650 !important;
}

.aiq-relationship-strip {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.aiq-related-item {
    min-height: 74px !important;
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
    padding: 8px 18px !important;
    border-right: 1px solid #E5E8ED !important;
}

.aiq-related-item:last-child {
    border-right: 0 !important;
}

.aiq-related-avatar {
    width: 42px !important;
    height: 42px !important;
    border-radius: 999px !important;
    background: #ECEFF3 !important;
    color: #475467 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 650 !important;
}

.aiq-related-item strong,
.aiq-preview-item strong {
    display: block !important;
    color: #273247 !important;
    font-size: 13px !important;
    font-weight: 650 !important;
    margin-bottom: 3px !important;
}

.aiq-related-item small,
.aiq-preview-item span,
.aiq-preview-item small {
    display: block !important;
    color: #667085 !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    line-height: 1.45 !important;
}

.aiq-related-item em {
    display: inline-flex !important;
    margin-top: 6px !important;
    font-style: normal !important;
}

.aiq-notes-tasks-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 20px !important;
    margin-top: 18px !important;
}

.aiq-notes-tasks-row .aiq-summary-card {
    margin-top: 0 !important;
    min-height: 150px !important;
}

.aiq-preview-list {
    display: grid !important;
    gap: 0 !important;
}

.aiq-preview-item {
    padding: 10px 4px !important;
    border-bottom: 1px solid #E5E8ED !important;
}

.aiq-preview-item:last-child {
    border-bottom: 0 !important;
}

.aiq-task-list .aiq-preview-item strong {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.aiq-task-dot {
    width: 18px !important;
    height: 18px !important;
    border-radius: 999px !important;
    border: 1.7px solid #AEB7C4 !important;
    display: inline-block !important;
}

/* Activity section */
.aiq-activity-card {
    margin-top: 18px !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.aiq-activity-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
}

.aiq-activity-panel {
    padding: 18px 22px 20px !important;
}

.aiq-activity-panel:first-child {
    border-right: 1px solid #E5E8ED !important;
}

.aiq-activity-panel .aiq-card-header {
    margin-bottom: 16px !important;
}

.aiq-activity-panel .aiq-btn {
    padding: 7px 12px !important;
    font-size: 12px !important;
}

.aiq-activity-panel .visual-timeline,
.aiq-activity-panel .audit-timeline {
    display: grid !important;
    gap: 12px !important;
}

.aiq-activity-panel .audit-item {
    display: grid !important;
    grid-template-columns: 18px minmax(0, 1fr) !important;
    gap: 10px !important;
}

.aiq-activity-panel .audit-content {
    border: 0 !important;
    box-shadow: none !important;
    padding: 2px 0 10px !important;
}

.aiq-activity-panel .audit-content strong {
    display: block !important;
    font-size: 13px !important;
    font-weight: 650 !important;
    color: #273247 !important;
    margin-bottom: 3px !important;
}

.aiq-activity-panel .audit-content .subtle {
    font-size: 12px !important;
}

.aiq-activity-panel .audit-dot {
    width: 8px !important;
    height: 8px !important;
    margin-top: 6px !important;
    background: #98A2B3 !important;
    box-shadow: none !important;
}

.aiq-activity-panel .visual-timeline-item,
.aiq-activity-panel .timeline-content {
    border: 0 !important;
    box-shadow: none !important;
}

.aiq-person-page > .card,
.aiq-person-page > .content-grid,
.aiq-person-page .crm-card,
.aiq-person-page .crm-notes-tasks-grid,
.aiq-person-page .crm-section-card {
    display: none !important;
}

.aiq-person-page > .aiq-card,
.aiq-person-page > .aiq-notes-tasks-row {
    display: grid !important;
}

.aiq-person-page > section.aiq-card {
    display: block !important;
}

@media (max-width: 1100px) {
    .aiq-profile-layout {
        grid-template-columns: 110px minmax(0, 1fr) !important;
    }

    .aiq-meta-panel {
        grid-column: 1 / -1 !important;
        margin-top: 12px !important;
        padding-left: 0 !important;
        border-left: 0 !important;
        border-top: 1px solid #E1E6ED !important;
        padding-top: 16px !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }

    .aiq-relationship-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 900px) {
    .aiq-person-page {
        margin: 0 18px !important;
    }

    .aiq-contact-matrix,
    .aiq-notes-tasks-row,
    .aiq-activity-grid,
    .aiq-relationship-strip {
        grid-template-columns: 1fr !important;
    }

    .aiq-related-item,
    .aiq-activity-panel:first-child {
        border-right: 0 !important;
        border-bottom: 1px solid #E5E8ED !important;
    }
}


/* Apply approved detail-page format to ALL major modules */
.aiq-company-page,
.aiq-household-page,
.aiq-business-page {
    max-width: 1280px !important;
    margin: 0 34px !important;
    padding: 32px 0 44px !important;
}

.aiq-company-page > .card,
.aiq-household-page > .card,
.aiq-business-page > .card,
.aiq-company-page > .content-grid,
.aiq-household-page > .content-grid,
.aiq-business-page > .content-grid,
.aiq-company-page .crm-card,
.aiq-household-page .crm-card,
.aiq-business-page .crm-card,
.aiq-company-page .crm-notes-tasks-grid,
.aiq-household-page .crm-notes-tasks-grid,
.aiq-business-page .crm-notes-tasks-grid,
.aiq-company-page .crm-section-card,
.aiq-household-page .crm-section-card,
.aiq-business-page .crm-section-card {
    display: none !important;
}

.aiq-company-page > .aiq-card,
.aiq-household-page > .aiq-card,
.aiq-business-page > .aiq-card,
.aiq-company-page > .aiq-notes-tasks-row,
.aiq-household-page > .aiq-notes-tasks-row,
.aiq-business-page > .aiq-notes-tasks-row {
    display: grid !important;
}

.aiq-company-page > section.aiq-card,
.aiq-household-page > section.aiq-card,
.aiq-business-page > section.aiq-card {
    display: block !important;
}

.aiq-company-page .aiq-relationship-strip,
.aiq-household-page .aiq-relationship-strip,
.aiq-business-page .aiq-relationship-strip {
    min-height: 74px;
}

.aiq-business-page .aiq-card-header .aiq-action-right {
    display: flex !important;
    gap: 8px !important;
}


/* Login registration CTA */
.login-register-panel {
    margin-top: 18px;
    padding: 14px;
    border: 1px solid var(--border);
    background: #FBFAF8;
    border-radius: 14px;
    display: flex;
    gap: 14px;
    align-items: center;
    justify-content: space-between;
}

.login-register-panel strong,
.login-register-panel span {
    display: block;
}

.login-register-panel span {
    margin-top: 3px;
    color: var(--muted);
    font-size: 13px;
}

.login-register-btn {
    white-space: nowrap;
}

/* Optional marketing site button style for crmIQ Essentials */
.advisoriq-essential-button,
.btn-advisoriq-essential {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 999px;
    padding: 12px 18px;
    background: #F49D0B;
    color: #fff !important;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(244, 157, 11, 0.22);
}

.advisoriq-essential-button:hover,
.btn-advisoriq-essential:hover {
    transform: translateY(-1px);
}


/* Clean record layout polish - tighter, less awkward, more usable */
.aiq-person-page,
.aiq-company-page,
.aiq-household-page,
.aiq-business-page {
    max-width: 1180px !important;
    margin: 0 auto !important;
    padding: 28px 28px 42px !important;
}

.aiq-profile-card {
    padding: 20px 24px !important;
}

.aiq-profile-layout {
    grid-template-columns: 116px minmax(0, 1fr) 230px !important;
    gap: 24px !important;
}

.aiq-avatar {
    width: 92px !important;
    height: 92px !important;
    font-size: 28px !important;
}

.aiq-name-row h1 {
    font-size: 24px !important;
    line-height: 1.1 !important;
}

.aiq-client-type {
    font-size: 14px !important;
}

.aiq-contact-matrix {
    margin-top: 22px !important;
    gap: 18px 34px !important;
}

.aiq-contact-item {
    grid-template-columns: 20px minmax(0, 1fr) !important;
}

.aiq-meta-panel {
    margin-top: 58px !important;
    padding-left: 22px !important;
    gap: 14px !important;
}

.aiq-summary-card {
    margin-top: 16px !important;
    padding: 16px 20px !important;
}

.aiq-relationship-strip {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    min-height: 72px !important;
}

.aiq-related-item {
    min-height: 66px !important;
    padding: 8px 14px !important;
}

.aiq-related-avatar {
    width: 38px !important;
    height: 38px !important;
}

.aiq-notes-tasks-row {
    margin-top: 16px !important;
    gap: 18px !important;
}

.aiq-notes-tasks-row .aiq-summary-card {
    min-height: 128px !important;
}

.aiq-activity-card {
    margin-top: 16px !important;
}

.aiq-activity-panel {
    padding: 16px 20px !important;
}

.login-register-panel {
    margin-top: 18px;
    padding: 14px;
    border: 1px solid var(--border);
    background: #FBFAF8;
    border-radius: 14px;
    display: flex;
    gap: 14px;
    align-items: center;
    justify-content: space-between;
}

.login-register-panel strong,
.login-register-panel span {
    display: block;
}

.login-register-panel span {
    margin-top: 3px;
    color: var(--muted);
    font-size: 13px;
}

.login-register-btn {
    white-space: nowrap;
}

@media (max-width: 1100px) {
    .aiq-person-page,
    .aiq-company-page,
    .aiq-household-page,
    .aiq-business-page {
        margin: 0 18px !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}


/* Updated advisorIQ essentials logo */
.brand {
    padding: 0 10px 10px;
}

.brand img {
    width: 186px;
    max-width: 100%;
    display: block;
    margin: 0 auto;
}

.login-logo {
    max-width: 340px !important;
    width: 100%;
    display: block;
    margin: 0 auto 18px;
}

.brand-subtitle {
    display: none !important;
}


/* Final app polish: correct logo, content breathing room, list consistency */
.main {
    padding-left: 28px !important;
    padding-right: 28px !important;
}

.topbar-card {
    margin-left: -28px !important;
    margin-right: -28px !important;
    padding-left: 36px !important;
    padding-right: 36px !important;
}

.page-header {
    margin-top: 22px !important;
    margin-bottom: 18px !important;
}

.card,
.stats-card,
.stat-card {
    max-width: 100%;
}

.dashboard-grid,
.stats-grid,
.content-grid {
    gap: 18px !important;
}

.brand {
    padding: 18px 8px 22px !important;
    min-height: 104px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.brand img {
    width: 198px !important;
    max-width: 198px !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
}

.login-logo {
    width: 300px !important;
    max-width: 86% !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
    margin: 0 auto 18px !important;
}

.login-card {
    padding-top: 34px !important;
    overflow: visible !important;
}

.brand-subtitle {
    display: none !important;
}

.filter-toolbar-card.compact-toolbar,
.advanced-filter-card {
    margin-bottom: 18px !important;
}

.advanced-filter-card.is-hidden {
    display: none !important;
}

.single-search-row {
    grid-template-columns: minmax(0, 1fr) !important;
}

.single-search-row input {
    width: 100% !important;
}

@media (max-width: 1100px) {
    .main {
        padding-left: 18px !important;
        padding-right: 18px !important;
    }

    .topbar-card {
        margin-left: -18px !important;
        margin-right: -18px !important;
    }

    .brand img {
        width: 176px !important;
        max-width: 176px !important;
    }
}


/* Consistent list view filters across modules */
.tasks-filter-row {
    grid-template-columns: 180px minmax(0, 1fr) !important;
}

.tasks-filter-row select,
.tasks-filter-row input {
    width: 100% !important;
}

.page-header-left .page-subtitle {
    margin-top: 4px;
}


/* Custom fields section on record pages */
.aiq-custom-fields-card {
    margin-top: 16px !important;
}

.aiq-custom-field-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px 24px;
}

.aiq-custom-field-item {
    min-width: 0;
}

.aiq-custom-field-item .aiq-value {
    overflow-wrap: anywhere;
}

@media (max-width: 1100px) {
    .aiq-custom-field-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .aiq-custom-field-grid {
        grid-template-columns: 1fr;
    }
}








/* Exact uploaded crmIQ Essentials logo sizing */
.brand {
    padding: 18px 8px 22px !important;
    min-height: 116px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.brand img {
    width: 132px !important;
    max-width: 132px !important;
    height: auto !important;
    object-fit: contain !important;
}

.login-logo {
    max-width: 235px !important;
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    margin: 0 auto 20px !important;
}

.brand-subtitle {
    display: none !important;
}


/* Signup verification resend panel */
.resend-code-panel {
    margin-top: 16px;
    padding: 14px;
    border: 1px solid var(--border);
    background: #FBFAF8;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.resend-code-panel strong,
.resend-code-panel span {
    display: block;
}

.resend-code-panel span {
    margin-top: 3px;
    color: var(--muted);
    font-size: 13px;
}

.resend-code-panel form {
    margin: 0;
}

.resend-code-panel .btn {
    white-space: nowrap;
}

@media (max-width: 640px) {
    .resend-code-panel {
        align-items: stretch;
        flex-direction: column;
    }

    .resend-code-panel .btn {
        width: 100%;
        justify-content: center;
    }
}


/* Billing and terms */
.billing-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 480px);
    gap: 18px;
    align-items: start;
}

.billing-stat-row,
.billing-summary {
    display: grid;
    gap: 10px;
}

.billing-stat-row > div,
.billing-summary > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
}

.billing-stat-row span,
.billing-summary span {
    color: var(--muted);
}

.billing-stat-row strong,
.billing-summary strong {
    color: var(--text);
}

.billing-summary .billing-total {
    border-bottom: 0;
    border-top: 2px solid var(--border);
    margin-top: 4px;
    padding-top: 16px;
    font-size: 18px;
}

.terms-check {
    margin: 16px 0;
    padding: 14px;
    border: 1px solid var(--border);
    background: #FBFAF8;
    border-radius: 14px;
}

.terms-check label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    line-height: 1.45;
    font-size: 14px;
    color: var(--text);
}

.terms-check input {
    width: auto;
    margin-top: 3px;
}

.public-terms-page {
    background: #f7f3ee;
    min-height: 100vh;
    padding: 36px 18px;
}

.terms-card {
    max-width: 860px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 24px;
    padding: 34px;
    box-shadow: 0 18px 44px rgba(38, 25, 18, 0.08);
}

.terms-card h1 {
    margin-top: 0;
}

.terms-card section {
    margin-top: 24px;
}

.terms-card h2 {
    font-size: 18px;
    margin-bottom: 8px;
}

@media (max-width: 900px) {
    .billing-grid {
        grid-template-columns: 1fr;
    }
}


/* Clean billing upgrade page */
.billing-upgrade-page {
    max-width: 1180px;
}

.upgrade-hero {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 22px;
    margin-bottom: 22px;
    padding: 26px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: linear-gradient(135deg, #fffaf3 0%, #ffffff 70%);
    box-shadow: 0 18px 44px rgba(38, 25, 18, 0.06);
}

.upgrade-hero .page-title {
    margin-top: 6px;
    font-size: 32px;
}

.upgrade-hero .page-subtitle {
    max-width: 780px;
    font-size: 15px;
    line-height: 1.55;
}

.upgrade-price-card {
    min-width: 210px;
    padding: 20px;
    border-radius: 20px;
    background: #111827;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
}

.upgrade-price-card span {
    font-size: 15px;
    color: rgba(255,255,255,.72);
}

.upgrade-price-card strong {
    font-size: 32px;
    line-height: 1.1;
    margin: 6px 0;
}

.upgrade-price-card small {
    color: rgba(255,255,255,.72);
}

.upgrade-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 390px;
    gap: 22px;
    align-items: start;
}

.upgrade-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 22px;
    padding: 22px;
    box-shadow: 0 14px 36px rgba(38, 25, 18, 0.05);
}

.upgrade-card-header {
    margin-bottom: 18px;
}

.upgrade-card-header h2 {
    margin: 0 0 4px;
    font-size: 19px;
}

.upgrade-card-header p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
}

.upgrade-summary-card {
    position: sticky;
    top: 18px;
}

.billing-summary.clean {
    margin: 18px 0;
}

.billing-summary.clean > div {
    padding: 12px 0;
}

.terms-check.compact {
    margin: 16px 0;
    padding: 12px;
    border-radius: 14px;
}

.terms-check.compact label {
    font-size: 12.5px;
}

.upgrade-submit {
    width: 100%;
    justify-content: center;
    min-height: 46px;
    font-weight: 700;
}

.field-help {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 12px;
}

@media (max-width: 980px) {
    .upgrade-hero,
    .upgrade-layout {
        grid-template-columns: 1fr;
        flex-direction: column;
    }

    .upgrade-summary-card {
        position: static;
    }
}


/* Friendly top upgrade banner */
.usage-banner-friendly {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin: 0 0 18px;
    border: 1px solid #E8D9C6;
    background: #FFF8EF;
    border-radius: 16px;
    padding: 14px 16px;
    color: var(--text);
    box-shadow: 0 10px 28px rgba(38, 25, 18, 0.05);
}

.usage-banner-friendly strong {
    display: block;
    font-size: 15px;
    margin-bottom: 4px;
}

.usage-banner-friendly span {
    display: block;
    color: var(--muted);
    line-height: 1.4;
}

.usage-banner-friendly .btn {
    flex: 0 0 auto;
    white-space: nowrap;
}

@media (max-width: 760px) {
    .usage-banner-friendly {
        align-items: stretch;
        flex-direction: column;
    }

    .usage-banner-friendly .btn {
        width: 100%;
        justify-content: center;
    }
}


/* Plan & Billing page */
.plan-billing-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(340px, .8fr);
    gap: 20px;
    align-items: start;
}

.plan-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 22px;
    padding: 22px;
    box-shadow: 0 14px 36px rgba(38, 25, 18, 0.05);
}

.plan-card-primary {
    grid-column: span 2;
}

.plan-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}

.plan-card h2 {
    margin: 0 0 8px;
    font-size: 20px;
}

.plan-status {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 7px 12px;
    font-weight: 700;
    font-size: 12px;
}

.plan-status.paid {
    background: #ecfdf3;
    color: #087443;
}

.plan-status.free {
    background: #fff8ef;
    color: #9a5b00;
}

.plan-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.plan-metrics > div {
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px;
    background: #fbfaf8;
}

.plan-metrics span,
.plan-detail-list span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-bottom: 6px;
}

.plan-metrics strong {
    display: block;
    font-size: 22px;
    margin-bottom: 4px;
}

.plan-metrics small {
    color: var(--muted);
}

.plan-actions {
    display: grid;
    gap: 10px;
    margin-top: 16px;
}

.plan-actions .btn,
.upgrade-secondary-link {
    width: 100%;
    justify-content: center;
}

.plan-detail-list {
    display: grid;
    gap: 12px;
}

.plan-detail-list > div {
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

.plan-detail-list > div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.plan-detail-list strong {
    word-break: break-word;
}

.alert-warning {
    background: #fff8ef;
    border: 1px solid #e8d9c6;
    color: #5f3b00;
}

@media (max-width: 980px) {
    .plan-billing-grid,
    .plan-card-primary {
        grid-template-columns: 1fr;
        grid-column: span 1;
    }

    .plan-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .plan-metrics {
        grid-template-columns: 1fr;
    }
}


/* Platform billing actions */
.platform-billing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.platform-billing-actions form {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0;
}


/* Platform subscription management */
.platform-subscription-actions {
    display: grid;
    gap: 8px;
    min-width: 360px;
}

.platform-subscription-actions form,
.inline-subscription-form {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin: 0;
}

.platform-subscription-actions label {
    font-size: 11px;
    color: var(--muted);
}

.platform-subscription-actions input[type="number"] {
    width: 74px;
}

.platform-subscription-actions input[type="date"] {
    width: 150px;
}

.platform-subscription-actions .btn {
    white-space: nowrap;
}


/* =========================================================
   MOBILE FRIENDLY LAYOUT FIX
   Keeps the menu from sitting on top of lists/forms.
   Final override layer — must stay at the bottom.
   ========================================================= */

@media (max-width: 900px) {
    html,
    body {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    .app-shell {
        display: block !important;
        width: 100% !important;
        min-height: 100vh !important;
    }

    .sidebar {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        width: 100% !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: visible !important;
        border-right: 0 !important;
        border-bottom: 1px solid #E6EAF0 !important;
        padding: 12px 12px 10px !important;
        z-index: 1 !important;
    }

    .brand {
        padding: 0 0 10px !important;
        text-align: left !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
    }

    .brand img {
        width: 128px !important;
        max-width: 128px !important;
        margin: 0 !important;
    }

    .nav {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        gap: 8px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding: 2px 0 8px !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: thin !important;
    }

    .nav-link {
        flex: 0 0 auto !important;
        white-space: nowrap !important;
        padding: 9px 11px !important;
        border-radius: 999px !important;
        font-size: 12.5px !important;
        background: #FBFAF8 !important;
        border: 1px solid #ECEFF3 !important;
    }

    .nav-link.active {
        background: #FCEBD3 !important;
        border-color: rgba(244,157,11,0.35) !important;
    }

    .sidebar-footer {
        display: none !important;
    }

    .main {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 12px !important;
        overflow: visible !important;
    }

    .topbar-card {
        position: relative !important;
        top: auto !important;
        z-index: 1 !important;
        display: block !important;
        width: 100% !important;
        margin: 0 0 12px !important;
        padding: 12px !important;
        border-radius: 16px !important;
    }

    .topbar-left,
    .topbar-right {
        display: block !important;
        width: 100% !important;
    }

    .firm-chip {
        margin-bottom: 10px !important;
    }

    .firm-chip::after {
        display: none !important;
    }

    .global-search-form {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
    }

    .global-search-form input {
        width: 100% !important;
        min-width: 0 !important;
    }

    .global-search-form button {
        width: 100% !important;
        margin-top: 8px !important;
    }

    .user-menu-wrap {
        margin-top: 10px !important;
    }

    .user-menu {
        width: 100% !important;
        justify-content: space-between !important;
    }

    .user-dropdown {
        right: 0 !important;
        left: 0 !important;
        width: 100% !important;
        min-width: 0 !important;
    }

    .page-header,
    .detail-header {
        display: block !important;
        margin: 14px 0 !important;
        padding: 0 !important;
    }

    .page-header-right,
    .profile-actions,
    .actions,
    .inline-form-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        width: 100% !important;
        margin-top: 12px !important;
    }

    .page-header-right > *,
    .profile-actions > *,
    .actions > *,
    .inline-form-actions > * {
        width: 100% !important;
        justify-content: center !important;
    }

    .card,
    .form-panel,
    .record-shell,
    .plan-card,
    .upgrade-card,
    .terms-card,
    .aiq-card,
    .aiq-custom-fields-card {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 14px !important;
        border-radius: 16px !important;
        overflow: hidden !important;
    }

    .table-wrap {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    table {
        min-width: 720px !important;
    }

    .form-grid,
    .form-grid-2,
    .form-grid-3,
    .form-grid-4,
    .grid,
    .grid-2,
    .grid-3,
    .grid-4,
    .content-grid,
    .info-grid,
    .billing-grid,
    .upgrade-layout,
    .plan-billing-grid,
    .crm-profile-grid,
    .crm-contact-grid,
    .crm-relationship-row,
    .crm-two-preview,
    .crm-notes-tasks-grid,
    .crm-activity-grid,
    .activity-split-grid,
    .aiq-custom-field-grid,
    .aiq-person-page,
    .aiq-company-page,
    .aiq-household-page,
    .aiq-business-page {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
        max-width: 100% !important;
        gap: 12px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .record-shell.crm-record-page {
        max-width: 100% !important;
        width: 100% !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .crm-record-meta,
    .plan-metrics {
        grid-template-columns: 1fr !important;
    }

    .upgrade-hero {
        display: block !important;
        padding: 16px !important;
        border-radius: 18px !important;
    }

    .upgrade-price-card {
        width: 100% !important;
        min-width: 0 !important;
        margin-top: 14px !important;
    }

    .upgrade-summary-card {
        position: static !important;
        top: auto !important;
    }

    input,
    select,
    textarea,
    button,
    .btn {
        max-width: 100% !important;
    }

    input,
    select,
    textarea {
        font-size: 16px !important; /* prevents iOS zoom */
    }

    .platform-subscription-actions,
    .platform-billing-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        min-width: 0 !important;
        width: 100% !important;
    }

    .platform-subscription-actions form,
    .platform-billing-actions form,
    .inline-subscription-form {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
    }

    .platform-subscription-actions input,
    .platform-billing-actions input {
        width: 100% !important;
    }
}

@media (max-width: 560px) {
    .main {
        padding: 10px !important;
    }

    .page-title,
    .upgrade-hero .page-title {
        font-size: 24px !important;
        line-height: 1.15 !important;
    }

    .page-subtitle {
        font-size: 13px !important;
        line-height: 1.45 !important;
    }

    .brand img {
        width: 118px !important;
        max-width: 118px !important;
    }

    .nav-link {
        font-size: 12px !important;
        padding: 8px 10px !important;
    }

    .card,
    .form-panel,
    .record-shell,
    .plan-card,
    .upgrade-card {
        padding: 12px !important;
    }

    table {
        min-width: 640px !important;
    }
}
