/* ============================================================
   Davila Construction — App CSS
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --bg:      #0D1B2A;
    --mid:     #1B2E40;
    --card:    #1E3448;
    --border:  rgba(255,255,255,.08);
    --text:    #F1F5F9;
    --sub:     rgba(255,255,255,.45);
    --accent:  #E8A020;
    --green:   #1D9E75;
    --blue:    #2E6DA4;
    --red:     #DC2626;
    --amber:   #F59E0B;
}

body { background: var(--bg); color: var(--text); font-family: 'Inter', system-ui, sans-serif; font-size: .9375rem; line-height: 1.5; }

a { color: inherit; }

/* ── Layout ──────────────────────────────────────────────── */
.app-layout { display: grid; grid-template-columns: 220px 1fr; min-height: 100vh; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar {
    background: var(--mid);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    padding: 0;
    position: sticky;
    top: 0;
    height: 100vh;
}

.sidebar__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 20px 16px;
    border-bottom: 1px solid var(--border);
}

.sidebar__logo { font-size: 1.5rem; }
.sidebar__name { font-size: .9375rem; font-weight: 800; }
.sidebar__sub  { font-size: .72rem; color: var(--sub); }

.sidebar__nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 16px;
    color: var(--sub);
    text-decoration: none;
    font-size: .875rem;
    font-weight: 600;
    transition: .12s;
    border-left: 3px solid transparent;
}

.sidebar__nav-link:hover { color: var(--text); background: rgba(255,255,255,.04); }
.sidebar__nav-link--active { color: var(--accent); border-color: var(--accent); background: rgba(232,160,32,.06); }
.sidebar__nav-icon { font-size: 1rem; }

.sidebar__footer {
    margin-top: auto;
    padding: 14px 16px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.sidebar__user   { font-size: .8125rem; font-weight: 600; }
.sidebar__logout { background: none; border: 1px solid var(--border); border-radius: 6px; padding: 5px 10px; color: var(--sub); cursor: pointer; font-size: .75rem; transition: .12s; }
.sidebar__logout:hover { color: var(--text); border-color: rgba(255,255,255,.2); }

/* ── Main content ────────────────────────────────────────── */
.main-content { padding: 24px 28px; max-width: 1400px; }

/* ── Flash ───────────────────────────────────────────────── */
.flash { padding: 12px 16px; border-radius: 10px; border: 1px solid; margin-bottom: 16px; font-size: .875rem; }
.flash--success { background: rgba(29,158,117,.1); border-color: rgba(29,158,117,.3); color: #34D399; }
.flash--error   { background: rgba(220,38,38,.1);  border-color: rgba(220,38,38,.3);  color: #F87171; }

/* ── Page header ─────────────────────────────────────────── */
.page-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 20px; }
.page-title  { font-size: 1.5rem; font-weight: 900; letter-spacing: -.03em; }
.page-sub    { font-size: .8125rem; color: var(--sub); margin-top: 3px; }
.header-actions { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }

/* ── Stat cards ──────────────────────────────────────────── */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 20px; }
.stat-grid--5 { grid-template-columns: repeat(5, 1fr); }

.stat-card {
    padding: 18px 20px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: var(--card);
}

.stat-card--green { border-color: rgba(29,158,117,.3); background: linear-gradient(160deg,rgba(29,158,117,.1),var(--card)); }
.stat-card--blue  { border-color: rgba(46,109,164,.3); background: linear-gradient(160deg,rgba(46,109,164,.1),var(--card)); }
.stat-card--amber { border-color: rgba(245,158,11,.3); background: linear-gradient(160deg,rgba(245,158,11,.08),var(--card)); }

.stat-card__icon  { font-size: 1.25rem; margin-bottom: 6px; }
.stat-card__val   { font-size: 1.625rem; font-weight: 900; letter-spacing: -.03em; }
.stat-card__label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--sub); margin-top: 5px; }

