@import url("https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&display=swap");

:root {
    --bg0: #f6f8f6;
    --bg1: #ffffff;
    --surface: #ffffff;
    --surface-strong: #ffffff;

    --text: #0b1220;
    --muted: rgba(11, 18, 32, 0.56);

    --stroke: rgba(11, 18, 32, 0.1);
    --stroke2: rgba(11, 18, 32, 0.18);

    --glass: #ffffff;
    --glass2: #ffffff;

    --shadow: 0 18px 40px rgba(11, 18, 32, 0.12);
    --shadow2: 0 6px 16px rgba(11, 18, 32, 0.08);

    --radius: 16px;
    --radius2: 20px;
    --blur: 0px;

    --primary: #0f766e;
    --primary2: #0b5f55;
    --accent: #f59e0b;
    --accent2: #b45309;

    --good: #16a34a;
    --warn: #f59e0b;
    --bad: #dc2626;

    --chipBg: rgba(15, 118, 110, 0.12);
    --chipText: #0f766e;

    --card: rgba(255, 255, 255, 0.96);
    --focus: rgba(15, 118, 110, 0.16);

    --font: "Sora", "SF Pro Display", "SF Pro Text", "Segoe UI", sans-serif;
}

* {
    box-sizing: border-box;
}
html,
body {
    height: 100%;
}

body.deal-modal-open {
    overflow: hidden;
}

body.modal-open {
    overflow: hidden;
}

body.deal-modal-open > *:not(.modal):not(.notes-modal) {
    pointer-events: none;
}

body.deal-modal-open .modal,
body.deal-modal-open .notes-modal {
    pointer-events: auto;
}

body.modal-open > *:not(.modal):not(.notes-modal) {
    pointer-events: none;
}

body.modal-open .modal,
body.modal-open .notes-modal {
    pointer-events: auto;
}

body.mobile-deal-open #deal-modal.modal {
    background: #f4f6f8;
}

body.mobile-deal-open #deal-modal .modal-content {
    box-shadow: none;
}
body {
    margin: 0;
    font-family: var(--font);
    color: var(--text);
    background:
        radial-gradient(
            900px 520px at 12% 0%,
            rgba(15, 118, 110, 0.12),
            transparent 60%
        ),
        linear-gradient(180deg, #f7f9f6 0%, #eef2ef 100%);
    -webkit-font-smoothing: antialiased;
    line-height: 1.4;
}

a {
    color: inherit;
    text-decoration: none;
}

.app-body {
    padding: 32px 36px 40px;
}

/* Header */
.app-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    padding: 22px 26px;
    border-radius: var(--radius);
    background: var(--surface-strong);
    border: 1px solid var(--stroke);
    box-shadow: var(--shadow2);
    position: relative;
    overflow: visible;
}
.app-header::before {
    display: none;
}
.app-header > * {
    position: relative;
    z-index: 1;
}
.app-header.has-tabs {
    flex-direction: column;
    align-items: stretch;
}
.app-header-row {
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: space-between;
}
.app-header-search {
    flex: 1;
    display: flex;
    justify-content: center;
}
.app-header-search-input {
    width: 100%;
    max-width: 520px;
}
.app-header-tabs {
    display: flex;
    justify-content: center;
}
.app-header-tabs .top-tabs {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    width: 100%;
    justify-content: center;
}
.app-header-tabs .top-tabs-left {
    justify-content: center;
    width: 100%;
}

.app-brand-link {
    display: inline-flex;
    align-items: center;
    color: inherit;
    text-decoration: none;
    cursor: pointer;
}

.app-brand {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-left: 52px;
    min-height: 42px;
}

.app-brand::before {
    content: "";
    position: absolute;
    left: 0;
    top: 2px;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: #fff url("/static/icons/icon-192.png") center/cover no-repeat;
    border: 1px solid rgba(15, 118, 110, 0.2);
    box-shadow: 0 10px 18px rgba(15, 118, 110, 0.22);
}

.app-header h1 {
    margin: 0;
    font-size: 22px;
    letter-spacing: -0.01em;
    font-weight: 800;
}
.app-header p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
}

.app-nav {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.app-menu-btn {
    width: 44px;
    height: 44px;
    font-size: 18px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.app-menu {
    position: fixed;
    inset: 0;
    display: flex;
    justify-content: flex-end;
    background: rgba(11, 18, 32, 0.35);
    z-index: 10040;
}

.app-menu.hidden {
    display: none;
}

.app-menu-panel {
    width: min(320px, 86vw);
    height: 100%;
    background: rgba(255, 255, 255, 0.98);
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    box-shadow: -18px 0 40px rgba(11, 18, 32, 0.2);
}

.app-menu-title {
    font-weight: 800;
    font-size: 16px;
    margin-bottom: 6px;
}

.app-menu-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.92);
    font-size: 13px;
    text-decoration: none;
}

.app-menu-link:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(11, 18, 32, 0.12);
}

body.menu-open {
    overflow: hidden;
}

/* Buttons */
.primary-button,
.secondary-button,
.danger-button,
.stage-button,
.tab-button,
.fc .fc-button,
.slot-refresh,
.slot-btn {
    border-radius: 14px;
    border: 1px solid var(--stroke);
    padding: 11px 14px;
    font-size: 13px;
    cursor: pointer;
    background: var(--surface-strong);
    color: var(--text);
    font-weight: 700;
    box-shadow: 0 3px 10px rgba(11, 18, 32, 0.08);
    transition:
        transform 0.12s ease,
        box-shadow 0.12s ease,
        background 0.12s ease,
        border-color 0.12s ease,
        color 0.12s ease;
}

.primary-button {
    border-color: rgba(15, 118, 110, 0.35);
    color: #fff;
    background: linear-gradient(
        180deg,
        rgba(15, 118, 110, 0.98),
        rgba(17, 94, 89, 0.98)
    );
    box-shadow: 0 14px 26px rgba(15, 118, 110, 0.22);
}
.primary-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(15, 118, 110, 0.28);
}

.secondary-button:hover,
.stage-button:hover,
.tab-button:hover,
.fc .fc-button:hover,
.slot-refresh:hover,
.slot-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 30px rgba(11, 18, 32, 0.14);
}

