.product-sticky-row {
    position:sticky;
    top: 112px;
    z-index:555;
}

@media(min-width: 1200px) {
    .product-sticky-row {
        top: 173px;
    }
}

#productdescription p {
    margin-bottom: 0;
}

.product-grid:not(.missingorder) {
  display: grid;
  grid-template-columns: 1fr 90px 90px;
  gap: 1px;
  background-color: #dee2e6;
  border:1px solid #dee2e6;
  grid-template-areas:
    "productnoheader priceheader qtyheader"
    "productno price qty"
    "holesize price qty"
    "size price qty"
    "keyholecover price qty";
}
.product-grid.missingkeyholecover.missingholesize:not(.missingorder) {
  grid-template-areas:
    "productnoheader priceheader qtyheader"
    "productno price qty"
    "size price qty";
}
.product-grid.missingkeyholecover:not(.missingholesize):not(.missingorder) {
  grid-template-areas:
    "productnoheader priceheader qtyheader"
    "productno price qty"
    "holesize price qty"
    "size price qty";
}
.product-grid:not(.missingkeyholecover).missingholesize:not(.missingorder) {
  grid-template-areas:
    "productnoheader priceheader qtyheader"
    "productno price qty"
    "size price qty"
    "keyholecover price qty";
}

.product-grid.missingorder {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background-color: #dee2e6;
  border:1px solid #dee2e6;
  grid-template-areas:
    "productnoheader "
    "productno "
    "holesize "
    "size "
    "keyholecover ";
}
.product-grid.missingkeyholecover.missingholesize.missingorder {
  grid-template-areas:
    "productnoheader "
    "productno "
    "size ";
}
.product-grid.missingkeyholecover:not(.missingholesize).missingorder {
  grid-template-areas:
    "productnoheader "
    "productno "
    "holesize "
    "size ";
}
.product-grid:not(.missingkeyholecover).missingholesize.missingorder {
  grid-template-areas:
    "productnoheader "
    "productno "
    "size "
    "keyholecover ";
}

@media(min-width: 640px) {
.product-grid:not(.missingorder){
  grid-template-columns: 1fr 140px 140px !important;
}
.product-grid.missingorder{
  grid-template-columns: 1fr !important;
}
}

@media(min-width: 800px) {
.product-grid:not(.missingorder) {
  grid-template-columns: 1fr 260px 140px !important;
}
.product-grid.missingorder {
  grid-template-columns: 1fr !important;
}
}

@media(min-width: 1200px) {
.product-grid:not(.missingorder) {
  grid-template-columns: 6fr 3fr 3fr 120px 120px 180px !important;
  grid-template-areas:
    "productnoheader holesizeheader sizeheader keyholecoverheader priceheader qtyheader"
    "productno holesize size keyholecover price qty";
}
.product-grid.missingkeyholecover.missingholesize:not(.missingorder) {
  grid-template-areas:
    "productnoheader sizeheader priceheader qtyheader"
    "productno size price qty";
  grid-template-columns: 6fr 3fr 120px 180px !important;
}
.product-grid.missingkeyholecover:not(.missingholesize):not(.missingorder) {
  grid-template-columns: 6fr 3fr 3fr 120px 180px !important;
  grid-template-areas:
    "productnoheader holesizeheader sizeheader priceheader qtyheader"
    "productno holesize size price qty";
}
.product-grid:not(.missingkeyholecover).missingholesize:not(.missingorder) {
  grid-template-columns: 6fr 3fr 120px 120px 180px !important;
  grid-template-areas:
    "productnoheader sizeheader keyholecoverheader priceheader qtyheader"
    "productno size keyholecover price qty";
}
.product-grid.missingorder {
  grid-template-columns: 6fr 3fr 3fr 120px !important;
  grid-template-areas:
    "productnoheader holesizeheader sizeheader keyholecoverheader "
    "productno holesize size keyholecover ";
}
.product-grid.missingkeyholecover.missingholesize.missingorder {
  grid-template-areas:
    "productnoheader sizeheader "
    "productno size ";
  grid-template-columns: 6fr 3fr !important;
}
.product-grid.missingkeyholecover:not(.missingholesize).missingorder {
  grid-template-columns: 6fr 3fr 3fr !important;
  grid-template-areas:
    "productnoheader holesizeheader sizeheader "
    "productno holesize size ";
}
.product-grid:not(.missingkeyholecover).missingholesize.missingorder {
  grid-template-columns: 6fr 3fr 120px !important;
  grid-template-areas:
    "productnoheader sizeheader keyholecoverheader "
    "productno size keyholecover ";
}
}

