.dt-tabs { display: flex; gap: 8px; margin-bottom: 18px; }
.dt-tab { flex: 1; padding: 10px; border-radius: 10px; border: 1.5px solid var(--c-border); background: var(--c-bg2); color: var(--c-text2); font-size: 13px; font-weight: 700; cursor: pointer; transition: all .15s; font-family: 'Lato', sans-serif; }
.dt-tab[data-person="her"]:hover { border-color: var(--c-her); color: var(--c-her); }
.dt-tab[data-person="his"]:hover { border-color: var(--c-his); color: var(--c-his); }
.dt-tab[data-person="her"].active { background: var(--c-her); border-color: var(--c-her); color: #fff; }
.dt-tab[data-person="his"].active { background: var(--c-his); border-color: var(--c-his); color: #fff; }

.dt-section { margin-bottom: 28px; }
.dt-section-hidden { display: none; }

.dt-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 12px; border: 1px solid var(--c-border); box-shadow: 0 2px 8px rgba(107,66,38,.05); }
.dt-table { width: 100%; border-collapse: collapse; font-size: 12px; }

.dt-head-row th { padding: 9px 12px; background: var(--c-bg2); color: var(--c-text2); font-weight: 700; font-size: 10px; text-transform: uppercase; letter-spacing: 0.8px; border-bottom: 1.5px solid var(--c-border); text-align: left; white-space: nowrap; }

.dt-month-row .dt-month-cell { padding: 6px 12px; background: var(--c-bg3); color: var(--c-his); font-size: 11px; font-weight: 700; border-bottom: 1px solid var(--c-border); border-top: 1px solid var(--c-border); }

.dt-tx-row td { padding: 9px 12px; border-bottom: 1px solid var(--c-bg3); vertical-align: middle; }
.dt-tx-row:hover td { background: var(--c-bg2); }

.dt-cell-date { white-space: nowrap; color: var(--c-text2); font-weight: 600; min-width: 52px; }
.dt-cell-amount { font-family: 'Playfair Display', Georgia, serif; font-weight: 700; white-space: nowrap; text-align: right; }
.dt-cell-wallet { color: var(--c-text2); white-space: nowrap; font-size: 11px; }
.dt-cell-note { color: var(--c-text3); font-style: italic; max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dt-cell-actions { white-space: nowrap; text-align: right; padding-right: 10px; }

.dt-btn-edit { width: 24px; height: 24px; border-radius: 6px; border: 1px solid var(--c-border); background: var(--c-bg); color: var(--c-her); font-size: 13px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all .15s; }
.dt-btn-edit:hover { background: var(--c-her-light); border-color: var(--c-her); }
.dt-btn-del { width: 24px; height: 24px; border-radius: 6px; border: 1px solid var(--c-border); background: var(--c-bg); color: var(--c-text3); font-size: 10px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all .15s; margin-left: 4px; }
.dt-btn-del:hover { background: #FEE2E2; border-color: #FCA5A5; color: #C94040; }

.dt-subtotal-row td { padding: 6px 12px; background: var(--c-bg2); border-top: 1.5px solid var(--c-border); border-bottom: 1px solid var(--c-border); }
.dt-cell-subtotal-label { font-size: 10px; color: var(--c-text3); font-style: italic; }
.dt-cell-subtotal-val { font-family: 'Playfair Display', Georgia, serif; font-size: 13px; font-weight: 700; text-align: right; }

.dt-total-row td { padding: 10px 12px; background: var(--c-bg2); border-top: 2px solid var(--c-border); }
.dt-total-label { font-size: 12px; font-weight: 700; color: var(--c-text); }
.dt-total-val { font-family: 'Playfair Display', Georgia, serif; font-size: 15px; font-weight: 700; text-align: right; }

.dt-empty { text-align: center; padding: 32px 20px; color: var(--c-text3); font-size: 13px; line-height: 1.8; border: 1px dashed var(--c-border); border-radius: 12px; }

@media (max-width: 480px) {
  .dt-hide-mobile { display: none; }
}

/* FAB */
.daily-fab { position: fixed; bottom: 80px; right: 20px; width: 52px; height: 52px; border-radius: 50%; background: linear-gradient(135deg, var(--c-her), var(--c-her-mid)); border: none; color: #fff; font-size: 28px; line-height: 1; cursor: pointer; box-shadow: 0 4px 18px rgba(0,0,0,.22); z-index: 900; display: flex; align-items: center; justify-content: center; transition: transform .15s; }
.daily-fab:hover { transform: scale(1.08); }

@media (min-width: 540px) {
  .daily-fab { bottom: 24px; right: 24px; }
}

/* Modal */
.daily-modal { position: fixed; inset: 0; z-index: 9998; background: rgba(0,0,0,.6); display: flex; align-items: flex-end; justify-content: center; opacity: 0; pointer-events: none; transition: opacity .25s ease; }
.daily-modal.active { opacity: 1; pointer-events: auto; }
.daily-modal-panel { background: var(--c-bg); border-radius: 22px 22px 0 0; width: 100%; max-width: 540px; max-height: 92vh; overflow-y: auto; padding: 20px 20px 32px; transform: translateY(30px); transition: transform .25s ease; }
.daily-modal.active .daily-modal-panel { transform: translateY(0); }
.daily-modal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.daily-modal-title { font-size: 15px; font-weight: 700; color: var(--c-his); }
.daily-modal-close { background: var(--c-bg2); border: 1px solid var(--c-border); border-radius: 8px; padding: 5px 12px; font-size: 13px; color: var(--c-text2); cursor: pointer; }

@media (min-width: 540px) {
  .daily-modal { align-items: center; }
  .daily-modal-panel { border-radius: 20px; max-height: 85vh; }
}

/* Form */
.daily-form-row { margin-bottom: 13px; }
.daily-form-label { display: block; font-size: 10px; font-weight: 700; color: var(--c-text2); margin-bottom: 5px; text-transform: uppercase; letter-spacing: 1px; }
.daily-form-input { width: 100%; padding: 10px 12px; background: var(--c-bg2); border: 1.5px solid var(--c-border); border-radius: 10px; color: var(--c-text); font-family: 'Lato', sans-serif; font-size: 14px; box-sizing: border-box; outline: none; }
.daily-form-input:focus { border-color: var(--c-her); }
.daily-form-select { width: 100%; padding: 10px 12px; background: var(--c-bg2); border: 1.5px solid var(--c-border); border-radius: 10px; color: var(--c-text); font-family: 'Lato', sans-serif; font-size: 14px; outline: none; }
.daily-form-select:focus { border-color: var(--c-her); }

.daily-form-row-check { display: flex; align-items: center; }
.daily-form-check-label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--c-text2); cursor: pointer; }
.daily-form-check-label input[type="checkbox"] { accent-color: var(--c-her); width: 15px; height: 15px; }

.daily-wallet-row { display: flex; gap: 8px; align-items: center; }
.daily-wallet-select { flex: 1; }
.daily-add-wallet-btn { width: 36px; height: 40px; border-radius: 10px; border: 1.5px solid var(--c-border); background: var(--c-bg2); color: var(--c-her); font-size: 20px; font-weight: 700; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center; line-height: 1; }

.daily-wallet-add-row { display: flex; gap: 8px; margin-top: 8px; }
.daily-wallet-add-row.hidden { display: none; }
.daily-wallet-add-row .daily-form-input { flex: 1; }
.daily-wallet-add-row button { padding: 8px 14px; border-radius: 8px; border: 1.5px solid var(--c-border); background: var(--c-bg2); color: var(--c-text2); font-size: 13px; cursor: pointer; white-space: nowrap; }
.daily-wallet-add-row button:first-of-type { background: var(--c-her); border-color: var(--c-her); color: #fff; }

.df-amount-wrap { display: flex; gap: 8px; align-items: center; }
.df-amount-input { flex: 1; }
.df-sign-btn { width: 40px; height: 42px; border-radius: 10px; border: 1.5px solid var(--c-border); font-size: 18px; font-weight: 700; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all .15s; }
.df-sign-btn.positive { background: var(--c-bg2); color: var(--c-his); border-color: var(--c-his); }
.df-sign-btn.negative { background: #FEE2E2; color: #C94040; border-color: #FCA5A5; }

.daily-form-save-btn { width: 100%; padding: 13px; margin-top: 6px; background: linear-gradient(135deg, var(--c-his), var(--c-his-mid)); border: none; border-radius: 12px; color: #fff; font-size: 14px; font-weight: 700; cursor: pointer; }