.primary-button {
    background: linear-gradient(135deg, var(--primary), var(--primary2));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 14px 30px rgba(15, 118, 110, 0.28);
}
.primary-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 36px rgba(15, 118, 110, 0.32);
}
.secondary-button {
    background: rgba(255, 255, 255, 0.9);
    border-color: var(--stroke2);
}
.stage-button {
    padding: 8px 10px;
    font-size: 12px;
    background: rgba(255, 255, 255, 0.7);
    border-color: rgba(11, 18, 32, 0.1);
}
.tab-button {
    padding: 10px 14px;
    background: rgba(255, 255, 255, 0.7);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.tab-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
}
.tab-icon svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.tab-text {
    line-height: 1;
}
.danger-button {
    border-color: rgba(220, 38, 38, 0.35);
    color: #fff;
    background: linear-gradient(180deg, rgba(220, 38, 38, 0.95), rgba(185, 28, 28, 0.95));
    box-shadow: 0 14px 26px rgba(220, 38, 38, 0.2);
}
.danger-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(220, 38, 38, 0.26);
}
.tab-active {
    border-color: rgba(15, 118, 110, 0.4);
    background: rgba(15, 118, 110, 0.12);
    box-shadow: 0 6px 14px rgba(15, 118, 110, 0.16);
}

/* Layout */
.dashboard-main {
    margin-top: 18px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Panels */
.top-tabs,
.controls-panel,
.google-panel,
#calendar-mount {
    border-radius: var(--radius);
    background: var(--surface-strong);
    border: 1px solid var(--stroke);
    box-shadow: var(--shadow2);
}

.top-tabs {
    display: flex;
    gap: 12px;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
}
.top-tabs-left {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.top-tabs-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}
.pipeline-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.pipeline-actions:empty {
    display: none;
}
.pipeline-actions .control-group {
    margin: 0;
}
.controls-panel {
    display: flex;
    align-items: end;
    gap: 14px;
    flex-wrap: wrap;
    padding: 12px 14px;
}

.modal-row {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.modal-row .modal-field {
    margin: 0;
}
.modal-row .modal-input,
.modal-row .modal-textarea,
.modal-row select {
    padding: 8px 10px;
    font-size: 12px;
}

.deal-metrics-row {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

#deal-modal-equity-field.hidden {
    display: none;
}

/* Inputs */
.control-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 180px;
}
.control-group label {
    font-size: 11px;
    color: var(--muted);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 800;
}
.control-group select,
.modal-input,
.modal-textarea,
input[type="text"],
input[type="number"],
input[type="datetime-local"],
textarea,
.slot-picker-row input[type="date"] {
    border-radius: 14px;
    border: 1px solid var(--stroke2);
    background: var(--surface);
    padding: 10px 12px;
    font-size: 13px;
    outline: none;
    color: var(--text);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.control-group select:focus,
.modal-input:focus,
.modal-textarea:focus,
input:focus,
textarea:focus {
    border-color: rgba(15, 118, 110, 0.45);
    box-shadow: 0 0 0 4px var(--focus);
}

/* Calendar */
.calendar-view {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.calendar-ai-scheduler {
    border-radius: var(--radius);
    background: var(--glass);
    border: 1px solid var(--stroke);
    box-shadow: var(--shadow2);
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.calendar-ai-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.calendar-ai-title {
    font-size: 14px;
    font-weight: 900;
}

.calendar-ai-subtitle {
    font-size: 12px;
    color: var(--muted);
}

.calendar-ai-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.calendar-ai-reschedule {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
.calendar-ai-reschedule-hint {
    font-size: 12px;
    color: var(--muted);
}
.ai-reschedule-actions {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}
.ai-reschedule-actions button {
    flex: 1;
}

.calendar-ai-status {
    font-size: 12px;
    color: var(--muted);
}

#calendar-ai-scheduler,
#ai-schedule-modal,
#ai-reschedule-modal {
    display: none !important;
}

.ai-schedule-modal {
    max-width: 680px;
}

.ai-schedule-body {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-height: 420px;
    overflow: auto;
    margin-top: 8px;
}

.ai-schedule-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ai-schedule-item {
    border-radius: 12px;
    border: 1px solid var(--stroke);
    padding: 10px;
    background: rgba(255, 255, 255, 0.82);
}

.ai-schedule-item-highlight {
    border-color: rgba(16, 185, 129, 0.35);
    box-shadow: 0 10px 18px rgba(16, 185, 129, 0.12);
    background: rgba(16, 185, 129, 0.08);
}

.ai-schedule-item-title {
    font-size: 13px;
    font-weight: 800;
}

.ai-schedule-item-meta {
    font-size: 11px;
    color: var(--muted);
    margin-top: 4px;
}

.ai-schedule-item-badge {
    margin-top: 6px;
    display: inline-flex;
    align-items: center;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #0f766e;
}

.ai-schedule-section {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ai-schedule-section-title {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-top: 6px;
}

.ai-schedule-empty {
    font-size: 12px;
    color: var(--muted);
}

@media (max-width: 720px) {
    .calendar-ai-reschedule {
        flex-direction: column;
        align-items: stretch;
    }
}

.google-panel {
    overflow: visible;
}
.google-topbar {
    padding: 12px 12px 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.46);
}
.google-badge {
    font-size: 12px;
    color: var(--muted);
    font-weight: 750;
}

.google-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    border-radius: 999px;
    border: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.75);
}

.google-badge-connected {
    border-color: rgba(16, 185, 129, 0.35);
    color: #065f46;
    background: rgba(16, 185, 129, 0.12);
}

.google-badge-muted {
    color: var(--muted);
    background: rgba(0, 0, 0, 0.04);
}

.google-badge-check {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: #10b981;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    line-height: 1;
}

.google-badge-label {
    font-size: 12px;
    font-weight: 800;
}
.google-events {
    padding: 12px;
}
.calendar-empty {
    padding: 18px;
    color: var(--muted);
    font-size: 13px;
}

.calendar-day {
    border-radius: 16px;
    border: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.78);
    box-shadow: 0 10px 22px rgba(11, 18, 32, 0.1);
    margin-bottom: 10px;
    overflow: visible;
}
.calendar-day-header {
    padding: 10px 12px;
    border-bottom: 1px solid var(--stroke);
    color: var(--muted);
    font-size: 12px;
    font-weight: 850;
    background: rgba(255, 255, 255, 0.46);
}
.calendar-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
}
.calendar-time {
    font-size: 12px;
    color: var(--muted);
}
.calendar-row-title {
    font-size: 13px;
    font-weight: 850;
}
.calendar-row-meta {
    font-size: 12px;
    color: var(--muted);
    margin-top: 4px;
}

