/* styling product listing page */
  .layout {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    padding: 0;
    margin: 0 1rem 2rem 1rem;
    list-style: none;
    justify-content: flex-start;
    align-items: stretch;
    box-sizing: border-box;
  }

  .layout-item {
    box-sizing: border-box;
    background: #ffffff;
    border: 1px solid #d8dbe0;
    border-radius: 8px;
    padding: 16px;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06);
    margin: 0;
    flex: 1 1 300px;
    max-width: 400px;
    min-width: 220px;
    display: flex;
    flex-direction: column;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
  }

  .layout-item:hover {
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
  }

  .layout-item img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 6px;
    margin-bottom: 12px;
    object-fit: cover;
  }

  .p-section {
    text-align: center;
    margin: 2rem 0;
    color: #203d8f;
    padding-top: 100px;
  }

  .p-name { 
    margin: 0 0 8px 0; font-size: 1.05rem; color: #112052; 
  }
  .p-desc { 
    margin: 0 0 12px 0; color: #444; flex: 1 1 auto; 
  }
  .p-price { 
    margin-top: 8px; font-weight: 700; color: #0b3a8a; 
  }

  