@media(min-width: 1400px) {
.product-grid:not(.missingorder) {
  grid-template-columns: 6fr 3fr 3fr 200px 200px 200px !important;
}
.product-grid.missingkeyholecover.missingholesize:not(.missingorder) {
  grid-template-areas:
    "productnoheader sizeheader priceheader qtyheader"
    "productno size price qty";
  grid-template-columns: 6fr 3fr 200px 200px !important;
}
.product-grid.missingkeyholecover:not(.missingholesize):not(.missingorder) {
  grid-template-columns: 6fr 3fr 3fr 200px 180px !important;
  grid-template-areas:
    "productnoheader holesizeheader sizeheader priceheader qtyheader"
    "productno holesize size price qty";
}
.product-grid:not(.missingkeyholecover).missingholesize:not(.missingorder) {
  grid-template-columns: 6fr 3fr 200px 200px 180px !important;
  grid-template-areas:
    "productnoheader sizeheader keyholecoverheader priceheader qtyheader"
    "productno size keyholecover price qty";
}
.product-grid.missingorder {
  grid-template-columns: 6fr 3fr 3fr 200px !important;
}
.product-grid.missingkeyholecover.missingholesize.missingorder {
  grid-template-areas:
    "productnoheader sizeheader "
    "productno size ";
  grid-template-columns: 6fr 3fr !important;
}
.product-grid.missingkeyholecover:not(.missingholesize).missingorder {
  grid-template-columns: 6fr 3fr 3fr !important;
  grid-template-areas:
    "productnoheader holesizeheader sizeheader "
    "productno holesize size ";
}
.product-grid:not(.missingkeyholecover).missingholesize.missingorder {
  grid-template-columns: 6fr 3fr 200px !important;
  grid-template-areas:
    "productnoheader sizeheader keyholecoverheader"
    "productno size keyholecover";
}
}

.product-grid-item {
    overflow:hidden;
    padding:5px;
}

.product-grid-item-span-2 {
    grid-row: span 2;
}

.product-grid-item-span-3 {
    grid-row: span 3;
}

.product-grid-item-span-4 {
    grid-row: span 4;
}

.product-grid-item-productnoheader { grid-area: productnoheader; }
.product-grid-item-holesizeheader { grid-area: holesizeheader; }
.product-grid-item-sizeheader { grid-area: sizeheader; }
.product-grid-item-keyholecoverheader { grid-area: keyholecoverheader; }
.product-grid-item-priceheader { grid-area: priceheader; }
.product-grid-item-qtyheader { grid-area: qtyheader; }
.product-grid-item-productno { grid-area: productno; }
.product-grid-item-holesize { grid-area: holesize; }
.product-grid-item-size { grid-area: size; }
.product-grid-item-keyholecover { grid-area: keyholecover; }
.product-grid-item-price { grid-area: price; text-align: center; }
.product-grid-item-qty { grid-area: qty; display: flex; align-items: center; justify-content: center; }

.detail-grid {
  display: grid;
  grid-template-columns: 1fr;
  border: 1px solid #ddd;
  border-radius: 0.25rem !important;
}

.detail-grid-item:nth-child(n + 1):nth-last-child(-n +1),
  .detail-grid-item:nth-child(n + 1):nth-last-child(-n +1 ) ~ .detail-grid-item {
    border-bottom: none;
}
  
@media (min-width: 600px) {
  .detail-grid {
    grid-template-columns: 200px 1fr;
  }
.detail-grid-item:nth-child(2n + 1):nth-last-child(-n + 2),
  .detail-grid-item:nth-child(2n + 1):nth-last-child(-n + 2) ~ .detail-grid-item {
    border-bottom: none;
  }
}

/* Közepes kijelzőkön 4 oszlop */
@media (min-width: 900px) {
      .detail-grid {
        grid-template-columns: 200px 1fr 200px 1fr;
      }

    .detail-grid-item:nth-child(4n + 1):nth-last-child(-n + 4),
    .detail-grid-item:nth-child(4n + 1):nth-last-child(-n + 4) ~ .detail-grid-item {
      border-bottom: none;
    }
}

.detail-grid-item {
  padding: 10px;
  border-bottom: 1px solid #ddd;
  font-size: 1rem;
}

.detail-grid-item-name {
  background-color: #f9f9f9;
  color: var(--detail-grid-text-color); 
  display: flex;
  align-items:center;
  border-top-left-radius: 0.25rem !important;
  border-bottom-left-radius: 0.25rem !important;
}


