body {
  font-family: Rubik,sans-serif;
  font-size: 1em;
  background: #fff7e5;
  color: #2c1810;
  text-align: center;
  margin: 0;
  min-height: 100vh
}
.shop-logo {
  width: 500px;
  height: auto;
  margin: 0 auto 20px auto;
  display: block
}
.shop-title {
  font-family: 'Rubik Mono One',monospace;
  font-size: 3.75em;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 32px;
  margin-top: 0;
  color: #2c1810;
  display: block;
  margin-left: auto;
  margin-right: auto
}
.shop-tagline {
  color: #2c1810;
  font-size: 1.65em;
  font-weight: 300;
  text-align: center;
  margin-bottom: 24px;
  margin-top: -18px;
  letter-spacing: .01em
}
.container {
  background: 0 0;
  margin: 0 auto;
  width: 90vw;
  max-width: 1200px;
  padding: 48px 36px 40px 36px
}
#shirts-list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 40px;
  margin-top: 32px;
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto
}
@media (max-width:1200px) {
  #shirts-list {
    grid-template-columns: repeat(2,1fr)!important;
    gap: 30px;
    padding: 20px
  }
  .shirt-card {
    max-width: 100%
  }
}
@media (max-width:1058px) {
  #shirts-list {
    grid-template-columns: repeat(2,1fr)!important;
    gap: 30px;
    padding: 20px
  }
  .shirt-card {
    max-width: 100%
  }
}
@media (max-width:1000px) {
  #shirts-list {
    grid-template-columns: 1fr!important;
    gap: 25px;
    padding: 15px
  }
  .shirt-card {
    max-width: 100%
  }
}
.shirt-card {
  background: rgba(255,239,209,.1);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(44,24,16,.2);
  padding: 60px 40px 50px 40px;
  max-width: 540px;
  min-width: 320px;
  display: flex;
  flex-direction: column;
  align-items: center
}
@media (max-width:768px) {
  .container {
    width: 95vw;
    min-width: 320px;
    padding: 24px 16px 20px 16px;
    margin: 10px auto;
    border-radius: 8px
  }
  .shop-title {
    font-size: 1.8em;
    margin-bottom: 16px;
    margin-top: 16px;
    padding: 0 10px
  }
  .shop-tagline {
    font-size: .9em;
    margin-bottom: 16px;
    margin-top: -8px;
    padding: 0 10px
  }
  .tagline {
    font-size: .95em;
    padding: 0 10px;
    margin-bottom: 16px
  }
  .product-image {
    width: 240px;
    height: 240px;
    margin-bottom: 16px;
    border-radius: 12px
  }
  .shirt-card {
    padding: 16px 12px 20px 12px;
    width: 100%;
    min-width: 320px;
    margin: 0 auto
  }
  .logo {
    min-width: 320px
  }
  #shirts-list {
    grid-template-columns: 1fr;
    gap: 40px;
    margin-top: 16px
  }
}
@media (max-width:480px) {
  .container {
    width: 98vw;
    padding: 16px 8px 16px 8px;
    margin: 5px auto
  }
  .shop-title {
    font-size: 1.4em;
    margin-bottom: 12px;
    margin-top: 12px
  }
  .shop-tagline {
    font-size: .8em;
    margin-bottom: 12px;
    margin-top: -4px
  }
  .tagline {
    font-size: .85em;
    margin-bottom: 12px
  }
  .product-image {
    width: 200px;
    height: 200px;
    margin-bottom: 12px
  }
  .shirt-card {
    padding: 12px 8px 16px 8px;
    min-width: 320px
  }
  .logo {
    min-width: 320px
  }
  #shirts-list {
    gap: 24px;
    margin-top: 12px
  }
}
.collections {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 32px
}
.collection-tab {
  background: #333;
  color: #ccc;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Intel One Mono',monospace;
  font-size: .9em;
  transition: all .2s ease
}
.collection-tab:hover {
  background: #444;
  color: #fff
}
.collection-tab.active {
  background: #666;
  color: #fff;
  font-weight: 700
}
.tagline {
  color: #999;
  font-size: 1em;
  font-weight: 300;
  text-align: center;
  margin-bottom: 32px;
  margin-top: -16px;
  letter-spacing: .01em;
  font-style: italic
}
#collection-title {
  font-family: 'Special Gothic Expanded One',sans-serif;
  font-size: 2.2em;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
  margin-top: 32px;
  color: #fff
}
#collection-tagline {
  color: #bbb;
  font-size: 1em;
  font-weight: 300;
  text-align: center;
  margin-bottom: 24px;
  margin-top: -8px;
  letter-spacing: .01em;
  font-style: italic
}
.shirt-name {
  font-size: 1.4em;
  font-weight: 700;
  margin-bottom: 8px;
  color: #fff
}
.desc {
  color: #ccc;
  margin-bottom: 16px;
  text-align: center;
  line-height: 1.4;
  max-width: 300px
}
.price {
  font-size: 1.6em;
  font-weight: 700;
  color: #2c1810;
  margin-bottom: 16px
}
.product-image {
  width: 300px;
  height: 300px;
  object-fit: cover;
  border-radius: 16px;
  margin-bottom: 20px;
  box-shadow: 0 4px 16px #000a
}
.color-selection {
  margin-bottom: 20px;
  text-align: center
}
.color-label {
  margin-bottom: 12px;
  color: #2c1810;
  font-weight: 500
}
.color-buttons {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap
}
.color-btn {
  background: #f0e6d0;
  color: #2c1810;
  border: 2px solid #d4c4a0;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-family: Rubik,sans-serif;
  font-size: .9em;
  transition: all .2s ease;
  min-width: 80px
}
.color-btn:hover {
  background: #e6d8c0;
  border-color: #c4b490
}
.color-btn.active {
  background: #4caf50;
  color: #fff;
  border-color: #4caf50;
  font-weight: 700
}
.platform-selection {
  margin: 15px 0
}
.platform-selection .platform-buttons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center
}
.platform-btn {
  background: #f0e6d0;
  color: #2c1810;
  border: 2px solid #d4c4a0;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-family: Rubik,sans-serif;
  font-size: .9em;
  transition: all .2s ease;
  min-width: 80px
}
.platform-btn:hover {
  background: #e6d8c0;
  border-color: #c4b490
}
.platform-btn.active {
  background: #4caf50;
  color: #fff;
  border-color: #4caf50;
  font-weight: 700
}
.custom-amount-section {
  margin-bottom: 20px;
  text-align: center
}
.custom-amount-label {
  margin-bottom: 12px;
  color: #2c1810;
  font-weight: 500
}
.suggested-amounts {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 16px
}
.amount-btn {
  background: #f0e6d0;
  color: #2c1810;
  border: 2px solid #d4c4a0;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-family: Rubik,sans-serif;
  font-size: .9em;
  transition: all .2s ease;
  min-width: 60px
}
.amount-btn:hover {
  background: #e6d8c0;
  border-color: #c4b490
}
.amount-btn.active {
  background: #4caf50;
  color: #fff;
  border-color: #4caf50;
  font-weight: 700
}
.custom-amount-input {
  margin-top: 16px
}
.custom-amount-input label {
  display: block;
  margin-bottom: 8px;
  color: #2c1810;
  font-weight: 500
}
.amount-input-container {
  position: relative;
  display: inline-block;
  margin-bottom: 8px
}
.currency-symbol {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: #2c1810;
  font-weight: 500
}
.custom-amount-field {
  padding: 8px 12px 8px 24px;
  border: 2px solid #d4c4a0;
  border-radius: 6px;
  font-family: Rubik,sans-serif;
  font-size: .9em;
  width: 120px;
  text-align: center
}
.custom-amount-field:focus {
  outline: 0;
  border-color: #4caf50;
  box-shadow: 0 0 0 2px rgba(76,175,80,.2)
}
.min-amount-note {
  display: block;
  color: #666;
  font-size: .8em;
  margin-top: 4px
}
.size-selection {
  margin-bottom: 20px;
  text-align: center
}
.size-label {
  margin-bottom: 12px;
  color: #ccc;
  font-weight: 500
}
.size-buttons {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap
}
.add-to-cart-btn {
  background: #5ab2e0;
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Intel One Mono',monospace;
  font-size: 1em;
  font-weight: 700;
  transition: all .2s ease;
  min-width: 120px;
  margin: 10px
}
.add-to-cart-btn:hover:not(:disabled) {
  background: #4a9bc7;
  transform: translateY(-2px)
}
.add-to-cart-btn.disabled,
.add-to-cart-btn:disabled {
  background: #ccc;
  color: #666;
  cursor: not-allowed;
  transform: none;
  opacity: .6
}
.cart-icon {
  position: fixed;
  top: 20px;
  right: 20px;
  background: #d4c4a0;
  color: #fff;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 2em;
  z-index: 1000;
  box-shadow: 0 4px 16px #000a;
  transition: all .2s ease;
  display: flex;
  align-items: center;
  justify-content: center
}
.cart-icon:hover {
  background: #4a9bc7;
  transform: scale(1.1)
}
.cart-count {
  position: absolute;
  top: -8px;
  right: -8px;
  background: #f44336;
  color: #fff;
  border-radius: 50%;
  padding: 4px 8px;
  font-size: .8em;
  font-weight: 700;
  min-width: 20px;
  min-height: 20px;
  text-align: center
}
.cart-sidebar {
  position: fixed;
  top: 0;
  right: 0;
  width: 500px;
  height: 100vh;
  background: #f8f4f0;
  box-shadow: -4px 0 16px #000a;
  z-index: 999;
  overflow-y: auto;
  display: none
}
.cart-sidebar.open {
  display: block
}
.cart-header {
  background: #e6d8c0;
  color: #2c1810;
  padding: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #d4c4a0
}
.cart-header h3 {
  margin: 0;
  font-size: 1.2em
}
.cart-empty {
  padding: 40px 20px;
  text-align: center;
  color: #666
}
.cart-items {
  padding: 20px
}
.cart-item {
  background: #fff;
  border: 1px solid #d4c4a0;
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 16px
}
.cart-item img {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: 8px
}
.cart-item-details {
  flex: 1
}
.cart-item-name {
  font-weight: 700;
  color: #2c1810;
  margin-bottom: 4px
}
.cart-item-size {
  color: #ccc;
  font-size: .9em;
  margin-bottom: 4px
}
.cart-item-color {
  color: #ccc;
  font-size: .9em;
  margin-bottom: 4px
}
.cart-item-platform {
  color: #ccc;
  font-size: .9em;
  margin-bottom: 4px
}
.cart-item-price {
  color: #2c1810;
  font-weight: 700
}
.cart-item-quantity {
  display: flex;
  align-items: center;
  gap: 8px
}
.quantity-btn {
  background: #f0e6d0;
  color: #2c1810;
  border: 2px solid #d4c4a0;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s ease
}
.quantity-btn:hover {
  background: #e6d8c0;
  color: #2c1810
}
.quantity-display {
  color: #2c1810;
  font-weight: 700;
  min-width: 30px;
  text-align: center
}
.remove-item {
  background: #f44336;
  color: #fff;
  border: none;
  padding: 6px 12px;
  border-radius: 4px;
  cursor: pointer;
  font-size: .8em;
  transition: background .2s ease
}
.remove-item:hover {
  background: #d32f2f
}
.cart-footer {
  background: #e6d8c0;
  padding: 20px;
  border-top: 1px solid #d4c4a0;
  position: sticky;
  bottom: 0
}
.cart-total {
  color: #2c1810;
  font-size: 1.1em;
  margin-bottom: 16px;
  text-align: center
}
.checkout-btn {
  background: #4caf50;
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Intel One Mono',monospace;
  font-size: 1em;
  font-weight: 700;
  width: 100%;
  transition: all .2s ease
}
.checkout-btn:hover {
  background: #45a049;
  transform: translateY(-2px)
}
.carousel {
  position: relative;
  width: 300px;
  height: 300px;
  margin-bottom: 20px
}
.carousel-img-group {
  position: relative;
  width: 100%;
  height: 100%
}
.carousel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  box-shadow: 0 4px 16px #000a
}
.carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,.7);
  color: #fff;
  border: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.2em;
  z-index: 10;
  transition: all .2s ease
}
.carousel-arrow:hover {
  background: rgba(0,0,0,.9);
  transform: translateY(-50%) scale(1.1)
}
.carousel-arrow.left {
  left: 10px
}
.carousel-arrow.right {
  right: 10px
}
.carousel-thumbs {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10
}
.carousel-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(255,255,255,.5);
  cursor: pointer;
  transition: all .2s ease
}
.carousel-dot:hover {
  background: rgba(255,255,255,.8)
}
.carousel-dot.active {
  background: #4caf50
}
.sizing-section {
  margin-top: 60px;
  padding-top: 40px;
  border-top: 1px solid #333
}
.sizing-title {
  font-size: 1.8em;
  color: #fff;
  margin-bottom: 24px;
  text-align: center
}
.sizing-tabs {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 24px
}
.sizing-tab {
  background: #333;
  color: #ccc;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-family: 'Intel One Mono',monospace;
  font-size: .9em;
  transition: all .2s ease
}
.sizing-tab:hover {
  background: #444;
  color: #fff
}
.sizing-tab.active {
  background: #666;
  color: #fff;
  font-weight: 700
}
.sizing-table-container {
  overflow-x: auto;
  margin: 0 auto;
  max-width: 800px
}
.sizing-table {
  width: 100%;
  border-collapse: collapse;
  background: #222;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 16px #000a
}
.sizing-table td,
.sizing-table th {
  padding: 12px 16px;
  text-align: center;
  border-bottom: 1px solid #333
}
.sizing-table th {
  background: #333;
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  font-size: .9em;
  letter-spacing: .05em
}
.sizing-table td {
  color: #ccc
}
.sizing-table .measurement-label {
  text-align: left;
  color: #fff;
  font-weight: 500
}
.sizing-table tr:hover {
  background: #2a2a2a
}
@media (max-width:768px) {
  .sizing-table td,
  .sizing-table th {
    padding: 8px 12px;
    font-size: .9em
  }
  .sizing-title {
    font-size: 1.5em
  }
  .sizing-tabs {
    gap: 12px
  }
  .sizing-tab {
    padding: 6px 12px;
    font-size: .8em
  }
}
@media (max-width:480px) {
  .sizing-table td,
  .sizing-table th {
    padding: 6px 8px;
    font-size: .8em
  }
  .sizing-title {
    font-size: 1.3em
  }
  .sizing-tabs {
    gap: 8px
  }
  .sizing-tab {
    padding: 4px 8px;
    font-size: .75em
  }
}
.cancel-card,
.success-card {
  background: #fff7e5;
  border: 2px solid #d4c4a0;
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(44,24,16,.2);
  padding: 60px 40px 50px 40px;
  max-width: 600px;
  margin: 0 auto;
  text-align: center
}
.cancel-icon,
.success-icon {
  font-size: 4em;
  margin-bottom: 24px
}
.cancel-title,
.success-title {
  font-size: 2.2em;
  color: #2c1810;
  margin-bottom: 16px;
  font-weight: 700
}
.cancel-message,
.success-message {
  color: #666;
  font-size: 1.1em;
  line-height: 1.6;
  margin-bottom: 32px
}
.cancel-details,
.order-details {
  text-align: left;
  margin-bottom: 32px
}
.cancel-details h3,
.order-details h3 {
  color: #2c1810;
  font-size: 1.3em;
  margin-bottom: 16px;
  text-align: center
}
.cancel-details ul,
.order-details ul {
  color: #666;
  line-height: 1.8;
  padding-left: 20px
}
.cancel-details li,
.order-details li {
  margin-bottom: 8px
}
.cancel-actions,
.success-actions {
  text-align: center
}
.back-to-store-btn {
  display: inline-block;
  background: #4caf50;
  color: #fff;
  text-decoration: none;
  padding: 14px 28px;
  border-radius: 8px;
  font-family: 'Intel One Mono',monospace;
  font-size: 1em;
  font-weight: 700;
  transition: all .2s ease
}
.back-to-store-btn:hover {
  background: #45a049;
  transform: translateY(-2px)
}
.order-container {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: #fff7e5
}
.order-content {
  background: #fff7e5;
  border: 2px solid #d4c4a0;
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(44,24,16,.2);
  padding: 60px 40px 50px 40px;
  max-width: 600px;
  width: 100%;
  text-align: center
}
.order-icon {
  font-size: 4em;
  margin-bottom: 24px;
  color: #f44336
}
.order-details {
  text-align: left;
  margin-bottom: 32px;
  background: rgba(255,239,209,.3);
  padding: 24px;
  border-radius: 12px;
  border: 1px solid #d4c4a0
}
.order-details h3 {
  color: #2c1810;
  font-size: 1.3em;
  margin-bottom: 16px;
  text-align: center
}
.order-details ul {
  color: #666;
  line-height: 1.8;
  padding-left: 20px;
  margin: 0
}
.order-details li {
  margin-bottom: 8px
}
@media (max-width:768px) {
  .cancel-card,
  .success-card {
    padding: 40px 24px 32px 24px;
    margin: 20px
  }
  .cancel-title,
  .success-title {
    font-size: 1.8em
  }
  .cancel-message,
  .success-message {
    font-size: 1em
  }
}
@media (max-width:480px) {
  .cancel-card,
  .success-card {
    padding: 32px 16px 24px 16px;
    margin: 16px
  }
  .cancel-title,
  .success-title {
    font-size: 1.5em
  }
  .cancel-message,
  .success-message {
    font-size: .9em
  }
  .back-to-store-btn {
    padding: 12px 24px;
    font-size: .9em
  }
}
.category-filters {
  margin-bottom: 32px;
  text-align: center
}
.filter-buttons {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap
}
.filter-btn {
  background: #d4c4a0;
  color: #2c1810;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-family: Rubik,sans-serif;
  font-size: 1.2em;
  transition: all .2s ease
}
.filter-btn:hover {
  background: #d4c4a0;
  color: #2c1810
}
.filter-btn.active {
  background: #4caf50;
  color: #fff;
  font-weight: 700
}
.product-image-container {
  margin-bottom: 20px
}
.product-info {
  text-align: center;
  width: 100%
}
.product-name {
  font-size: 1.4em;
  font-weight: 700;
  margin-bottom: 8px;
  color: #2c1810
}
.product-description {
  color: #666;
  margin-bottom: 16px;
  text-align: center;
  line-height: 1.4;
  max-width: 300px;
  margin-left: auto;
  margin-right: auto
}
.product-price {
  font-size: 1.6em;
  font-weight: 700;
  color: #2c1810;
  margin-bottom: 16px
}
@media (max-width:768px) {
  .filter-buttons {
    gap: 12px
  }
  .filter-btn {
    padding: 6px 12px;
    font-size: .8em
  }
}
.sizing-guide-btn {
  background: #666;
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 6px;
  cursor: pointer;
  font-family: Rubik,sans-serif;
  font-size: .9em;
  margin-bottom: 16px;
  transition: all .2s ease
}
.sizing-guide-btn:hover {
  background: #777;
  transform: translateY(-1px)
}
#sizing-guide-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000
}
.sizing-guide-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,.8);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px
}
.sizing-guide-content {
  background: #fff7e5;
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(44,24,16,.3);
  max-width: 800px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative
}
.sizing-guide-header {
  background: #2c1810;
  color: #fff7e5;
  padding: 20px;
  border-radius: 16px 16px 0 0;
  display: flex;
  justify-content: space-between;
  align-items: center
}
.sizing-guide-header h2 {
  margin: 0;
  font-family: 'Rubik Mono One',monospace;
  font-size: 1.5em
}
.close-sizing-guide {
  background: 0 0;
  border: none;
  color: #fff7e5;
  font-size: 2em;
  cursor: pointer;
  padding: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background .2s ease
}
.close-sizing-guide:hover {
  background: rgba(255,255,255,.1)
}
.sizing-guide-tabs {
  background: #f0e6d0;
  padding: 20px;
  display: flex;
  justify-content: center;
  gap: 16px;
  border-bottom: 1px solid #d4c4a0
}
.sizing-tab-btn {
  background: #d4c4a0;
  color: #2c1810;
  border: none;
  padding: 10px 20px;
  border-radius: 6px;
  cursor: pointer;
  font-family: Rubik,sans-serif;
  font-size: .9em;
  transition: all .2s ease
}
.sizing-tab-btn:hover {
  background: #c4b490
}
.sizing-tab-btn.active {
  background: #4caf50;
  color: #fff;
  font-weight: 700
}
.sizing-guide-table {
  padding: 20px
}
.sizing-guide-table .sizing-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(44,24,16,.1)
}
.sizing-guide-table .sizing-table td,
.sizing-guide-table .sizing-table th {
  padding: 12px 16px;
  text-align: center;
  border-bottom: 1px solid #f0e6d0
}
.sizing-guide-table .sizing-table th {
  background: #2c1810;
  color: #fff7e5;
  font-weight: 700;
  text-transform: uppercase;
  font-size: .9em;
  letter-spacing: .05em
}
.sizing-guide-table .sizing-table td {
  color: #2c1810
}
.sizing-guide-table .sizing-table td:first-child {
  text-align: left;
  font-weight: 500;
  background: #f8f4e8
}
.sizing-guide-table .sizing-table tr:hover {
  background: #f8f4e8
}
@media (max-width:768px) {
  .sizing-guide-content {
    margin: 10px;
    max-height: 95vh
  }
  .sizing-guide-tabs {
    flex-direction: column;
    align-items: center;
    gap: 12px
  }
  .sizing-tab-btn {
    width: 100%;
    max-width: 200px
  }
  .sizing-guide-table .sizing-table td,
  .sizing-guide-table .sizing-table th {
    padding: 8px 12px;
    font-size: .9em
  }
}
@media (max-width:480px) {
  .sizing-guide-content {
    margin: 5px
  }
  .sizing-guide-header {
    padding: 16px
  }
  .sizing-guide-header h2 {
    font-size: 1.3em
  }
  .sizing-guide-table .sizing-table td,
  .sizing-guide-table .sizing-table th {
    padding: 6px 8px;
    font-size: .8em
  }
}
@media (max-width:1200px) {
  .container {
    max-width: 95%;
    padding: 0 20px
  }
  .shirt-card {
    flex-direction: column;
    text-align: center;
    max-width: 400px;
    margin: 20px auto
  }
  .product-image-container {
    width: 100%;
    max-width: 300px;
    margin: 0 auto 20px
  }
  .product-info {
    width: 100%;
    padding: 0 20px
  }
}
@media (max-width:768px) {
  .shop-title {
    font-size: 2em;
    margin: 20px 0
  }
  .shop-tagline {
    font-size: 1em;
    margin-bottom: 30px
  }
  .shirt-card {
    margin: 15px auto;
    padding: 20px
  }
  .product-name {
    font-size: 1.4em
  }
  .product-description {
    font-size: .9em;
    line-height: 1.4
  }
  .product-price {
    font-size: 1.3em;
    margin: 15px 0
  }
  .color-selection,
  .size-selection {
    margin-bottom: 15px
  }
  .color-buttons,
  .size-buttons {
    gap: 6px;
    flex-wrap: wrap;
    justify-content: center
  }
  .color-btn {
    padding: 6px 12px;
    font-size: .8em;
    min-width: 70px
  }
  .custom-amount-section {
    margin-bottom: 15px
  }
  .suggested-amounts {
    gap: 6px;
    margin-bottom: 12px
  }
  .amount-btn {
    padding: 6px 12px;
    font-size: .8em;
    min-width: 50px
  }
  .custom-amount-field {
    width: 100px;
    padding: 6px 10px 6px 20px
  }
  .sizing-guide-btn {
    padding: 8px 16px;
    font-size: .9em;
    margin: 10px 0
  }
  .add-to-cart-btn {
    padding: 12px 24px;
    font-size: 1em;
    margin-top: 15px
  }
  .cart-sidebar {
    width: 100%;
    right: 0;
    height: 100vh;
    border-radius: 0
  }
  .cart-header {
    padding: 15px 20px
  }
  .cart-header h3 {
    font-size: 1.3em
  }
  .cart-item {
    padding: 15px;
    flex-direction: column;
    text-align: center;
    gap: 10px
  }
  .cart-item-image {
    width: 80px;
    height: 80px;
    margin: 0 auto
  }
  .cart-item-details h4 {
    font-size: 1.1em
  }
  .cart-item-quantity {
    justify-content: center
  }
  .cart-footer {
    padding: 15px 20px
  }
  .checkout-btn {
    padding: 15px 24px;
    font-size: 1.1em
  }
}
@media (max-width:480px) {
  .container {
    padding: 0 15px
  }
  .shop-logo {
    width: 120px;
    height: 120px;
    margin: 20px auto
  }
  .shop-title {
    font-size: 1.6em;
    margin: 15px 0
  }
  .shop-tagline {
    font-size: .9em;
    margin-bottom: 25px;
    padding: 0 10px
  }
  .shirt-card {
    margin: 10px auto;
    padding: 15px
  }
  .product-image-container {
    max-width: 250px;
    margin-bottom: 15px
  }
  .product-info {
    padding: 0 10px
  }
  .product-name {
    font-size: 1.2em
  }
  .product-description {
    font-size: .85em;
    line-height: 1.3
  }
  .product-price {
    font-size: 1.2em;
    margin: 12px 0
  }
  .color-btn {
    padding: 5px 10px;
    font-size: .75em;
    min-width: 60px
  }
  .amount-btn {
    padding: 5px 10px;
    font-size: .75em;
    min-width: 45px
  }
  .custom-amount-field {
    width: 90px;
    padding: 5px 8px 5px 18px;
    font-size: .8em
  }
  .color-label,
  .custom-amount-label,
  .size-label {
    font-size: .9em;
    margin-bottom: 8px
  }
  .sizing-guide-btn {
    padding: 6px 12px;
    font-size: .8em;
    margin: 8px 0
  }
  .add-to-cart-btn {
    padding: 10px 20px;
    font-size: .9em;
    margin-top: 12px
  }
  .cart-icon {
    top: 15px;
    right: 15px;
    width: 60px;
    height: 60px;
    font-size: 1.5em
  }
  .cart-count {
    font-size: .8em;
    padding: 2px 6px
  }
  .cart-item {
    padding: 12px
  }
  .cart-item-image {
    width: 60px;
    height: 60px
  }
  .cart-item-details h4 {
    font-size: 1em
  }
  .cart-item-color,
  .cart-item-price,
  .cart-item-size {
    font-size: .8em
  }
  .quantity-btn {
    width: 20px;
    height: 20px;
    font-size: .8em
  }
  .remove-item {
    padding: 4px 8px;
    font-size: .7em
  }
  .loading-products {
    padding: 40px 20px
  }
  .loading-spinner {
    font-size: 2em;
    margin-bottom: 15px
  }
  .loading-products p {
    font-size: 1em
  }
}
@media (max-width:768px) and (orientation:landscape) {
  .shop-title {
    font-size: 1.8em;
    margin: 15px 0
  }
  .shop-tagline {
    font-size: .9em;
    margin-bottom: 20px
  }
  .shirt-card {
    flex-direction: row;
    max-width: 600px;
    text-align: left
  }
  .product-image-container {
    width: 40%;
    max-width: 200px;
    margin: 0 20px 0 0
  }
  .product-info {
    width: 60%;
    padding: 0
  }
  .cart-sidebar {
    width: 80%;
    right: 0
  }
}
@media (-webkit-min-device-pixel-ratio:2),
(min-resolution:192dpi) {
  .product-image {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges
  }
}
@media print {
  .add-to-cart-btn,
  .cart-icon,
  .cart-sidebar,
  .sizing-guide-btn {
    display: none!important
  }
  .shirt-card {
    break-inside: avoid;
    margin: 20px 0;
    border: 1px solid #ccc
  }
  .product-image-container {
    max-width: 200px
  }
}