/* FullCalendar */
.fc {
    font-family: var(--font);
    border: 1px solid var(--stroke);
    border-radius: 16px;
    overflow: visible;
    background: var(--surface);
    box-shadow: var(--shadow2);
}
.fc .fc-toolbar {
    padding: 12px 12px 8px;
}
.fc .fc-toolbar-title {
    font-size: 14px;
    font-weight: 950;
    letter-spacing: -0.01em;
}
.fc .fc-button {
    padding: 8px 10px;
    font-size: 12px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.82);
    color: var(--text);
}
.fc .fc-button:focus {
    box-shadow: 0 0 0 4px var(--focus);
}
.fc .fc-button-primary:disabled {
    opacity: 0.55;
}
.fc .fc-day-today {
    background: rgba(15, 118, 110, 0.08);
}
.fc .fc-col-header-cell {
    background: rgba(255, 255, 255, 0.52);
}
.fc .fc-col-header-cell-cushion {
    padding: 10px 6px;
    font-size: 12px;
    color: var(--muted);
    font-weight: 900;
}
.fc .fc-timegrid-slot-label {
    font-size: 11px;
    color: var(--muted);
}
.fc .fc-event {
    border-radius: 10px;
    border: 1px solid rgba(11, 18, 32, 0.14);
    background: rgba(15, 118, 110, 0.12);
    padding: 2px 6px;
}
.fc .fc-event-title {
    font-size: 12px;
    font-weight: 900;
}
.fc .fc-event-time {
    font-size: 11px;
    opacity: 0.88;
}
.fc-theme-standard td,
.fc-theme-standard th,
.fc .fc-scrollgrid,
.fc .fc-scrollgrid-section td,
.fc .fc-scrollgrid-section th {
    border-color: rgba(11, 18, 32, 0.08);
}
.fc .fc-timegrid-slots tr:nth-child(2n) td {
    background: rgba(255, 255, 255, 0.36);
}
.fc .fc-daygrid-day-frame {
    padding: 6px;
}
.fc .fc-daygrid-event {
    margin: 4px 6px;
}

/* Cleaner calendar look */
#calendar-mount {
    background: rgba(255, 255, 255, 0.96);
    border-radius: 18px;
    border: 1px solid var(--stroke);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.08);
    padding: 8px;
}
.fc {
    --fc-border-color: rgba(15, 23, 42, 0.08);
    --fc-page-bg-color: #ffffff;
    --fc-today-bg-color: rgba(15, 118, 110, 0.08);
    --fc-neutral-bg-color: rgba(15, 23, 42, 0.02);
    font-size: 12px;
}
.fc .fc-scrollgrid {
    border-radius: 16px;
    overflow: hidden;
}
.fc .fc-daygrid-day-frame,
.fc .fc-timegrid-slot {
    background: #ffffff;
}
.fc .fc-timegrid-slot-label {
    color: var(--muted);
}
.fc .fc-daygrid-event,
.fc .fc-timegrid-event {
    border-radius: 8px;
    border: none;
    padding: 2px 6px;
    background: rgba(15, 118, 110, 0.14);
    color: #0b1220;
    font-weight: 700;
}
.fc .fc-timegrid-event {
    background: rgba(15, 118, 110, 0.18);
}
.fc .calendar-task-event {
    background: rgba(245, 158, 11, 0.2);
    color: #7c2d12;
    border: 1px solid rgba(245, 158, 11, 0.4);
}
.fc .calendar-task-event .fc-event-title {
    color: #7c2d12;
}
.fc .fc-event-title {
    font-size: 11px;
    font-weight: 700;
}
.fc .fc-list-day-cushion {
    background: rgba(255, 255, 255, 0.7);
    font-weight: 800;
    color: var(--muted);
}
.fc .fc-list-event {
    border-bottom: 1px solid var(--stroke);
}
.fc .fc-list-event-title {
    font-weight: 700;
}
.fc .fc-col-header-cell-cushion {
    font-size: 11px;
    font-weight: 700;
    color: var(--muted);
}
.fc .fc-daygrid-day-number {
    font-size: 11px;
    font-weight: 700;
    color: var(--muted);
}

/* Calendar subtabs */
.calendar-subtabs {
    display: flex;
    gap: 10px;
    padding: 10px 12px 0;
}
.calendar-subtab {
    border-radius: 14px;
    border: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.9);
    padding: 9px 12px;
    cursor: pointer;
    font-weight: 900;
    font-size: 12px;
    color: var(--muted);
    box-shadow: 0 6px 16px rgba(11, 18, 32, 0.08);
    transition:
        transform 0.12s ease,
        box-shadow 0.12s ease,
        background 0.12s ease,
        border-color 0.12s ease,
        color 0.12s ease;
}
.calendar-subtab:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 30px rgba(11, 18, 32, 0.14);
}
.calendar-subtab.active {
    color: var(--text);
    border-color: rgba(15, 118, 110, 0.4);
    background: rgba(15, 118, 110, 0.16);
    box-shadow: 0 14px 26px rgba(15, 118, 110, 0.18);
}
.calendar-subview {
    padding: 0;
}

/* Modals */
.modal,
.notes-modal {
    position: fixed;
    inset: 0;
    background: rgba(11, 18, 32, 0.35);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    z-index: 9999;
    overflow: auto;
}

.modal-body {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.modal-radio-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 6px;
}

.modal-radio {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--text);
}

.modal-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--muted);
    margin-top: 10px;
}

.modal-checkbox input {
    accent-color: var(--primary);
}

.deal-pack-row {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.deal-pack-row .modal-input {
    flex: 1;
    min-width: 200px;
}

.deal-address-block {
    display: grid;
    gap: 10px;
    padding: 10px;
    border-radius: 16px;
    background: rgba(11, 18, 32, 0.04);
    border: 1px solid rgba(11, 18, 32, 0.08);
}
.deal-address-primary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
}
.deal-address-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}
.deal-address-list {
    display: grid;
    gap: 8px;
}
.deal-address-row {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.9fr) minmax(0, 0.9fr) auto;
    gap: 10px;
    align-items: center;
}
.deal-address-row .stage-button,
.deal-address-primary .stage-button {
    white-space: nowrap;
}

.modal-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--muted);
}

#task-workspace-modal {
    z-index: 10010;
}

#work-waiting-modal {
    z-index: 10020;
}

#subitem-modal {
    z-index: 10030;
}

#task-workspace-reschedule,
#task-workspace-sync {
    display: none;
}