/* ── Cards ───────────────────────────────────────────────── */
.card { background: var(--card); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; margin-bottom: 14px; }
.card__header { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.card__title  { font-size: 1rem; font-weight: 800; }
.empty { padding: 32px; text-align: center; color: var(--sub); }

/* ── Buttons ─────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 9px 18px; border-radius: 8px; border: 1px solid transparent; font-size: .875rem; font-weight: 600; cursor: pointer; text-decoration: none; transition: .12s; line-height: 1; }
.btn--primary { background: var(--accent); color: #0D1B2A; border-color: var(--accent); }
.btn--primary:hover { background: #d4911c; }
.btn--ghost   { background: rgba(255,255,255,.05); border-color: var(--border); color: var(--sub); }
.btn--ghost:hover { color: var(--text); background: rgba(255,255,255,.1); }
.btn--sm      { padding: 6px 12px; font-size: .8125rem; }
.btn--xs      { padding: 4px 8px; font-size: .75rem; }
.btn--danger  { color: rgba(220,38,38,.7); }
.btn--danger:hover { color: #F87171; border-color: rgba(220,38,38,.3); }

/* ── Badges ──────────────────────────────────────────────── */
.badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 20px; font-size: .72rem; font-weight: 700; border: 1px solid transparent; }
.badge--green { background: rgba(29,158,117,.15); color: #34D399; border-color: rgba(29,158,117,.3); }
.badge--blue  { background: rgba(46,109,164,.15); color: #93C5FD; border-color: rgba(46,109,164,.3); }
.badge--amber { background: rgba(245,158,11,.12); color: #FBBF24; border-color: rgba(245,158,11,.2); }
.badge--gray  { background: rgba(255,255,255,.06); color: var(--sub); border-color: var(--border); }
.badge--red   { background: rgba(220,38,38,.12);  color: #F87171; border-color: rgba(220,38,38,.2); }

.link { color: #93C5FD; text-decoration: none; }
.link:hover { text-decoration: underline; }

/* ── Forms ───────────────────────────────────────────────── */
.form-card  { padding: 24px; }
.form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.form-label { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--sub); }
.form-input { padding: 10px 13px; border-radius: 8px; border: 1px solid var(--border); background: rgba(255,255,255,.05); color: var(--text); font-size: .9375rem; font-family: inherit; transition: .12s; width: 100%; }
.form-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(232,160,32,.15); }
textarea.form-input { resize: vertical; min-height: 80px; }
select.form-input option { background: var(--mid); }
.form-footer { display: flex; gap: 10px; justify-content: flex-end; padding-top: 14px; border-top: 1px solid var(--border); margin-top: 8px; }

/* ── Job cards (dashboard) ───────────────────────────────── */
.job-card { background: var(--card); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; margin-bottom: 12px; }
.job-card__header { display: flex; justify-content: space-between; align-items: flex-start; padding: 16px 20px; gap: 16px; }
.job-card__num    { font-size: .75rem; color: var(--sub); font-weight: 700; margin-bottom: 3px; }
.job-card__name   { font-size: 1.0625rem; font-weight: 800; text-decoration: none; color: var(--text); }
.job-card__name:hover { color: var(--accent); }
.job-card__client { font-size: .8125rem; color: var(--sub); margin-top: 4px; }
.job-card__summary { display: flex; gap: 20px; align-items: center; }
.job-card__alert { padding: 10px 20px; background: rgba(245,158,11,.08); border-top: 1px solid rgba(245,158,11,.2); font-size: .8125rem; color: #FBBF24; }

.job-stat { text-align: center; }
.job-stat__val   { font-size: 1.25rem; font-weight: 900; }
.job-stat__label { font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; color: var(--sub); }
.job-stat--green .job-stat__val { color: #34D399; }
.job-stat--amber .job-stat__val { color: #FBBF24; }

/* ── Table (jobs list) ───────────────────────────────────── */
.table-header { display: grid; grid-template-columns: 120px 1fr 100px 80px 120px 80px; gap: 12px; padding: 10px 16px; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--sub); border-bottom: 1px solid var(--border); background: rgba(255,255,255,.02); }
.table-row    { display: grid; grid-template-columns: 120px 1fr 100px 80px 120px 80px; gap: 12px; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); transition: .1s; }
.table-row:last-child { border-bottom: none; }
.table-row:hover { background: rgba(255,255,255,.02); }
.table-row__num   { font-size: .78rem; font-weight: 700; color: var(--sub); }
.table-row__name  { font-weight: 700; }
.table-row__sub   { font-size: .75rem; color: var(--sub); margin-top: 2px; }
.table-row__center { text-align: center; font-weight: 700; }
.table-row__bold  { font-weight: 800; }

/* ── Scope rows ──────────────────────────────────────────── */
.scope-header { display: grid; grid-template-columns: 90px 1fr 55px 100px 130px 220px; gap: 10px; padding: 10px 16px; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--sub); border-bottom: 1px solid var(--border); background: rgba(255,255,255,.02); }
.scope-row    { display: grid; grid-template-columns: 90px 1fr 55px 100px 130px 220px; gap: 10px; align-items: center; padding: 11px 16px; border-bottom: 1px solid var(--border); transition: .1s; font-size: .875rem; }
.scope-row:last-child { border-bottom: none; }
.scope-row:hover { background: rgba(255,255,255,.02); }
.scope-row--completed { background: rgba(245,158,11,.03); }
.scope-row--paid      { background: rgba(29,158,117,.03); }
.scope-type  { font-size: .75rem; color: var(--sub); font-weight: 600; text-transform: uppercase; }
.scope-main  { min-width: 0; }
.scope-label { font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.scope-desc  { font-size: .8rem; color: var(--sub); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.scope-dates { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 3px; font-size: .75rem; color: var(--sub); }
.scope-ref-inline { font-weight: 600; color: var(--accent); }
.scope-days  { font-size: .8rem; color: var(--sub); text-align: center; }
.scope-price { font-weight: 800; }
.scope-status { }
.scope-ref   { font-size: .78rem; color: var(--sub); }
.scope-date  { font-size: .7rem; color: var(--sub); margin-top: 3px; }
.scope-actions { display: flex; gap: 4px; align-items: center; }

/* ── Client rows ─────────────────────────────────────────── */
.client-row { display: grid; grid-template-columns: 1fr 1fr auto auto; gap: 12px; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.client-row:last-child { border-bottom: none; }
.client-row__name { font-weight: 700; }
.client-row__sub  { font-size: .78rem; color: var(--sub); margin-top: 2px; }
.client-row__address { font-size: .8125rem; color: var(--sub); }

/* ── Modals ──────────────────────────────────────────────── */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 100; align-items: center; justify-content: center; }
.modal-overlay.modal--open { display: flex; }
.modal { background: var(--mid); border: 1px solid var(--border); border-radius: 16px; padding: 0; width: 540px; max-width: 95vw; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.modal--wide { width: 700px; }
.modal__header { padding: 18px 20px 14px; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; justify-content: space-between; }
.modal__title  { font-size: 1.0625rem; font-weight: 800; }
.modal__sub    { font-size: .8125rem; color: var(--sub); margin-top: 3px; }
.modal__footer { padding: 14px 20px; border-top: 1px solid var(--border); display: flex; gap: 10px; justify-content: flex-end; }
.modal form { padding: 16px 20px; }
.modal-form-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }

/* ── Edit panel (job) ────────────────────────────────────── */
.edit-panel-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 150; }
.edit-panel-backdrop.open { display: block; }
.edit-panel {
    position: fixed; top: 0; right: -600px; width: 580px; max-width: 100vw; height: 100vh;
    background: var(--mid); border-left: 1px solid var(--border); z-index: 151;
    display: flex; flex-direction: column; transition: right .25s ease; overflow-y: auto; padding: 20px 24px;
}
.edit-panel.open { right: 0; }
.edit-panel__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }

/* ── Auth ────────────────────────────────────────────────── */
.auth-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: var(--bg); }
.auth-wrap  { width: 100%; max-width: 400px; padding: 20px; }
.auth-card  { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 32px 28px; }
.auth-card__header { text-align: center; margin-bottom: 28px; }
.auth-card__logo   { font-size: 2.5rem; margin-bottom: 8px; }
.auth-card__title  { font-size: 1.25rem; font-weight: 900; }
.auth-card__sub    { font-size: .8125rem; color: var(--sub); margin-top: 4px; }
.auth-field { margin-bottom: 14px; }
.auth-label { display: block; font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--sub); margin-bottom: 5px; }
.auth-input { width: 100%; padding: 10px 13px; border-radius: 8px; border: 1px solid var(--border); background: rgba(255,255,255,.05); color: var(--text); font-size: .9375rem; font-family: inherit; }
.auth-input:focus { outline: none; border-color: var(--accent); }
.auth-btn   { width: 100%; padding: 12px; border-radius: 8px; border: none; background: var(--accent); color: #0D1B2A; font-size: 1rem; font-weight: 700; cursor: pointer; margin-top: 8px; }

@media (max-width: 900px) {
    .stat-grid { grid-template-columns: repeat(2, 1fr); }
    .stat-grid--5 { grid-template-columns: repeat(3, 1fr); }
}

/* ── Job reference fields ─────────────────────────────────── */
.form-section-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--sub); padding: 14px 0 6px; border-top: 1px solid var(--border); margin-top: 8px; }
.form-hint-inline   { font-size: .75rem; font-weight: 400; color: var(--sub); text-transform: none; letter-spacing: 0; margin-left: 4px; }
.page-sub--refs     { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 4px; font-size: .8rem; color: var(--sub); }
.page-sub--refs span { display: flex; gap: 4px; align-items: center; }

