/*
Theme Name: NVBareBones
Theme URI: https://novavisiongrp.com
Author: Novavision Group
Author URI: https://novavisiongrp.com
Description: A barebones WordPress theme.
Version: 2.0.0
License: GPL-2.0+
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: my-custom-theme
Since 20251217 by JESR.
*/

/* -- BEGIN: Font Styles -- */
/* -- Ref: https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-weight -- */

/* ============================================================
   Invoices page — scoped overrides
   ============================================================ */

.invoices-page .nav-tabs { border-bottom: 1px solid #dee2e6; }
.invoices-page .nav-tabs .nav-link { color: #495057; background-color: #fff; border: 1px solid #dee2e6; border-bottom-color: transparent; border-radius: 4px 4px 0 0; margin-right: 2px; }
.invoices-page .nav-tabs .nav-link:hover { background-color: #f8f9fa; border-color: #dee2e6; color: #212529; }
.invoices-page .nav-tabs .nav-link.active { color: #212529; background-color: #fff; border-color: #dee2e6 #dee2e6 #fff; font-weight: 600; }
.invoices-page .invoice-card { border: 1px solid #dee2e6; border-left: 4px solid #f5c400; border-radius: 4px; overflow: hidden; }
.invoices-page .invoice-card.status-paid    { border-left-color: #198754; }
.invoices-page .invoice-card.status-unpaid  { border-left-color: #dc3545; }
.invoices-page .invoice-card.status-partial { border-left-color: #f5c400; }
.invoices-page .invoice-card.status-neutral { border-left-color: #adb5bd; }
.invoices-page .invoice-card-header { background-color: #f8f9fa; border-bottom: 1px solid #dee2e6; cursor: pointer; user-select: none; }
.invoices-page .invoice-card-header:hover { background-color: #f0f0f0; }
.invoices-page .invoice-pending-label { color: #212529; font-weight: 700; }
.invoices-page .btn-payment { background-color: #fff; border: 1px solid #6c757d; color: #212529; white-space: nowrap; }
.invoices-page .btn-payment:hover { background-color: #f8f9fa; border-color: #495057; color: #212529; }
.invoices-page .payment-history-toggle { background-color: #f0f0f0; border: 1px solid #dee2e6; color: #212529; font-weight: 600; text-align: left; width: 100%; padding: 10px 14px; display: flex; justify-content: space-between; align-items: center; cursor: pointer; }
.invoices-page .payment-history-toggle:hover { background-color: #e9ecef; }
.invoices-page .fee-row { border-top: 1px solid #dee2e6; padding-top: 12px; padding-bottom: 12px; }
.invoices-page .balance-due { color: #dc3545; font-weight: 600; }

/* ===== INVOICES PAGE ===== */

.color-inprogress-div {
  border-left: 5px solid #f5c400 !important;
}

.accordion-button:not(.collapsed),
.accordion-button {
  background-color: #f0f0f0 !important;
  color: #000000 !important;
  box-shadow: none !important;
}

[id^="accordionHistory-"] .accordion-button:not(.collapsed),
[id^="accordionHistory-"] .accordion-button {
  background-color: #e2e6ea !important;
  color: #000000 !important;
  font-weight: 600 !important;
  box-shadow: none !important;
}

#myTab .nav-link {
  color: #555555 !important;
}

#myTab .nav-link.active {
  color: #000000 !important;
  font-weight: 600 !important;
}

.row-shadow {
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  border-radius: 4px;
}

.accordion-button::after {
  filter: none !important;
}
/* ===== INVOICES - RESPONSIVE MOBILE FIX ===== */
@media (max-width: 768px) {
  #accordionFlushCurrent .accordion-button .row,
  [id^="accordionFlush"] .accordion-button .row {
    flex-direction: column !important;
    gap: 4px;
  }

  #accordionFlushCurrent .accordion-button .row > div,
  [id^="accordionFlush"] .accordion-button .row > div {
    width: 100% !important;
    flex: none !important;
    justify-content: flex-start !important;
  }

  #accordionFlushCurrent .accordion-button .h3-header,
  [id^="accordionFlush"] .accordion-button .h3-header {
    font-size: 13px !important;
    margin: 0 !important;
    line-height: 1.3;
  }

  #accordionFlushCurrent .accordion-button,
  [id^="accordionFlush"] .accordion-button {
    padding: 12px 16px !important;
    align-items: flex-start !important;
  }
}

/* ============================================================
   INVOICES PAGE — MOBILE RESPONSIVE (≤768px)
   ============================================================ */

/* 1. Year tabs: wrap horizontally, compact */
@media (max-width: 768px) {
  .invoices-page .nav-tabs {
    flex-wrap: wrap;
    gap: 2px;
  }
  .invoices-page .nav-tabs .nav-item {
    flex: 1 1 auto;
    text-align: center;
  }
  .invoices-page .nav-tabs .nav-link {
    padding: 6px 8px;
    font-size: 13px;
    white-space: nowrap;
  }
}

/* 2. Invoice card header: stack date above invoice row on mobile */
@media (max-width: 768px) {
  .invoices-page .invoice-card-header {
    flex-wrap: wrap;
    gap: 6px 0;
    padding: 10px 12px;
  }
  .invoices-page .invoice-card-header .inv-date {
    min-width: auto !important;
    flex: 0 0 auto;
  }
  .invoices-page .invoice-card-header .inv-number {
    flex: 1 1 auto;
    text-align: left;
    font-size: 14px;
  }
  .invoices-page .invoice-pending-label {
    min-width: 100% !important;
    text-align: left !important;
    font-size: 14px;
    order: 3;
  }
  .invoices-page .invoice-card-header .collapse-icon {
    order: 2;
    align-self: flex-start;
    margin-top: 2px;
  }
}

/* 3. Fee rows: stack columns vertically, full width */
@media (max-width: 768px) {
  .invoices-page .fee-row.row {
    flex-direction: column;
    gap: 8px;
  }
  .invoices-page .fee-row.row > [class*="col-"] {
    width: 100% !important;
    max-width: 100% !important;
    flex: none;
  }
  .invoices-page .fee-row .input-group {
    max-width: 100% !important;
  }
}

/* 4. Make a Payment button: full width on mobile so text doesn't wrap */
@media (max-width: 576px) {
  .invoices-page .btn-payment {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .invoices-page .fee-row .input-group {
    flex-wrap: nowrap;
  }
}

/* 5. Payment History table: tighten columns, prevent cell wrapping */
@media (max-width: 768px) {
  .invoices-page #payment-history-13165 table {
    font-size: 13px;
  }
  .invoices-page #payment-history-13165 table td:nth-child(1) {
    width: 45%;
    word-break: break-word;
  }
  .invoices-page #payment-history-13165 table td:nth-child(2) {
    width: 30%;
    text-align: center;
    white-space: nowrap;
  }
  .invoices-page #payment-history-13165 table td:nth-child(3) {
    width: 25%;
    text-align: right;
    white-space: nowrap;
  }
}

/* 6. Card body padding reduction on mobile */
@media (max-width: 768px) {
  .invoices-page .invoice-card > .collapse > .p-3 {
    padding: 12px !important;
  }
}

/* Year tabs: stack vertically one per row at ≤575px */
@media (max-width: 575px) {
  #invoiceYearTabs {
    flex-direction: column !important;
    border-bottom: none;
  }
  #invoiceYearTabs .nav-item {
    flex: none;
    width: 100%;
  }
  #invoiceYearTabs .nav-link {
    width: 100%;
    border-radius: 4px !important;
    border: 1px solid #dee2e6 !important;
    border-bottom-color: #dee2e6 !important;
    margin-bottom: 2px;
  }
  #invoiceYearTabs .nav-link.active {
    border-color: #dee2e6 !important;
    background-color: #1B2B4B !important;
    color: #fff !important;
  }
}


/* ============================================================
   INVOICES2 PAGE — Modernized Bootstrap 5 styles
   ============================================================ */
/* Override theme blue tones back to neutral grey */
.invoices2-page .bg-light { background-color: #f5f5f5 !important; }
.invoices2-page .text-muted { color: #6c757d !important; }

.invoices2-page p { color: #212529; }
.invoices2-page .invoice-card { border-radius: 10px !important; overflow: hidden; transition: box-shadow 0.2s ease; }
.invoices2-page .invoice-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.1) !important; }
.invoices2-page #invoiceYearTabs .nav-link { color: #495057; border: none; font-size: 14px; }
.invoices2-page #invoiceYearTabs .nav-link:hover { background-color: rgba(255,255,255,0.6); color: #212529; }
.invoices2-page #invoiceYearTabs .nav-link.active { background-color: #fff; color: #212529; box-shadow: 0 1px 4px rgba(0,0,0,0.12); font-weight: 600; }
.invoices2-page .payment-history-toggle { background-color: #f0f0f0; border: 1px solid #dee2e6; color: #212529; font-weight: 600; text-align: left; width: 100%; padding: 10px 14px; display: flex; justify-content: space-between; align-items: center; cursor: pointer; border-radius: 6px; }
.invoices2-page .payment-history-toggle:hover { background-color: #e9ecef; }
.invoices2-page .fee-row { border-top: 1px solid #dee2e6; padding-top: 12px; padding-bottom: 12px; }
.invoices2-page .balance-due { color: #dc3545; font-weight: 600; }

@media (max-width: 768px) {
  .invoices2-page .invoice-card-header { flex-wrap: wrap; gap: 6px 0; padding: 10px 12px; }
  .invoices2-page .invoice-card-header .inv-date { min-width: auto !important; flex: 0 0 auto; }
  .invoices2-page .invoice-pending-label { min-width: 100% !important; text-align: left !important; font-size: 14px; order: 3; }
  .invoices2-page .fee-row.row { flex-direction: column; gap: 8px; }
  .invoices2-page .fee-row.row > [class*="col-"] { width: 100% !important; max-width: 100% !important; flex: none; }
}



/* ============================================================
   FORMS PAGE — original client-dashboard styles
   ============================================================ */
.h3-header, .status-header { font-weight: 700; color: #1F2F47; }
.accordion-item { border-top: 1px solid rgba(0,0,0,.125) !important; }
.color-completed-div { border-left: 24px solid #0A7A06; }
.color-disabled-div  { border-left: 24px solid #757575; }
.color-inprogress-div { border-left: 24px solid #FFD110; }
.color-fillout-div   { border-left: 24px solid #BF0606; }
.accordion-button:focus { box-shadow: none; }
.accordion-button:not(.collapsed) { color: black; background-color: #E3E4E5; }
.accordion-button:not(.collapsed)::after { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e") !important; }
.line-accordion:not(:last-child) { border-bottom: 1px solid #000; }
.row-shadow { box-shadow: 11px 11px 17px -5px rgba(87,87,87,1); }
.btn-kl { border: 1px solid transparent; line-height: 1.5; background-color: #1F2F47; font-weight: 700; color: white !important; border-radius: 12px; padding: 2.5px 10px; margin-top: 7px; }
@media only screen and (min-width: 1024px) { #sectionMain { min-height: 480px; } }
@media only screen and (max-width: 480px) {
  .color-completed-div { border-left: 12px solid #0A7A06; }
  .color-inprogress-div { border-left: 12px solid #FFD110; }
  .color-fillout-div { border-left: 12px solid #BF0606; }
}