#ai-underwrite-modal .modal-content {
    width: min(980px, 96vw);
}
.ai-underwrite-modal .modal-body {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.ai-underwrite-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 6px;
}
.ai-underwrite-output {
    font-size: 13px;
    color: var(--text);
    margin-top: 12px;
}
.ai-underwrite-summary {
    font-weight: 700;
    margin-bottom: 6px;
}
.missing-info-modal .modal-body {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.missing-info-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.missing-info-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.missing-info-item {
    padding: 8px 12px;
    border-radius: 12px;
    border: 1px solid var(--stroke);
    background: #fff;
    font-size: 12px;
}
.missing-info-item.missing {
    border-color: rgba(225, 29, 72, 0.26);
    background: rgba(225, 29, 72, 0.08);
}
.missing-info-item.rejected {
    border-color: rgba(217, 119, 6, 0.3);
    background: rgba(217, 119, 6, 0.12);
}
.missing-info-item.submitted {
    border-color: rgba(37, 99, 235, 0.25);
    background: rgba(37, 99, 235, 0.08);
}
.ai-breakdown-output {
    display: flex;
    flex-direction: column;
    gap: 10px;
    font-size: 12px;
    color: var(--text);
}
.ai-breakdown-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.ai-breakdown-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--stroke);
    background: #fff;
}
.ai-breakdown-title {
    font-weight: 700;
}
.ai-breakdown-deps {
    font-size: 11px;
    color: var(--muted);
    margin-top: 4px;
}
.ai-underwrite-meta {
    font-size: 12px;
    color: var(--muted);
    margin-bottom: 10px;
}

.ai-underwrite-focus {
    font-size: 12px;
    color: var(--text);
    margin-bottom: 10px;
}
.ai-underwrite-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.ai-underwrite-block {
    background: var(--surface);
    border: 1px solid var(--stroke);
    border-radius: 14px;
    padding: 10px;
}
.ai-underwrite-block-title {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-bottom: 6px;
}
.ai-underwrite-block ul {
    margin: 0;
    padding-left: 16px;
}
.ai-underwrite-block li {
    margin: 4px 0;
}

.work-underwrite-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

.work-underwrite-title {
    font-weight: 700;
    font-size: 1.2rem;
}

.work-underwrite-subtitle {
    color: var(--muted);
    font-size: 0.92rem;
}

.work-underwrite-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

.work-underwrite-controls {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 16px;
}

.work-underwrite-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.work-underwrite-card {
    background: var(--surface-strong);
    border: 1px solid var(--stroke);
    border-radius: var(--radius);
    padding: 14px;
    box-shadow: var(--shadow2);
}

.work-underwrite-card-title {
    font-weight: 600;
    margin-bottom: 8px;
}

.work-underwrite-kv {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    padding: 6px 0;
    border-bottom: 1px dashed var(--stroke);
    font-size: 0.9rem;
}

.work-underwrite-kv span {
    color: var(--muted);
}

.work-underwrite-kv strong {
    font-weight: 600;
    text-align: right;
}

.work-underwrite-kv:last-child,
.work-underwrite-checklist li:last-child {
    border-bottom: 0;
}

.work-underwrite-addresses {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.work-underwrite-address {
    border: 1px solid var(--stroke);
    background: var(--surface);
    color: var(--text);
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 0.78rem;
    cursor: pointer;
}

.work-underwrite-address:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.work-underwrite-checklist {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.work-underwrite-checklist li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    border-bottom: 1px dashed var(--stroke);
    font-size: 0.9rem;
}

.work-underwrite-check.is-done span {
    text-decoration: line-through;
    color: var(--muted);
}

.work-underwrite-check.is-done .work-underwrite-pill {
    background: rgba(22, 163, 74, 0.15);
    color: var(--good);
}

.work-underwrite-pill {
    background: var(--chipBg);
    color: var(--chipText);
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    border: 0;
    cursor: pointer;
}

.work-underwrite-market-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.work-underwrite-market-geo {
    margin-top: 6px;
    font-size: 0.82rem;
    color: var(--muted);
}

.work-underwrite-market-cards {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 6px;
}

.work-underwrite-market-links {
    margin-top: 12px;
}

.work-underwrite-market-card {
    border: 1px solid var(--stroke);
    border-radius: 12px;
    padding: 10px;
    background: var(--surface);
}

.work-underwrite-market-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 8px;
    margin-top: 10px;
}

.work-underwrite-market-metrics div {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.82rem;
    background: var(--surface);
    border: 1px solid var(--stroke);
    border-radius: 10px;
    padding: 8px;
}

.work-underwrite-market-metrics span {
    color: var(--muted);
}

.work-underwrite-market-note {
    margin-top: 8px;
    color: var(--muted);
    font-size: 0.85rem;
}

.work-underwrite-docs-metrics {
    font-size: 0.9rem;
    color: var(--muted);
    margin-bottom: 10px;
}

.work-underwrite-section-title {
    font-weight: 600;
    font-size: 0.85rem;
    margin-bottom: 6px;
}

.work-underwrite-missing ul {
    margin: 6px 0 0;
    padding-left: 18px;
}

.work-underwrite-docs-foot {
    margin-top: 10px;
    color: var(--muted);
    font-size: 0.85rem;
}

.work-underwrite-press-summary {
    font-weight: 600;
    margin-bottom: 6px;
}

.work-underwrite-press {
    font-size: 0.9rem;
}

.work-underwrite-ofac-row {
    margin-top: 10px;
}

.work-underwrite-ofac-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}

.work-underwrite-ofac-detail {
    border: 1px solid var(--stroke);
    border-radius: 12px;
    padding: 6px 10px;
    background: rgba(255, 255, 255, 0.8);
    margin-top: 6px;
}

.work-underwrite-ofac-detail summary {
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 600;
}

.work-underwrite-ofac-meta {
    font-size: 0.78rem;
    color: var(--muted);
    margin-top: 4px;
}

.work-underwrite-press-risk {
    font-size: 0.85rem;
    color: var(--muted);
    margin-bottom: 8px;
}

.work-underwrite-press-section {
    margin-top: 8px;
}

.work-underwrite-press-suggest {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px dashed var(--stroke);
}

.work-underwrite-press-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
}

