/* =====================================================
   FRAPPE PORTAL RFQ — MOBILE FIX (Pure CSS)
   ===================================================== */

div.row[id^="page-"] *, div.row[id^="page-"] *::before, div.row[id^="page-"] *::after {
  box-sizing: border-box;
}

@media (max-width: 768px) {

  div.row[id^="page-"] {
    margin-left: 0 !important;
    margin-right: 0 !important;
    overflow-x: hidden;
    display: block !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* === SIDEBAR === */
  div.row[id^="page-"] > .sidebar-column {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding: 8px 14px !important;
  }

  div.row[id^="page-"] .web-sidebar {
    background: #f1f5f9;
    border-radius: 10px;
    padding: 8px 10px !important;
    margin-bottom: 12px;
    border: none !important;
  }

  div.row[id^="page-"] .sidebar-items ul {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 5px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
  }

  div.row[id^="page-"] .sidebar-item {
    flex: 1 1 auto !important;
  }

  div.row[id^="page-"] .sidebar-item a {
    display: block !important;
    padding: 5px 10px !important;
    font-size: 12px !important;
    border-radius: 20px !important;
    border: 1px solid #cbd5e1 !important;
    background: #fff !important;
    color: #475569 !important;
    white-space: nowrap !important;
    text-align: center !important;
    text-decoration: none !important;
  }

  div.row[id^="page-"] .sidebar-item a.active,
  div.row[id^="page-"] .sidebar-item a:hover {
    background: #4f46e5 !important;
    color: #fff !important;
    border-color: #4f46e5 !important;
  }

  /* === MAIN COLUMN === */
  div.row[id^="page-"] > .main-column {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding: 0 14px !important;
  }

  div.row[id^="page-"] main.container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-top: 8px !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  /* Fix: breadcrumb container was eating left space */
  div.row[id^="page-"] .breadcrumb-container.container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  div.row[id^="page-"] .my-account-header {
    padding-left: 4px !important;
}

  div.row[id^="page-"] ol.breadcrumb {
    font-size: 12px !important;
    padding: 0 !important;
    margin-bottom: 10px !important;
    background: none !important;
    flex-wrap: wrap !important;
    margin-left: 0 !important;
  }

  /* === PAGE HEADER === */
  div.row[id^="page-"] .page-header-wrapper {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
  }

  div.row[id^="page-"] .page-header h1 {
    font-size: 20px !important;
    margin: 0 !important;
    word-break: break-word !important;
    line-height: 1.3 !important;
  }

  div.row[id^="page-"] .page-header-actions-block {
    width: 100% !important;
    margin: 0 !important;
  }

  div.row[id^="page-"] .page-header-actions-block .btn {
    display: block !important;
    width: 100% !important;
    padding: 11px 16px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    text-align: center !important;
  }

  /* === VENDOR + DATE ROW === */
  div.row[id^="page-"] .rfq-content > .row:first-child {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .rfq-content > .row:first-child > .col-6 {
    flex: 0 0 auto !important;
    max-width: 55% !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .rfq-content > .row:first-child > .col-6:last-child {
    max-width: 45% !important;
    text-align: right !important;
  }

  /* === HIDE DESKTOP HEADERS === */
  div.row[id^="page-"] .cart-item-header,
  div.row[id^="page-"] #rfq-items > hr {
    display: none !important;
  }

  /* =====================================================
     RFQ ITEM CARD
     Row 1: [48px image] [name + long description]
     Row 2: [QTY]  [RATE]  [AMOUNT — ₹ + number inline]
     ===================================================== */

  div.row[id^="page-"] .rfq-item {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 12px !important;
    margin-bottom: 10px !important;
    overflow: hidden;
  }

  div.row[id^="page-"] .rfq-item > .row {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    grid-template-rows: auto auto !important;
    column-gap: 0 !important;
    row-gap: 0 !important;
    margin: 0 !important;
  }

  /* Row 1: product — full width */
  div.row[id^="page-"] .rfq-item > .row > .col-sm-5 {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    padding: 0 0 10px 0 !important;
    margin: 0 !important;
    border-bottom: 1px solid #e2e8f0;
  }

  /* Inner image+text row: flex row, no wrapping */
  div.row[id^="page-"] .rfq-item .col-sm-5 > .row {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    /* reset grid placement from parent override */
    grid-column: unset !important;
    grid-row: unset !important;
  }

  /* Image: fixed 48px */
  div.row[id^="page-"] .rfq-item .col-sm-5 > .row > .col-3 {
    flex: 0 0 48px !important;
    width: 48px !important;
    max-width: 48px !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .website-image {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    border-radius: 6px !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
  }

  /* Text: fills remaining width, wraps long descriptions */
  div.row[id^="page-"] .rfq-item .col-sm-5 > .row > .col-9 {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: 0 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
  }

  div.row[id^="page-"] .rfq-item .col-9 .text-muted.small {
    font-size: 12px !important;
    margin: 2px 0 0 !important;
    line-height: 1.5 !important;
    display: block !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
  }

  div.row[id^="page-"] .rfq-item .supplier-part-no {
    font-size: 11px !important;
    margin: 2px 0 0 !important;
  }

  /* === Row 2: QTY col 1 === */
  div.row[id^="page-"] .rfq-item > .row > .col-sm-2:nth-of-type(2) {
    grid-column: 1 !important;
    grid-row: 2 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    text-align: center !important;
    padding: 10px 4px 0 !important;
  }

  /* === Row 2: RATE col 2 — dividers on both sides === */
  div.row[id^="page-"] .rfq-item > .row > .col-sm-2:nth-of-type(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    text-align: center !important;
    padding: 10px 4px 0 !important;
    border-left: 1px solid #e2e8f0 !important;
    border-right: 1px solid #e2e8f0 !important;
  }

  /* === Row 2: AMOUNT col 3 === */
  div.row[id^="page-"] .rfq-item > .row > .col-sm-3 {
    grid-column: 3 !important;
    grid-row: 2 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    text-align: center !important;
    padding: 10px 4px 0 !important;
    /* critical: override grid display set by parent */
    display: block !important;
  }

  /* Field labels */
  div.row[id^="page-"] .rfq-item > .row > .col-sm-2:nth-of-type(2)::before {
    content: "Qty";
    display: block;
    font-size: 10px;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
    font-weight: 600;
  }

  div.row[id^="page-"] .rfq-item > .row > .col-sm-2:nth-of-type(3)::before {
    content: "Rate";
    display: block;
    font-size: 10px;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
    font-weight: 600;
  }

  div.row[id^="page-"] .rfq-item > .row > .col-sm-3::before {
    content: "Amount";
    display: block;
    font-size: 10px;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
    font-weight: 600;
  }

  /* Qty + Rate inputs */
  div.row[id^="page-"] .rfq-qty,
  div.row[id^="page-"] .rfq-rate {
    width: 100% !important;
    text-align: center !important;
    font-size: 13px !important;
    padding: 6px 2px !important;
    border-radius: 6px !important;
    margin-top: 0 !important;
    display: block !important;
  }

  /* UOM text under qty */
  div.row[id^="page-"] .rfq-item .col-sm-2 .text-muted.small {
    font-size: 10px !important;
    margin-top: 3px !important;
    display: block !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  /* =====================================================
     AMOUNT FIX: ₹ symbol + number on ONE line
     The HTML is:  ₹ <space> <span class="rfq-amount">
     We make the parent a flex row so they sit inline
     ===================================================== */
  div.row[id^="page-"] .rfq-item > .row > .col-sm-3 > [style*="padding-top"] {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
    gap: 2px !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
  }

  div.row[id^="page-"] .rfq-amount {
    font-size: 14px !important;
    font-weight: 700 !important;
    display: inline !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* === GRAND TOTAL === */
  div.row[id^="page-"] .grand-total-row {
    background: #eef2ff !important;
    border-radius: 8px !important;
    padding: 12px 14px !important;
    margin: 10px 0 0 0 !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
  }

  div.row[id^="page-"] .grand-total-row > [class*="col-"] {
    flex: none !important;
    width: auto !important;
    max-width: none !important;
    padding: 0 !important;
    white-space: nowrap !important;
  }

  /* === NOTES === */
  div.row[id^="page-"] .terms .col-6 {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .terms-feedback {
    width: 100% !important;
    height: 90px !important;
    border-radius: 8px !important;
  }

  /* === QUOTATION LIST CARDS === */
  div.row[id^="page-"] .web-list-item.transaction-list-item {
    position: relative !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    /* right padding makes room for the "Link" badge */
    padding: 10px 80px 10px 12px !important;
    margin-bottom: 8px !important;
  }

  div.row[id^="page-"] .transaction-list-item > .row {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .transaction-list-item .col-sm-6,
  div.row[id^="page-"] .transaction-list-item .col-sm-3 {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding: 0 !important;
    font-size: 13px !important;
    /* prevent text being hidden under badge */
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  div.row[id^="page-"] .transaction-item-link {
    position: absolute !important;
    top: 50% !important;
    right: 12px !important;
    transform: translateY(-50%) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: #4f46e5 !important;
    background: #ede9fe !important;
    border-radius: 5px !important;
    padding: 4px 10px !important;
    text-decoration: none !important;
    white-space: nowrap !important;
  }

  div.row[id^="page-"] .transaction-item-link:hover {
    background: #4f46e5 !important;
    color: #fff !important;
  }

  /* === PO ITEMS: hide header === */
  div.row[id^="page-"] .order-items.order-item-header {
    display: none !important;
  }

  /* === PO ITEMS: card === */
  div.row[id^="page-"] .order-items.align-items-center {
    display: flex !important;
    flex-wrap: wrap !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important;
    padding: 12px !important;
    margin-bottom: 10px !important;
    overflow: hidden !important;
    align-items: flex-start !important;
  }

  /* Product name: full width row 1 */
  div.row[id^="page-"] .order-items.align-items-center > .order-item-name {
    order: 0 !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 0 10px 0 !important;
    margin-bottom: 10px !important;
    border-bottom: 1px solid #e2e8f0 !important;
  }

  /* Hide Qty(1) from inside item name — d-l-n = display-large-none shown on mobile */
  div.row[id^="page-"] .order-qty {
    display: none !important;
  }

  /* Image + text — same as RFQ */
  div.row[id^="page-"] .item_name_and_description > .row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin: 0 !important;
  }

  div.row[id^="page-"] .order-image-col {
    flex: 0 0 48px !important;
    width: 48px !important;
    max-width: 48px !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .no-image-cart-item {
    width: 48px !important;
    height: 48px !important;
    min-height: 48px !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 6px !important;
  }

  div.row[id^="page-"] .item_name_and_description .col-sm-10 {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: 0 !important;
    word-break: break-word !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
  }

  div.row[id^="page-"] .item-description {
    font-size: 12px !important;
    display: block !important;
    word-break: break-word !important;
    margin-top: 2px !important;
  }

  /* QTY — show d-s-n, place as col 1 of row 2 */
  div.row[id^="page-"] .order-items.align-items-center > .d-s-n {
    display: block !important;
    order: 1 !important;
    flex: 1 1 33.33% !important;
    max-width: 33.33% !important;
    text-align: center !important;
    padding: 10px 4px 0 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    box-sizing: border-box !important;
    border-right: 1px solid #e2e8f0 !important;
  }

  /* RATE — col 2 of row 2 */
  div.row[id^="page-"] .order-items.align-items-center > .order-rate {
    order: 2 !important;
    flex: 1 1 33.33% !important;
    max-width: 33.33% !important;
    text-align: center !important;
    padding: 10px 4px 0 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    box-sizing: border-box !important;
    border-right: 1px solid #e2e8f0 !important;
  }

  /* AMOUNT — col 3 of row 2 */
  div.row[id^="page-"] .order-items.align-items-center > span:last-child {
    order: 3 !important;
    flex: 1 1 33.33% !important;
    max-width: 33.33% !important;
    text-align: center !important;
    padding: 10px 4px 0 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    box-sizing: border-box !important;
  }

  /* Labels above each col */
  div.row[id^="page-"] .order-items.align-items-center > .d-s-n::before {
    content: "Qty";
    display: block;
    font-size: 10px;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
    font-weight: 600;
  }

  div.row[id^="page-"] .order-items.align-items-center > .order-rate::before {
    content: "Rate";
    display: block;
    font-size: 10px;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
    font-weight: 600;
  }

  div.row[id^="page-"] .order-items.align-items-center > span:last-child::before {
    content: "Amount";
    display: block;
    font-size: 10px;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
    font-weight: 600;
  }

  /* PO: Vendor name */
  div.row[id^="page-"] .indicator-container {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
  }

  div.row[id^="page-"] .indicator-container .col-10 {
    flex: 1 1 auto !important;
    max-width: 60% !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .indicator-container .col-2 {
    flex: 0 0 auto !important;
    max-width: 40% !important;
    padding: 0 !important;
    text-align: right !important;
    word-break: break-word !important;
    white-space: normal !important;
  }

  /* PO: Grand Total */
  div.row[id^="page-"] .order-taxes {
    margin-top: 10px !important;
  }

  div.row[id^="page-"] .order-taxes .col-4 {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 12px 14px !important;
    background: #eef2ff !important;
    border-radius: 8px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    margin: 0 !important;
  }

  div.row[id^="page-"] .order-taxes .item-grand-total {
    flex: none !important;
    width: auto !important;
    max-width: none !important;
    padding: 0 !important;
    white-space: nowrap !important;
  }

  /* PO: h3 title */
  div.row[id^="page-"] .page-header h3 {
    font-size: 20px !important;
    margin: 0 !important;
    word-break: break-word !important;
    line-height: 1.3 !important;
  }


    /* === LIST VIEW CARDS === */
  div.row[id^="page-"] .web-list-item.transaction-list-item {
    position: relative !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important;
    padding: 12px 14px !important;
    margin-bottom: 10px !important;
    overflow: hidden !important;
  }

 /* === LIST: fix amount alignment === */
  div.row[id^="page-"] .transaction-list-item > .row.align-items-center {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto auto !important;
    gap: 4px 8px !important;
    margin: 0 !important;
    padding-right: 52px !important;
  }

  div.row[id^="page-"] .transaction-list-item .col-sm-4 {
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    padding: 0 !important;
  }

  div.row[id^="page-"] .transaction-list-item .list-item-name {
    font-size: 13px !important;
    font-weight: 700 !important;
    display: block !important;
    color: #1e293b !important;
    word-break: break-all !important;
    white-space: normal !important;
  }

  div.row[id^="page-"] .transaction-list-item .item-total {
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    padding: 0 !important;
    text-align: right !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    align-self: start !important;
  }

  div.row[id^="page-"] .transaction-list-item .col-sm-3:not(.item-total) {
    grid-column: 1 !important;
    grid-row: 2 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    padding: 0 !important;
    margin-top: 2px !important;
  }

  div.row[id^="page-"] .transaction-list-item .col-sm-2 {
    grid-column: 1 !important;
    grid-row: 3 !important;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    padding: 0 !important;
    margin-top: 2px !important;
  }

  /* === ACTIONS BUTTON: full width === */
  div.row[id^="page-"] .page-header-actions-block .dropdown {
    width: 100% !important;
  }

  div.row[id^="page-"] .page-header-actions-block .dropdown .btn {
    width: 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    border-radius: 8px !important;
  }

  div.row[id^="page-"] .page-header-actions-block .dropdown-menu {
    width: 100% !important;
    min-width: 100% !important;
  }

} /* end 768px */

@media (max-width: 480px) {
  div.row[id^="page-"] .page-header h1 { font-size: 17px !important; }
  div.row[id^="page-"] .sidebar-item a { font-size: 11px !important; padding: 4px 8px !important; }
  div.row[id^="page-"] .rfq-qty, div.row[id^="page-"] .rfq-rate { font-size: 12px !important; }
  div.row[id^="page-"] .grand-total-row { font-size: 13px !important; }
  div.row[id^="page-"] .rfq-amount { font-size: 12px !important; }
  
}