/* ── Rent Roll ────────────────────────────────────────────── */
.rr-pricing-grid  { padding: 0 18px; display: flex; flex-direction: column; gap: 8px; }
.rr-pricing-row   { display: grid; grid-template-columns: 1fr 160px; gap: 12px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--border); }
.rr-pricing-row:last-child { border-bottom: none; }
.rr-fp-name       { display: flex; align-items: center; gap: 10px; font-weight: 600; }
.rr-fp-meta       { font-size: .78rem; color: var(--sub); font-weight: 400; }
.rr-fp-price      { display: flex; align-items: center; gap: 6px; }
.rr-import-row    { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; padding: 18px; }
.rr-table-wrap    { overflow-x: auto; }
.rr-header        { display: grid; grid-template-columns: 80px 80px 100px 80px 70px 90px 90px 40px; gap: 8px; padding: 8px 16px; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--sub); border-bottom: 1px solid var(--border); background: rgba(255,255,255,.02); }
.rr-row           { display: grid; grid-template-columns: 80px 80px 100px 80px 70px 90px 90px 40px; gap: 8px; align-items: center; padding: 9px 16px; border-bottom: 1px solid var(--border); font-size: .875rem; }
.rr-row:last-child { border-bottom: none; }
.rr-row--assigned { opacity: .55; }
.rr-filter-tabs   { display: flex; gap: 4px; }
.rr-tab           { padding: 4px 12px; border-radius: 20px; border: 1px solid var(--border); background: none; font-size: .78rem; cursor: pointer; color: var(--sub); }
.rr-tab.active    { background: var(--accent); color: #fff; border-color: var(--accent); }
.card__footer     { padding: 14px 18px; border-top: 1px solid var(--border); }
.card__body       { padding: 18px; }
.card__sub        { font-size: .78rem; color: var(--sub); }
.text-muted       { color: var(--sub); font-size: .875rem; margin: 0; }
.card__sub        { font-size: .78rem; color: var(--sub); }

/* ── Rent Roll extras ─────────────────────────────────────── */
.rr-card            { margin-bottom: 20px; }
.rr-clear-form      { margin-top: 10px; }
.rr-unit-picker-group { display: none; }
.rr-unit-picker-group.visible { display: block; }
.rr-header-controls { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.form-input--sm     { padding: 6px 10px; font-size: .8rem; width: 200px; }

/* ── Rent Roll status rows ────────────────────────────────── */
.rr-row--available  { }
.rr-row--assigned   { background: rgba(59,130,246,.03); }
.rr-row--invoiced   { background: rgba(245,158,11,.03); }
.rr-row--paid       { background: rgba(29,158,117,.04); opacity: .75; }
.rr-stat            { font-weight: 600; }
.rr-stat--available { color: var(--sub); }
.rr-stat--assigned  { color: #3B82F6; }
.rr-stat--invoiced  { color: #D97706; }
.rr-stat--paid      { color: #1D9E75; }

/* ── Subcontractors ───────────────────────────────────────── */
.sub-header  { display: grid; grid-template-columns: 1fr 120px 1fr 60px 120px 80px 140px; gap: 10px; padding: 8px 16px; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--sub); border-bottom: 1px solid var(--border); background: rgba(255,255,255,.02); }
.sub-row     { display: grid; grid-template-columns: 1fr 120px 1fr 60px 120px 80px 140px; gap: 10px; align-items: center; padding: 11px 16px; border-bottom: 1px solid var(--border); font-size: .875rem; }
.sub-row:last-child { border-bottom: none; }
.sub-row:hover { background: rgba(255,255,255,.02); }
.sub-row > div { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sub-name    { font-weight: 600; }
.sub-actions { display: flex; gap: 6px; align-items: center; }
.sub-actions > button { padding: 4px 8px; font-size: .8rem; }