.work-underwrite-press-headlines {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.work-underwrite-press-headlines a {
    color: var(--primary);
    text-decoration: underline;
    font-size: 0.85rem;
}

.work-underwrite-report {
    background: var(--surface-strong);
    border: 1px solid var(--stroke);
    border-radius: var(--radius);
    padding: 14px;
}

.work-underwrite-report-title {
    font-weight: 600;
    margin-bottom: 10px;
}

.work-underwrite-links {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 10px 0 18px;
    padding: 10px 12px;
    border-radius: 14px;
    background: var(--surface);
    border: 1px solid var(--stroke);
}

.work-underwrite-links-title {
    font-weight: 600;
}

.work-underwrite-links-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

@media (max-width: 720px) {
    .work-underwrite-links {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 720px) {
    .work-underwrite-header {
        align-items: stretch;
    }
    .work-underwrite-actions {
        width: 100%;
        justify-content: flex-start;
    }
    .work-underwrite-controls {
        flex-direction: column;
        align-items: stretch;
    }
}

.hidden{
  display:none !important;
  pointer-events:none !important;
}

.modal-content,
.notes-modal-content {
    border-radius: var(--radius2);
    background: var(--surface-strong);
    border: 1px solid var(--stroke);
    box-shadow: var(--shadow);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    padding: 14px;
    max-height: calc(100vh - 44px);
    overflow: auto;
}
.modal-content {
    width: min(980px, 96vw);
}
.notes-modal-content {
    width: min(720px, 96vw);
}

.notes-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--stroke);
    margin-bottom: 12px;
}
.notes-modal-title {
    font-weight: 950;
    font-size: 14px;
    letter-spacing: -0.01em;
}
.modal-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin: 10px 0;
}
.modal-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.deal-modal-section {
    border-radius: 16px;
    border: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.92);
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.deal-modal-section-title {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}
.deal-modal-section .modal-field,
.deal-modal-section .modal-row {
    margin: 0;
}
.modal-field-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.modal-field label {
    font-size: 12px;
    color: var(--muted);
    font-weight: 800;
}
.notes-modal-actions,
.modal-actions {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
}

#deal-modal .modal-actions {
    align-items: stretch;
}

#deal-modal .modal-actions button {
    min-height: 42px;
    font-size: 13px;
    letter-spacing: 0.01em;
}

#deal-modal .modal-actions .stage-button {
    padding: 10px 12px;
    font-size: 13px;
    background: rgba(255, 255, 255, 0.9);
    border-color: var(--stroke2);
}

#deal-modal .modal-actions .delete-button {
    padding: 10px 12px;
    font-size: 13px;
    font-weight: 700;
    color: #fff;
    border-color: transparent;
    background: linear-gradient(135deg, rgba(220, 38, 38, 0.95), rgba(185, 28, 28, 0.95));
    box-shadow: 0 14px 26px rgba(220, 38, 38, 0.2);
}

#deal-modal .modal-actions .delete-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(220, 38, 38, 0.26);
}

#subitem-modal .modal-actions {
    position: sticky;
    bottom: 0;
    background: var(--surface-strong);
    padding: 12px 0 6px;
    z-index: 2;
}

.modal-deal-name {
    font-weight: 950;
    font-size: 14px;
    margin-bottom: 10px;
}
.modal-textarea {
    width: 100%;
    min-height: 200px;
    resize: vertical;
    font-size: 13px;
}

.address-results {
    border: 1px solid var(--stroke);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
    margin-top: 8px;
    max-height: 240px;
    overflow: auto;
}
.address-result {
    width: 100%;
    text-align: left;
    padding: 10px 12px;
    border: none;
    background: transparent;
    cursor: pointer;
}
.address-result:hover {
    background: rgba(15, 118, 110, 0.08);
}
.address-result-main {
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
}
.address-result-sub,
.address-result-empty {
    font-size: 11px;
    color: var(--muted);
    margin-top: 2px;
}

.dependency-list {
    display: grid;
    gap: 8px;
    margin-top: 6px;
}
.dependency-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--text);
}

.email-ai-prompt {
    min-height: 90px;
}

.install-modal {
    max-width: 520px;
}

.install-modal-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 12px;
    color: var(--muted);
}

.install-step {
    padding: 10px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--stroke);
}

.install-tip {
    font-size: 11px;
    color: var(--muted);
}

/* Hebrew calendar blocks */
.fc .hebcal-block {
    opacity: 1 !important;
}
.fc .fc-bg-event .fc-event-title {
    font-weight: 950;
    font-size: 11px;
    padding-left: 6px;
    opacity: 0.95;
}
.fc .hebcal-shabbat {
    background: rgba(15, 118, 110, 0.18) !important;
}
.fc .hebcal-holiday {
    background: rgba(245, 158, 11, 0.18) !important;
}

.upcoming-wrap {
    padding: 14px;
}

.upcoming-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.upcoming-item {
    border-radius: 18px;
    border: 1px solid var(--stroke);
    background: rgba(255, 255, 255, 0.64);
    box-shadow: 0 10px 24px rgba(11, 18, 32, 0.1);
    padding: 12px;
}

.upcoming-title {
    font-weight: 900;
    font-size: 14px;
    line-height: 1.25;
    margin: 0;
}

.upcoming-meta {
    margin-top: 6px;
    font-size: 12px;
    color: var(--muted);
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.deal-notes-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 10px;
}

.deal-notes-add {
  display: flex;
  gap: 10px;
  align-items: center;
}

#deal-note-new {
  flex: 1;
  min-width: 0;
}

.deal-notes-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.deal-note-item {
  border-radius: 14px;
  padding: 12px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,0.65);
}

.deal-note-body {
  width: 100%;
  resize: vertical;
}
.deal-note-body[readonly] {
  background: rgba(245, 246, 248, 0.9);
  border: 1px dashed rgba(0,0,0,0.2);
  color: #555;
  cursor: not-allowed;
}

.deal-note-meta {
  font-size: 12px;
  color: var(--muted);
  margin-top: 6px;
}

.deal-note-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 10px;
}

.deal-notes-empty {
  font-size: 13px;
  color: var(--muted);
  padding: 6px 2px;
}

.checkbox-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

.checkbox-row-danger {
  color: #991b1b;
}

.checkbox-row-danger input {
  accent-color: #ef4444;
}


.metrics-item,
.metric-card {
  min-width: 0;
}

.metrics-value,
.metric-sub,
.metrics-amount {
  overflow: hidden;
  text-overflow: ellipsis;
}

.metrics-value {
  white-space: nowrap;
}

.metrics-amount {
  white-space: normal;
  overflow-wrap: anywhere;
}

.summary-row-sub {
  overflow-wrap: anywhere;
}


.summary-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.summary-row {
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,0.70);
  padding: 12px;
  box-shadow: 0 8px 18px rgba(11, 18, 32, 0.08);
}

.summary-row-title {
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.02em;
  margin-bottom: 6px;
}



.contact-badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:0.2px;
  border:1px solid rgba(255,255,255,0.25);
  background:rgba(255,255,255,0.14);
  backdrop-filter: blur(10px);
}

.note-ts{
  opacity:0.85;
  font-weight:600;
}

.contact-deal-section{
  margin:14px 0 18px 0;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  backdrop-filter: blur(10px);
}

.contact-deal-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight:800;
  margin-bottom:10px;
}

.contact-deal-count{
  opacity:0.85;
  font-weight:800;
}

.contact-deal-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.contact-deal-item{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(0,0,0,0.12);
}

.contacts-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(280px, 360px);
  gap:20px;
  align-items:start;
}

.contacts-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

.contacts-title{
  font-size:20px;
  font-weight:900;
  letter-spacing:-0.01em;
}

.contacts-subtitle{
  font-size:12px;
  color:var(--muted);
}

.contacts-summary{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.marketplace-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.marketplace-title{
  font-size:20px;
  font-weight:900;
  letter-spacing:-0.01em;
}

.marketplace-subtitle{
  font-size:12px;
  color:var(--muted);
}

.contacts-summary-card{
  border-radius:14px;
  border:1px solid rgba(15,23,42,0.12);
  background:var(--surface-strong);
  padding:12px 14px;
  min-width:150px;
}

.contacts-summary-value{
  font-weight:900;
  font-size:14px;
}

.contacts-summary-label{
  font-size:11px;
  color:var(--muted);
  margin-top:2px;
}


.contacts-view{
  margin-top:20px;
}

.marketplace-view{
  margin-top:20px;
}

.contacts-subtabs{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.contacts-subtab{
  border-radius:999px;
  border:1px solid rgba(15,23,42,0.12);
  background:var(--surface-strong);
  padding:10px 18px;
  font-size:12px;
  font-weight:900;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:var(--muted);
  cursor:pointer;
}

.contacts-subtab.active{
  color:var(--text);
  border-color:rgba(15,118,110,0.35);
  background:rgba(15,118,110,0.12);
  box-shadow:0 10px 18px rgba(15,118,110,0.14);
}

.contacts-subview{
  display:block;
}

.contacts-market{
  display:flex;
  flex-direction:column;
  gap:20px;
}

.contacts-market-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}

.contacts-market-grid-split{
  grid-template-columns:minmax(0, 1fr) minmax(0, 1.2fr);
}

.contacts-market-panel{
  border-radius:var(--radius);
  border:1px solid var(--stroke);
  background:var(--surface-strong);
  box-shadow:var(--shadow2);
  backdrop-filter:blur(var(--blur));
  -webkit-backdrop-filter:blur(var(--blur));
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.contacts-market-title{
  font-weight:900;
  font-size:14px;
}

.contacts-market-filters{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:10px;
}

.contacts-market-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.contacts-market-note{
  font-size:12px;
  color:var(--muted);
}

.contacts-market-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.contacts-market-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,0.12);
  background:var(--surface-strong);
}

.contacts-market-item-main{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}

.contacts-market-item-name{
  font-weight:800;
  font-size:13px;
}

.contacts-market-item-meta{
  font-size:11px;
  color:var(--muted);
  overflow-wrap:anywhere;
}

.contacts-chat-thread{
  border-radius:14px;
  border:1px dashed rgba(15,23,42,0.2);
  background:var(--surface-strong);
  padding:16px;
  min-height:260px;
  max-height:360px;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.contacts-chat-msg{
  padding:8px 10px;
  border-radius:12px;
  background:rgba(15,23,42,0.08);
  font-size:12px;
}

.contacts-chat-msg.me{
  align-self:flex-end;
  background:rgba(15,118,110,0.16);
}

.contacts-chat-meta{
  font-size:10px;
  color:var(--muted);
  margin-top:4px;
}

.contacts-chat-input{
  display:flex;
  gap:8px;
  align-items:center;
}

.contacts-panel{
  border-radius: var(--radius);
  background: var(--surface-strong);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow2);
  backdrop-filter: blur(var(--blur));
  -webkit-backdrop-filter: blur(var(--blur));
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.contacts-panel-side{
  min-height:200px;
}

.contacts-panel-title{
  font-weight:900;
  font-size:13px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--muted);
}

.contacts-focus{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.contacts-focus-card{
  border-radius:16px;
  border:1px solid rgba(15,23,42,0.12);
  background:var(--surface-strong);
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.contacts-focus-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}

.contacts-focus-name{
  font-weight:900;
  font-size:15px;
}

.contacts-focus-meta{
  font-size:12px;
  color:var(--muted);
  overflow-wrap:anywhere;
}

.contacts-focus-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

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

.contacts-focus-section-title{
  font-weight:800;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--muted);
}

.contacts-focus-mix{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.contacts-focus-badges{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}

.contacts-focus-badge{
  border-radius:999px;
  border:1px solid rgba(15,23,42,0.12);
  background:rgba(255,255,255,0.72);
  padding:4px 10px;
  font-size:11px;
  font-weight:800;
  color:var(--muted);
}

.contacts-focus-deals{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.contacts-focus-deal{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,0.14);
  background:var(--surface-strong);
}

.contacts-focus-deal.won{
  border-color:rgba(22,163,74,0.22);
  background:rgba(22,163,74,0.12);
}

.contacts-focus-deal.lost{
  border-color:rgba(220,38,38,0.22);
  background:rgba(220,38,38,0.1);
}

.contacts-focus-deal-main{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.contacts-focus-deal-title{
  font-weight:900;
  font-size:13px;
}

.contacts-focus-deal-meta{
  font-weight:800;
  font-size:11px;
  color:var(--muted);
}

.contact-row-active{
  border-color:rgba(16,185,129,0.4);
  box-shadow:0 18px 36px rgba(16,185,129,0.18);
}

.contacts-toolbar{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

.contacts-toolbar-left{
  display:flex;
  gap:14px;
  align-items:end;
  flex-wrap:wrap;
}

.contacts-toolbar-right{
  display:flex;
  gap:10px;
  align-items:center;
}

.contacts-segments{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.contacts-segment{
  border-radius:999px;
  border:1px solid rgba(15,23,42,0.12);
  background:var(--surface-strong);
  padding:8px 14px;
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  cursor:pointer;
}

.contacts-segment.active{
  color:var(--text);
  border-color:rgba(15,118,110,0.3);
  background:rgba(15,118,110,0.14);
  box-shadow:0 10px 18px rgba(15,118,110,0.16);
}

.contacts-create{
  display:flex;
  gap:14px;
  align-items:end;
  flex-wrap:wrap;
  border-top: 1px solid var(--stroke);
  padding-top: 16px;
}

.contacts-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.contact-row{
  border-radius: 18px;
  border: 1px solid var(--stroke);
  background: var(--surface-strong);
  box-shadow: var(--shadow2);
  padding: 16px;
}

.contact-row-top{
  display:grid;
  grid-template-columns:minmax(0, 1.4fr) minmax(0, 1fr) auto;
  align-items:start;
  gap:16px;
}

.contact-row-left{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.contact-name{
  font-weight: 950;
  font-size: 16px;
  line-height: 1.2;
}

.contact-meta{
  font-size: 12px;
  color: var(--muted);
  overflow-wrap:anywhere;
}

.contact-row-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}

.contact-row-stats{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
}

.contact-stat{
  border-radius:12px;
  border:1px solid rgba(15,23,42,0.12);
  background:rgba(255,255,255,0.8);
  padding:8px 10px;
}

.contact-stat-value{
  font-weight:900;
  font-size:13px;
}

.contact-stat-label{
  font-size:11px;
  color:var(--muted);
}

.contact-quick-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;
}

.contact-quick-link{
  text-decoration:none;
}

.contact-tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,0.12);
  background:rgba(255,255,255,0.72);
  font-size:11px;
  font-weight:800;
  color:var(--muted);
}

.contact-tag-won{
  border-color:rgba(22,163,74,0.3);
  background:rgba(22,163,74,0.12);
  color:#166534;
}

.contact-tag-lost{
  border-color:rgba(220,38,38,0.28);
  background:rgba(220,38,38,0.1);
  color:#7f1d1d;
}

.contact-cat-badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(37,99,235,0.30);
  background: rgba(37,99,235,0.16);
  color: #1d4ed8;
  font-weight: 900;
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
}

.contact-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.contact-edit-form{
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--stroke);
}

.contact-edit-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:10px;
}

@media (max-width: 980px){
  .contact-edit-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 1100px){
  .contacts-layout{ grid-template-columns: 1fr; }
}

@media (max-width: 900px){
  .contact-row-top{ grid-template-columns: 1fr; }
  .contact-row-stats{ grid-template-columns: 1fr 1fr; }
}


.contact-deals-wrap{
  margin-top: 10px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.contact-deals-badges{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.deal-count-badge{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,0.18);
  background: rgba(255,255,255,0.72);
  font-weight: 900;
  font-size: 12px;
}

.deal-count-badge b{
  font-size: 13px;
  font-weight: 1000;
}

.deal-count-badge.won{
  border-color: rgba(22,163,74,0.28);
  background: rgba(22,163,74,0.14);
  color: #166534;
}

.deal-count-badge.lost{
  border-color: rgba(220,38,38,0.28);
  background: rgba(220,38,38,0.12);
  color: #7f1d1d;
}

.contacts-insights{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.contacts-insight-card{
  border-radius:14px;
  border:1px solid rgba(15,23,42,0.12);
  background:rgba(255,255,255,0.78);
  padding:10px;
  box-shadow:0 10px 20px rgba(11,18,32,0.06);
}

.contacts-insight-title{
  font-weight:900;
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--muted);
}

.contacts-insight-list{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:8px;
}

.contacts-insight-row{
  display:flex;
  justify-content:space-between;
  gap:8px;
  font-size:12px;
}

.contacts-insight-name{
  font-weight:800;
}

.contacts-insight-value{
  font-weight:800;
  color:var(--muted);
}

.contact-deals-list{
  border-top: 1px solid var(--stroke);
  padding-top: 10px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.contact-deal-row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.14);
  background: rgba(255,255,255,0.70);
}

.contact-deal-row.won{
  border-color: rgba(22,163,74,0.22);
  background: rgba(22,163,74,0.10);
}

.contact-deal-row.lost{
  border-color: rgba(220,38,38,0.22);
  background: rgba(220,38,38,0.08);
}

.contact-deal-name{
  font-weight: 950;
  font-size: 13px;
}

.contact-deal-status{
  font-weight: 900;
  font-size: 12px;
  color: var(--muted);
}

.top-tabs-left{
  padding: 4px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(255, 255, 255, 0.75);
}

.top-tabs .tab-button{
  padding: 8px 14px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
  font-weight: 700;
}

.top-tabs .tab-button.tab-active{
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(15, 118, 110, 0.3);
  box-shadow: 0 10px 20px rgba(15, 118, 110, 0.16);
}

#calendar-view, #contacts-view, #marketplace-view{
  padding: 18px;
}

#deal-modal.deal-modal-readonly .modal-form .modal-field:not(#deal-modal-files-inline),
#deal-modal.deal-modal-readonly .modal-form .deal-modal-section:not(#deal-modal-files-inline) {
  opacity: 0.75;
}

#calendar-mount{
  padding: 0;
}

.contacts-grid{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:6px;
}

.contact-role-row{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
}

.contact-role-label{
  min-width:150px;
  font-weight:600;
  opacity:.9;
}

.contact-role-controls{
  display:flex;
  gap:8px;
  flex:1;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#metrics-bar,
.top-tabs,
.controls-panel,
.kanban-board,
.work-view,
.calendar-view,
.marketplace-view,
.ai-panel {
  animation: fadeUp 0.55s ease both;
}

#metrics-bar {
  animation-delay: 0.05s;
}
.top-tabs {
  animation-delay: 0.09s;
}
.controls-panel {
  animation-delay: 0.13s;
}
.kanban-board {
  animation-delay: 0.17s;
}

@media (prefers-reduced-motion: reduce) {
  #metrics-bar,
  .top-tabs,
  .controls-panel,
  .kanban-board,
  .work-view,
  .calendar-view,
  .marketplace-view,
  .ai-panel,
  .modal-content {
    animation: none !important;
    transition: none !important;
  }
}

@media (max-width: 900px) {
  .deal-metrics-row {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  }
  .deal-address-primary,
  .deal-address-row,
  .deal-address-meta {
    grid-template-columns: 1fr;
  }
  .deal-address-primary .stage-button,
  .deal-address-row .stage-button {
    width: 100%;
  }
}

.contact-role-controls select{
  flex:1;
}

.contact-help-text{
  margin-top:8px;
  font-size:12px;
  opacity:.75;
}
.contacts-toolbar .contacts-filter{min-width:220px}
.contacts-toolbar .contacts-search{flex:1;min-width:240px}
.contacts-toolbar .contacts-select{min-width:320px}
.contacts-toolbar .contacts-sort{min-width:200px}
.contacts-toolbar .contacts-sort-toggle{min-width:160px; height:44px}
.contacts-danger{
  margin-left:auto;
  display:flex;
  align-items:center;
}
.contacts-danger .delete-button{
  padding:10px 14px;
}
.contacts-danger .delete-button:disabled{
  opacity:.45;
  cursor:not-allowed;
}
#contact-deals-wrap{
  margin-top:10px;
}

.contact-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);margin:4px 6px 0 0;font-size:13px}
.contact-chip-empty{opacity:.6}
.contact-chip-x{border:0;background:transparent;color:inherit;cursor:pointer;font-size:16px;line-height:1;padding:0;margin:0;opacity:.7}
.contact-chip-x:hover{opacity:1}
.contact-picker-list{display:flex;flex-direction:column;gap:10px}
.contact-picker-row{display:flex;justify-content:space-between;align-items:center;padding:10px;border-radius:12px;border:1px solid rgba(255,255,255,0.10);background:rgba(255,255,255,0.05)}
.contact-picker-name{font-weight:600}
.contact-picker-meta{opacity:.75;font-size:12px;margin-top:2px}
.contact-picker-empty{opacity:.7;padding:10px}
.contact-create-error{color:#ff6b6b;font-size:12px;min-height:16px}

.contact-roles{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.contact-role-list{display:flex;flex-wrap:wrap;gap:8px;min-height:34px;align-items:center}
.contact-role-actions{display:flex;gap:8px;flex-wrap:wrap}
.contact-picker-left{display:flex;flex-direction:column;gap:3px;min-width:0}

.modal-input{
  width:100%;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(20,20,28,0.7);
  color:#fff;
  outline:none;
}
.modal-input:focus{
  border-color:rgba(255,255,255,0.28);
}

.modal-status{
  flex:1;
  display:flex;
  align-items:center;
  padding-right:10px;
  opacity:0.9;
  font-size:13px;
}

.slot-wrap{
  margin-top:8px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.03);
}
#slot-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.slot-pill{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.12);
  cursor:pointer;
  font-size:13px;
}
.slot-pill:hover{
  border-color:rgba(255,255,255,0.28);
}

/* Slim Google topbar (Calendar tab) */
.google-panel-slim { padding: 10px 12px; margin: 10px 0 12px; }
.google-metrics { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.google-metric { font-size: 12px; opacity: 0.9; }
.google-menu { position: relative; }
.google-menu-pop { position: absolute; right: 0; top: 36px; display: flex; flex-direction: column; gap: 6px; padding: 10px; background: #fff; border: 1px solid rgba(0,0,0,0.12); border-radius: 10px; z-index: 50; min-width: 180px; }
.google-menu-pop.hidden { display: none; }

.google-panel-slim { border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; }
.google-badge { font-weight: 600; }
.google-range { font-size: 12px; opacity: 0.7; margin-left: 10px; }
.google-right { gap: 10px; }

.contacts-focus-linker{
  margin-top:14px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
}
.contacts-link-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr auto;
  gap:12px;
  align-items:end;
}
.contacts-link-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.contacts-link-action{
  align-items:flex-start;
  gap:8px;
}
@media (max-width: 900px){
  .contacts-link-grid{ grid-template-columns: 1fr; }
  .contacts-link-action{ align-items:stretch; }
}

.deal-contacts-panel{
  margin-top:10px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
}
.deal-contacts-header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.deal-contacts-title{
  font-weight:700;
  font-size:14px;
}
.deal-contacts-sub{
  font-size:12px;
  opacity:0.7;
  margin-top:4px;
}
.deal-contacts-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.deal-contacts-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:12px;
}
.deal-contacts-role{
  border:1px solid rgba(15,118,110,0.16);
  background:rgba(255,255,255,0.85);
  border-radius:14px;
  padding:12px;
}
.deal-contacts-role-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.deal-contacts-role-title{
  font-weight:700;
  font-size:13px;
  color:var(--text);
}
.deal-contacts-role-actions{
  display:inline-flex;
  gap:8px;
}
.deal-contacts-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.contact-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(15,118,110,0.28);
  background:rgba(15,118,110,0.12);
  font-size:12px;
  font-weight:600;
  color:var(--text);
}
.contact-chip-empty{
  border-style:dashed;
  background:rgba(148,163,184,0.18);
  color:var(--muted);
}
.contact-chip-x{
  border:none;
  background:transparent;
  font-size:14px;
  cursor:pointer;
  color:var(--muted);
}
.contact-role-modal{
  width:min(460px,92vw);
}
.contact-role-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;
  margin:14px 0 6px;
}
.deal-contacts-empty{
  opacity:0.7;
  padding:10px;
  border-radius:12px;
  border:1px dashed rgba(255,255,255,0.2);
}
.deal-contact-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(0,0,0,0.12);
}
.deal-contact-main{
  display:flex;
  flex-direction:column;
  gap:4px;
  flex:1;
  min-width:0;
}
.deal-contact-name{
  font-weight:600;
  font-size:14px;
}
.deal-contact-meta{
  font-size:12px;
  opacity:0.7;
}
.deal-contact-role{
  font-size:12px;
  font-weight:600;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.06);
  white-space:nowrap;
}
.deal-contact-remove{
  border:0;
  background:rgba(255,255,255,0.08);
  color:inherit;
  border-radius:10px;
  padding:6px 10px;
  cursor:pointer;
}
.deal-contact-remove:hover{
  background:rgba(255,255,255,0.16);
}
@media (max-width: 900px){
  .deal-contact-item{ flex-direction:column; align-items:flex-start; }
  .deal-contact-role{ align-self:flex-start; }
}

@media (min-width: 1100px){
  .app-body{ padding:40px 56px 64px; }
  .app-header{ padding:26px 32px; }
  .app-header h1{ font-size:24px; }
  .dashboard-main{ gap:28px; }
  .top-tabs{ padding:18px 20px; }
  .controls-panel{ padding:18px 20px; gap:18px; }
  .modal-content{ padding:20px; }
  .modal-field{ margin:12px 0; }
  .modal-form{ gap:18px; }
  .contacts-layout{ grid-template-columns:minmax(0, 1fr) minmax(320px, 380px); }
}
