/* ==========================================================================
   Collegiate ABCs — Site-Wide Styles
   Applied via Customizer > Additional CSS on collegiateabcs.com
   Brand: Poppins font, Tangerine #FE5F1B, Eggshell #EFE8E2, Noir #1A1A1A
   ========================================================================== */

/* ===== GLOBAL TYPOGRAPHY & BASE ===== */
body,
.wp-site-blocks,
.wp-block-post-content,
.entry-content,
.woocommerce,
.wp-block-group {
  font-family: 'Poppins', sans-serif !important;
  color: #333333;
  line-height: 1.7;
}

h1, h2, h3, h4, h5, h6,
.wp-block-heading,
.wp-block-post-title,
.wc-block-components-product-title {
  font-family: 'Poppins', sans-serif !important;
  color: #1A1A1A;
  line-height: 1.25;
}

h1, .wp-block-post-title { font-weight: 800; }
h2 { font-weight: 700; }
h3 { font-weight: 700; }

a {
  color: #1A1A1A;
  transition: color 0.2s, opacity 0.2s;
}
a:hover {
  color: #FE5F1B;
}

/* Fix paragraph width to match headings on policy/info pages */
.entry-content > p,
.wp-block-post-content > p {
  max-width: 1100px !important;
}

/* Ensure Poppins loads */

/* ===== MINI CART IN HEADER (already deployed) ===== */
header.wp-block-template-part {
  position: relative;
}
header.wp-block-template-part > .wc-block-mini-cart {
  position: absolute !important;
  top: 0 !important;
  right: 48px;
  height: 72px;
  display: flex !important;
  align-items: center;
  z-index: 10000;
  margin: 0 !important;
  padding: 0 !important;
}
@media (max-width: 900px) {
  header.wp-block-template-part > .wc-block-mini-cart {
    right: 56px;
  }
}

/* ===== HIDE OLD THEME ELEMENTS ===== */
.mysticky-welcomebar-fixed,
div[class*="mysticky-welcomebar"],
.mysticky_welcomebar_holder {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* ===== GLOBAL BUTTONS ===== */
.wp-element-button,
.wp-block-button__link,
.wc-block-components-product-button__button,
.single_add_to_cart_button,
.button,
input[type="submit"],
.wc-block-components-button {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  border-radius: 100px !important;
  padding: 12px 26px !important;
  transition: all 0.2s !important;
  cursor: pointer;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: none !important;
  line-height: 1.4 !important;
}

/* Primary buttons — Tangerine */
.wp-element-button,
.wp-block-button__link,
.wc-block-components-product-button__button,
.single_add_to_cart_button,
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wc-block-mini-cart__footer-checkout,
.button.alt,
input[type="submit"] {
  background: #FE5F1B !important;
  color: #FFFFFF !important;
}
.wp-element-button:hover,
.wp-block-button__link:hover,
.wc-block-components-product-button__button:hover,
.single_add_to_cart_button:hover,
.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover,
.wc-block-mini-cart__footer-checkout:hover,
.button.alt:hover,
input[type="submit"]:hover {
  background: #E24D0F !important;
  color: #FFFFFF !important;
  opacity: 1 !important;
}

/* Outline / secondary button variant */
.wp-block-button.is-style-outline .wp-block-button__link,
.wc-block-mini-cart__footer-cart,
.button:not(.alt) {
  background: transparent !important;
  color: #1A1A1A !important;
  border: 1.5px solid #EBEBEB !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover,
.wc-block-mini-cart__footer-cart:hover,
.button:not(.alt):hover {
  border-color: #999999 !important;
}

/* ===== BREADCRUMBS ===== */
.woocommerce-breadcrumb,
.wp-block-woocommerce-breadcrumbs {
  font-family: 'Poppins', sans-serif !important;
  font-size: 12px !important;
  color: #999999 !important;
  padding: 16px 0 8px !important;
  margin-bottom: 8px !important;
}
.woocommerce-breadcrumb a,
.wp-block-woocommerce-breadcrumbs a {
  color: #999999 !important;
  text-decoration: none !important;
}
.woocommerce-breadcrumb a:hover,
.wp-block-woocommerce-breadcrumbs a:hover {
  color: #FE5F1B !important;
}

/* ===== PAGE CONTENT AREA — Consistent Padding ===== */
.wp-site-blocks > main,
.wp-site-blocks > .wp-block-group,
.wp-block-post-content {
  font-family: 'Poppins', sans-serif !important;
}

/* Constrain content width for readability */
.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  max-width: 1100px;
}

/* ===== WOOCOMMERCE SHOP / PRODUCT GRID ===== */
/* Product grid cards */
.wc-block-product {
  background: #FFFFFF;
  border: 1px solid #EBEBEB;
  border-radius: 16px;
  overflow: hidden;
  transition: box-shadow 0.3s, transform 0.3s;
}
.wc-block-product:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 40px rgba(0,0,0,0.08);
}

/* Product images in grid */
.wc-block-components-product-image {
  overflow: hidden;
  border-radius: 16px 16px 0 0;
  background: #F7F3EF;
}
.wc-block-components-product-image img {
  transition: transform 0.3s;
  width: 100%;
  object-fit: cover;
}
.wc-block-product:hover .wc-block-components-product-image img {
  transform: scale(1.03);
}

/* Product title in grid */
.wc-block-components-product-title {
  font-family: 'Poppins', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
  text-decoration: none !important;
  line-height: 1.35 !important;
  display: block;
  padding: 0 4px;
}
.wc-block-components-product-title:hover {
  color: #FE5F1B !important;
}

/* Product price in grid */
.wc-block-components-product-price {
  font-family: 'Poppins', sans-serif !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
}
.wc-block-components-product-price .wc-block-components-product-price__value--sale {
  color: #FE5F1B !important;
}
.wc-block-components-product-price del {
  color: #999999 !important;
  font-size: 13px !important;
}

/* Sale badge */
.wc-block-components-product-sale-badge {
  background: #FE5F1B !important;
  color: #FFFFFF !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 10px !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: 100px !important;
  padding: 4px 12px !important;
}

/* Product button in grid */
.wc-block-components-product-button .wc-block-components-product-button__button {
  font-size: 12px !important;
  padding: 8px 18px !important;
  border-radius: 100px !important;
  background: #FE5F1B !important;
  color: #FFFFFF !important;
}
.wc-block-components-product-button .wc-block-components-product-button__button:hover {
  background: #E24D0F !important;
}

/* ===== SINGLE PRODUCT PAGE ===== */
/* Product gallery */
.wp-block-woocommerce-product-gallery img,
.woocommerce-product-gallery img {
  border-radius: 16px;
}

/* Single product title */
.wp-block-post-title,
.product_title {
  font-family: 'Poppins', sans-serif !important;
  font-size: clamp(24px, 3vw, 36px) !important;
  font-weight: 800 !important;
  color: #1A1A1A !important;
  line-height: 1.2 !important;
  margin-bottom: 12px !important;
}

/* Single product price */
.wp-block-woocommerce-product-price .wc-block-components-product-price,
.summary .price {
  font-size: 24px !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
}

/* Quantity input */
.quantity input[type="number"],
.wc-block-components-quantity-selector input {
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 100px !important;
  padding: 8px 12px !important;
  text-align: center;
  color: #1A1A1A !important;
  background: #FFFFFF !important;
}
.wc-block-components-quantity-selector {
  border: 1.5px solid #EBEBEB !important;
  border-radius: 100px !important;
  overflow: hidden;
}
.wc-block-components-quantity-selector input {
  border: none !important;
  border-radius: 0 !important;
}
.wc-block-components-quantity-selector button {
  color: #1A1A1A !important;
  background: transparent !important;
  border: none !important;
  font-weight: 600 !important;
}
.wc-block-components-quantity-selector button:hover {
  color: #FE5F1B !important;
}

/* Add to cart button on single product */
.single_add_to_cart_button {
  font-size: 15px !important;
  padding: 14px 32px !important;
  min-width: 180px;
}

/* Product meta (SKU, categories, tags) */
.product_meta,
.woocommerce-product-details__short-description {
  font-family: 'Poppins', sans-serif !important;
  font-size: 13px;
  color: #666666;
}
.product_meta a {
  color: #FE5F1B;
  text-decoration: none;
}
.product_meta a:hover {
  text-decoration: underline;
}

/* Product tabs */
.woocommerce-tabs .tabs,
.wc-tabs {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 24px !important;
  display: flex;
  gap: 0;
  border-bottom: 2px solid #EBEBEB;
}
.woocommerce-tabs .tabs li a,
.wc-tabs li a {
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #999999 !important;
  text-decoration: none !important;
  padding: 12px 20px !important;
  display: block;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all 0.2s;
}
.woocommerce-tabs .tabs li.active a,
.wc-tabs li.active a {
  color: #1A1A1A !important;
  border-bottom-color: #FE5F1B !important;
}
.woocommerce-tabs .tabs li a:hover,
.wc-tabs li a:hover {
  color: #1A1A1A !important;
}

/* Related products heading */
.wp-block-heading:where([class*="related"]),
.related.products > h2 {
  font-size: 22px !important;
  font-weight: 700 !important;
}

/* ===== CART PAGE ===== */
/* Cart table */
.wc-block-cart .wc-block-cart-items {
  font-family: 'Poppins', sans-serif !important;
}
.wc-block-cart .wc-block-cart-items__row {
  border-bottom: 1px solid #EBEBEB !important;
  padding: 20px 0 !important;
}
.wc-block-cart .wc-block-components-product-name {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  color: #1A1A1A !important;
  text-decoration: none !important;
  font-size: 15px !important;
}
.wc-block-cart .wc-block-components-product-name:hover {
  color: #FE5F1B !important;
}

/* Cart totals sidebar */
.wc-block-cart .wp-block-woocommerce-cart-order-summary-block,
.wc-block-cart__totals-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
}

/* Proceed to checkout */
.wc-block-cart__submit-button {
  font-size: 15px !important;
  padding: 14px 32px !important;
  width: 100%;
}

/* Coupon input */
.wc-block-components-totals-coupon__input input {
  font-family: 'Poppins', sans-serif !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 100px !important;
  padding: 10px 18px !important;
  font-size: 13px !important;
}
.wc-block-components-totals-coupon__button {
  border-radius: 100px !important;
  background: #FE5F1B !important;
  color: #FFFFFF !important;
  font-size: 13px !important;
  padding: 10px 20px !important;
}
.wc-block-components-totals-coupon__button:hover {
  opacity: 0.8 !important;
}

/* Empty cart */
.wc-block-cart__empty-cart__title,
.cart-empty {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 22px !important;
  color: #1A1A1A !important;
  text-align: center;
}

/* ===== CHECKOUT ===== */
.wc-block-checkout {
  font-family: 'Poppins', sans-serif !important;
}
.wc-block-checkout input,
.wc-block-checkout select,
.wc-block-checkout textarea {
  font-family: 'Poppins', sans-serif !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 12px !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
  color: #333333 !important;
  transition: border-color 0.2s;
}
.wc-block-checkout input:focus,
.wc-block-checkout select:focus,
.wc-block-checkout textarea:focus {
  border-color: #FE5F1B !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(254,95,27,0.1) !important;
}
.wc-block-components-checkout-place-order-button {
  font-size: 16px !important;
  padding: 16px 36px !important;
  width: 100%;
}

/* Checkout section titles */
.wc-block-components-checkout-step__title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
  font-size: 16px !important;
}

/* ===== MINI CART DRAWER ===== */
.wc-block-mini-cart__drawer {
  font-family: 'Poppins', sans-serif !important;
}
.wc-block-mini-cart__drawer .wc-block-mini-cart__title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
}
.wc-block-mini-cart__footer-checkout {
  background: #FE5F1B !important;
  color: #FFFFFF !important;
  border-radius: 100px !important;
}
.wc-block-mini-cart__footer-checkout:hover {
  background: #E24D0F !important;
}
.wc-block-mini-cart__footer-cart {
  background: transparent !important;
  color: #1A1A1A !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 100px !important;
}

/* ===== BLOG ===== */
/* Blog post grid */
.wp-block-post-template {
  gap: 28px !important;
}

/* Blog post cards */
.wp-block-post {
  background: #FFFFFF;
  border: 1px solid #EBEBEB;
  border-radius: 16px;
  overflow: hidden;
  transition: box-shadow 0.3s, transform 0.3s;
}
.wp-block-post:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 40px rgba(0,0,0,0.08);
}

/* Blog featured image */
.wp-block-post-featured-image {
  overflow: hidden;
  margin: 0 !important;
}
.wp-block-post-featured-image img {
  width: 100%;
  height: auto;
  transition: transform 0.3s;
  object-fit: cover;
}
.wp-block-post:hover .wp-block-post-featured-image img {
  transform: scale(1.03);
}

/* Blog post title */
.wp-block-post .wp-block-post-title {
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  padding: 0 20px !important;
  margin: 16px 0 6px !important;
}
.wp-block-post .wp-block-post-title a {
  color: #1A1A1A !important;
  text-decoration: none !important;
}
.wp-block-post .wp-block-post-title a:hover {
  color: #FE5F1B !important;
}

/* Blog post date */
.wp-block-post-date {
  font-family: 'Poppins', sans-serif !important;
  font-size: 12px !important;
  color: #999999 !important;
  font-weight: 500 !important;
  padding: 0 20px !important;
}

/* Blog post excerpt / content in grid */
.wp-block-post .wp-block-post-content,
.wp-block-post .wp-block-post-excerpt {
  font-size: 14px !important;
  color: #666666 !important;
  line-height: 1.7 !important;
  padding: 0 20px 20px !important;
}
.wp-block-post .wp-block-post-excerpt__more-link {
  color: #FE5F1B !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  font-size: 13px !important;
}
.wp-block-post .wp-block-post-excerpt__more-link:hover {
  text-decoration: underline !important;
}

/* Single blog post */
.single-post .wp-block-post-content {
  max-width: 720px;
  margin: 0 auto;
}
.single-post .wp-block-post-content p {
  font-size: 16px;
  line-height: 1.8;
  color: #333333;
  margin-bottom: 20px;
}
.single-post .wp-block-post-content h2 {
  font-size: 26px;
  margin: 40px 0 16px;
}
.single-post .wp-block-post-content h3 {
  font-size: 20px;
  margin: 32px 0 12px;
}
.single-post .wp-block-post-content img {
  border-radius: 16px;
}
.single-post .wp-block-post-content blockquote {
  border-left: 3px solid #FE5F1B;
  padding-left: 20px;
  margin: 24px 0;
  font-style: italic;
  color: #666666;
}

/* Blog pagination */
.wp-block-query-pagination {
  font-family: 'Poppins', sans-serif !important;
  gap: 8px !important;
  margin-top: 40px !important;
  justify-content: center !important;
}
.wp-block-query-pagination-numbers .page-numbers {
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #1A1A1A !important;
  text-decoration: none !important;
  transition: all 0.2s;
}
.wp-block-query-pagination-numbers .page-numbers.current,
.wp-block-query-pagination-numbers .page-numbers:hover {
  background: #FE5F1B !important;
  color: #FFFFFF !important;
}
.wp-block-query-pagination-next,
.wp-block-query-pagination-previous {
  font-weight: 600 !important;
  color: #FE5F1B !important;
  text-decoration: none !important;
}

/* ===== STATIC PAGES (About, Store Finder, etc.) ===== */
/* Page title */
.page .wp-block-post-title,
.page-title {
  text-align: center;
  margin-bottom: 32px !important;
}

/* Content pages — clean typography */
.page .wp-block-post-content p {
  font-size: 15px;
  line-height: 1.8;
  color: #333333;
  max-width: 1100px;
}
.page .wp-block-post-content h2 {
  font-size: clamp(22px, 2.5vw, 30px);
  margin: 40px 0 16px;
}
.page .wp-block-post-content h3 {
  font-size: 18px;
  margin: 28px 0 12px;
}

/* Images on content pages */
.page .wp-block-post-content .wp-block-image img {
  border-radius: 16px;
}

/* Column blocks */
.wp-block-columns {
  gap: 28px !important;
}
.page .wp-block-column {
  background: #FFFFFF;
  border: 1px solid #EBEBEB;
  border-radius: 16px;
  padding: 28px 24px;
}

/* ===== FORMS (Jetpack, Contact, etc.) ===== */
.jetpack-contact-form input[type="text"],
.jetpack-contact-form input[type="email"],
.jetpack-contact-form input[type="tel"],
.jetpack-contact-form textarea,
.jetpack-contact-form select,
.wp-block-search__input,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 textarea {
  font-family: 'Poppins', sans-serif !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 12px !important;
  padding: 12px 18px !important;
  font-size: 14px !important;
  color: #333333 !important;
  background: #FFFFFF !important;
  transition: border-color 0.2s;
  width: 100%;
}
.jetpack-contact-form input:focus,
.jetpack-contact-form textarea:focus,
.jetpack-contact-form select:focus,
.wp-block-search__input:focus,
.wpcf7 input:focus,
.wpcf7 textarea:focus {
  border-color: #FE5F1B !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(254,95,27,0.1) !important;
}
.jetpack-contact-form label,
.wpcf7 label {
  font-family: 'Poppins', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #1A1A1A !important;
  margin-bottom: 6px !important;
  display: block;
}

/* Search */
.wp-block-search__button {
  background: #FE5F1B !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  padding: 12px 22px !important;
}
.wp-block-search__button:hover {
  background: #E24D0F !important;
}

/* ===== WOOCOMMERCE NOTICES ===== */
.woocommerce-message,
.wc-block-components-notice-banner.is-success {
  border-color: #21D873 !important;
  background: #f0fdf4 !important;
  font-family: 'Poppins', sans-serif !important;
  border-radius: 12px !important;
  font-size: 14px !important;
}
.woocommerce-error,
.wc-block-components-notice-banner.is-error {
  border-color: #FE5F1B !important;
  background: #fff5f2 !important;
  font-family: 'Poppins', sans-serif !important;
  border-radius: 12px !important;
  font-size: 14px !important;
}
.woocommerce-info,
.wc-block-components-notice-banner.is-info {
  border-color: #155CFC !important;
  background: #f0f6ff !important;
  font-family: 'Poppins', sans-serif !important;
  border-radius: 12px !important;
  font-size: 14px !important;
}

/* ===== 404 PAGE ===== */
.error-404 h1,
.page-title.error-404 {
  font-size: 80px !important;
  font-weight: 800 !important;
  color: #EFE8E2 !important;
  text-align: center;
}

/* ===== STAR RATINGS ===== */
.star-rating,
.wc-block-components-product-rating {
  color: #E8A817 !important;
}

/* ===== GENERAL SPACING & POLISH ===== */
/* Ensure no jarring background clashes */
.wp-site-blocks {
  background: #FFFFFF;
}

/* Smooth scroll for anchor links */
html {
  scroll-behavior: smooth;
}

/* Selection color */
::selection {
  background: rgba(254,95,27,0.15);
  color: #1A1A1A;
}

/* Focus styles for accessibility */
:focus-visible {
  outline: 2px solid #FE5F1B !important;
  outline-offset: 2px;
  border-radius: 4px;
}

/* ===== RESPONSIVE ADJUSTMENTS ===== */
@media (max-width: 768px) {
  /* Blog grid to single column */
  .wp-block-post-template.columns-2,
  .wp-block-post-template.columns-3 {
    grid-template-columns: 1fr !important;
    max-width: 400px;
    margin: 0 auto;
  }

  /* Product grid on mobile */
  .wc-block-product-template.columns-3,
  .wc-block-product-template.columns-4,
  .wc-block-product-template.columns-5,
  .wc-block-product-template.columns-6 {
    grid-template-columns: 1fr 1fr !important;
  }

  /* Stack columns on mobile */
  .wp-block-columns {
    flex-direction: column !important;
  }

  /* Page title smaller on mobile */
  .wp-block-post-title,
  .product_title {
    font-size: 24px !important;
  }

  /* Cart/checkout full width buttons */
  .wc-block-cart__submit-button,
  .wc-block-components-checkout-place-order-button {
    font-size: 14px !important;
    padding: 14px 24px !important;
  }
}

@media (max-width: 480px) {
  /* Single column products on small phones */
  .wc-block-product-template.columns-3,
  .wc-block-product-template.columns-4,
  .wc-block-product-template.columns-5,
  .wc-block-product-template.columns-6 {
    grid-template-columns: 1fr !important;
    max-width: 340px;
    margin: 0 auto;
  }
}

/* ===== WAITLIST PLUGIN STYLING ===== */
.xoo-wl-form {
  font-family: 'Poppins', sans-serif !important;
}
.xoo-wl-form input[type="email"] {
  border: 1.5px solid #EBEBEB !important;
  border-radius: 100px !important;
  padding: 12px 18px !important;
  font-family: 'Poppins', sans-serif !important;
}
.xoo-wl-form button {
  background: #FE5F1B !important;
  color: #FFFFFF !important;
  border-radius: 100px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
}

/* ===== SHIPPING & RETURNS / POLICY PAGES ===== */
.page .wp-block-post-content ul,
.page .wp-block-post-content ol {
  font-size: 15px;
  line-height: 1.8;
  color: #333333;
  padding-left: 24px;
}
.page .wp-block-post-content li {
  margin-bottom: 8px;
}

/* Tables (if any on policy pages) */
.wp-block-table table,
.woocommerce table {
  font-family: 'Poppins', sans-serif !important;
  border-collapse: collapse;
  width: 100%;
  font-size: 14px;
}
.wp-block-table th,
.woocommerce table th {
  background: #EFE8E2 !important;
  color: #1A1A1A !important;
  font-weight: 700 !important;
  padding: 12px 16px !important;
  text-align: left;
}
.wp-block-table td,
.woocommerce table td {
  padding: 12px 16px !important;
  border-bottom: 1px solid #EBEBEB !important;
  color: #333333;
}

/* ===== WOOCOMMERCE RESULT COUNT & ORDERING ===== */
.woocommerce-result-count,
.wc-block-product-results-count {
  font-family: 'Poppins', sans-serif !important;
  font-size: 13px !important;
  color: #999999 !important;
}
.woocommerce-ordering select,
.wc-block-product-sort-select select {
  font-family: 'Poppins', sans-serif !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 100px !important;
  padding: 8px 16px !important;
  font-size: 13px !important;
  color: #333333 !important;
  background: #FFFFFF !important;
}

/* ===== ACCOUNT PAGES ===== */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #333333 !important;
  text-decoration: none !important;
  padding: 12px 20px !important;
  display: block;
  border-radius: 12px;
  transition: all 0.2s;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: #EFE8E2 !important;
  color: #1A1A1A !important;
  font-weight: 600 !important;
}

/* ===== CONTACT & ABOUT PAGE JETPACK FORM ===== */
.cabs-contact-page .wp-block-jetpack-contact-form,
.cabs-about-page .wp-block-jetpack-contact-form,
.page-id-3160 .wp-block-jetpack-contact-form {
  font-family: 'Poppins', sans-serif !important;
}
.cabs-contact-page .wp-block-jetpack-contact-form input[type="text"],
.cabs-contact-page .wp-block-jetpack-contact-form input[type="email"],
.cabs-contact-page .wp-block-jetpack-contact-form textarea,
.page-id-3160 .wp-block-jetpack-contact-form input[type="text"],
.page-id-3160 .wp-block-jetpack-contact-form input[type="email"],
.page-id-3160 .wp-block-jetpack-contact-form textarea {
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  border: 1.5px solid #EBEBEB !important;
  border-radius: 12px !important;
  padding: 12px 16px !important;
  transition: border-color 0.2s !important;
  background: #FAFAFA !important;
}
.cabs-contact-page .wp-block-jetpack-contact-form input:focus,
.cabs-contact-page .wp-block-jetpack-contact-form textarea:focus,
.page-id-3160 .wp-block-jetpack-contact-form input:focus,
.page-id-3160 .wp-block-jetpack-contact-form textarea:focus {
  border-color: #FE5F1B !important;
  outline: none !important;
  background: #FFFFFF !important;
}
.cabs-contact-page .wp-block-jetpack-contact-form button[type="submit"],
.page-id-3160 .wp-block-jetpack-contact-form button[type="submit"],
.wp-block-jetpack-button button {
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  background: #FE5F1B !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 100px !important;
  padding: 13px 36px !important;
  cursor: pointer;
  transition: opacity 0.2s !important;
}
.cabs-contact-page .wp-block-jetpack-contact-form button[type="submit"]:hover,
.page-id-3160 .wp-block-jetpack-contact-form button[type="submit"]:hover,
.wp-block-jetpack-button button:hover {
  opacity: 0.85 !important;
}
.cabs-contact-page .wp-block-jetpack-contact-form label,
.page-id-3160 .wp-block-jetpack-contact-form label {
  font-family: 'Poppins', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #1A1A1A !important;
  margin-bottom: 6px !important;
}

/* Contact page: style Jetpack form as a card below FAQ */
.page-id-3160 > .entry-content > .wp-block-jetpack-contact-form,
.page-id-3160 .wp-block-post-content > .wp-block-jetpack-contact-form {
  max-width: 680px !important;
  margin: 0 auto 64px !important;
  padding: 40px 36px !important;
  background: #FFFFFF !important;
  border: 1px solid #EBEBEB !important;
  border-radius: 16px !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.04) !important;
}
/* Add a heading-like effect before the form */
.page-id-3160 > .entry-content > .wp-block-jetpack-contact-form::before,
.page-id-3160 .wp-block-post-content > .wp-block-jetpack-contact-form::before {
  content: "Send Us a Message";
  display: block;
  font-family: 'Poppins', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #1A1A1A;
  margin-bottom: 24px;
}
/* Hide the "Send Us a Message" div in the HTML block since form is separate */
.cabs-contact-form-wrap { display: none !important; }

/* ===== OVERRIDE BLACK BUTTONS SITE-WIDE ===== */
.cabs-btn-dark {
  background: transparent !important;
  color: #1A1A1A !important;
  border: 1.5px solid #1A1A1A !important;
}
.cabs-btn-dark:hover {
  border-color: #888 !important;
}

/* ===== HIDE DEFAULT PAGE TITLE ON ABOUT & CONTACT ===== */
.page-id-1 .wp-block-post-title,
.page-id-3160 .wp-block-post-title,
.page-id-1 .entry-title,
.page-id-3160 .entry-title {
  display: none !important;
}


/* Center About page headlines - How It All Started section */
.cabs-about-story {
  text-align: center;
}
.cabs-about-story .cabs-about-story-label,
.cabs-about-story h2 {
  text-align: center;
}


/* Hide product category and tags from product page display (kept in metadata) */
.single-product .taxonomy-product_cat,
.single-product .taxonomy-product_tag {
    display: none !important;
}


/* ===== CABCS-PAGE-397-FIXES : alignment + density fixes for /bring-collegiate-abcs-to-your-school/ ===== */
@media (min-width: 782px) {
  .page-id-397 #community-campaign .wp-block-columns {
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 40px;
  }
  .page-id-397 #community-campaign .wp-block-columns > .wp-block-column {
    flex: 1 1 0 !important;
  }
  .page-id-397 #community-campaign .wp-block-columns > .wp-block-column[style*="flex-basis:100%"] {
    flex-basis: 0 !important;
  }
}
.page-id-397 .cabcs-campaign-stats br,
.page-id-397 #community-campaign div[style*="space-between"] br { display: none; }
.page-id-397 .cabcs-campaigns-carousel p:empty { display: none; }
.page-id-397 .cabcs-campaigns-carousel > p,
.page-id-397 .cabcs-campaigns-track > p { margin: 0; }
.page-id-397 .cabcs-campaign-tile > p:last-child { margin-top: auto; margin-bottom: 0; }
.page-id-397 .cabcs-campaign-tile .cabcs-campaign-cta { margin-top: 0; }
@media (min-width: 782px) {
  .page-id-397 .entry-content > .wp-block-group { padding-top: 60px !important; padding-bottom: 60px !important; }
  .page-id-397 .entry-content > .wp-block-group:nth-child(2) { padding-top: 18px !important; padding-bottom: 18px !important; }
}
@media (max-width: 781px) {
  .page-id-397 .entry-content > .wp-block-group { padding-top: 36px !important; padding-bottom: 36px !important; }
  .page-id-397 .entry-content > .wp-block-group:nth-child(2) { padding-top: 16px !important; padding-bottom: 16px !important; }
  .page-id-397 #community-campaign .wp-block-columns { gap: 24px; }
}
/* ===== end CABCS-PAGE-397-FIXES ===== */

/* ===== CABCS-PAGE-397-COLUMNS-RESTORE : core block 'columns' rule (flex-basis:0;flex-grow:1) is missing site-wide, so equal-width columns collapse into stacks. Restore correct desktop behavior for this page. ===== */
@media (min-width: 782px) {
  .page-id-397 .entry-content .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column:not([style*="flex-basis"]) {
    flex-basis: 0 !important;
    flex-grow: 1 !important;
  }
}
/* ===== end CABCS-PAGE-397-COLUMNS-RESTORE ===== */

/* ===== CABCS-397-CARD-ALIGN : column rows were align-items:center, staggering cards of different lengths. Stretch them for clean equal-height, top-aligned cards (campaign section keeps its own flex-start). ===== */
@media (min-width: 782px) {
  .page-id-397 .entry-content .wp-block-columns:not(.is-not-stacked-on-mobile) { align-items: stretch; }
}
/* ===== end CABCS-397-CARD-ALIGN ===== */

/* ===== CABCS-397-FORM-STYLE : match the Jetpack form submit button to the brand pill buttons + readable inputs ===== */
.page-id-397 form.contact-form button[type="submit"],
.page-id-397 .wp-block-jetpack-contact-form button[type="submit"] {
  background:#fe5f1b !important; color:#fff !important; border:none !important;
  border-radius:100px !important; padding:14px 36px !important; font-weight:600 !important;
  font-size:16px !important; cursor:pointer; box-shadow:none !important; width:auto !important;
}
.page-id-397 form.contact-form button[type="submit"]:hover,
.page-id-397 .wp-block-jetpack-contact-form button[type="submit"]:hover { background:#d36f3c !important; }
.page-id-397 .wp-block-jetpack-contact-form { max-width:640px; margin-left:auto; margin-right:auto; }
.page-id-397 form.contact-form input[type="text"],
.page-id-397 form.contact-form input[type="email"],
.page-id-397 form.contact-form select,
.page-id-397 form.contact-form textarea { border-radius:8px; }
/* ===== end CABCS-397-FORM-STYLE ===== */

/* ===== CABCS-397-RESTORE-INLINE : FAQ + carousel CSS recovered from inline <style> blocks that wpautop corrupts inside the Classic block. Also restores core button-centering. ===== */
/* buttons: core .is-content-justification-center rule was stripped site-wide */
.page-id-397 .wp-block-buttons.is-content-justification-center { justify-content: center; }
.page-id-397 .wp-block-buttons.is-content-justification-right { justify-content: flex-end; }

/* ---- Active Community Campaigns carousel ---- */
.cabcs-campaigns-carousel { position: relative; max-width: 100%; margin: 0 auto; padding: 0 56px; box-sizing: border-box; }
  .cabcs-campaigns-track {
    display: flex;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding: 8px 16px 24px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .cabcs-campaigns-track::-webkit-scrollbar { display: none; }
  .cabcs-campaign-tile {
    flex: 0 0 clamp(280px, 88%, 460px);
    scroll-snap-align: center;
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
  }
  .cabcs-campaign-tile h3 { margin: 0 0 8px; font-size: 24px; line-height: 1.2; }
  .cabcs-campaign-school { margin: 0 0 16px; color: #555; font-size: 14px; }
  .cabcs-campaign-progress {
    background: #eaeaea;
    border-radius: 999px;
    height: 8px;
    overflow: hidden;
    margin: 8px 0 12px;
  }
  .cabcs-campaign-progress span {
    display: block;
    height: 100%;
    background: #fe5f1b;
    border-radius: 999px;
  }
  .cabcs-campaign-stats {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    color: #555;
    margin-bottom: 24px;
  }
  .cabcs-campaign-cta {
    display: inline-block;
    background: #fe5f1b;
    color: #fff;
    padding: 12px 24px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 600;
    text-align: center;
    margin-top: auto;
  }
  .cabcs-campaign-cta:hover { background: #d36f3c; }
  .cabcs-campaigns-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: #fff;
    border: 1px solid #ddd;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    line-height: 1;
    color: #333;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    z-index: 2;
    padding: 0;
  }
  .cabcs-campaigns-arrow:hover { background: #f5f5f5; }
  .cabcs-campaigns-arrow--prev { left: 4px; }
  .cabcs-campaigns-arrow--next { right: 4px; }
  .cabcs-campaigns-arrow[disabled] { opacity: 0.3; cursor: default; }
  .cabcs-campaigns-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 4px;
  }
  .cabcs-campaigns-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #d4d4d4;
    border: 0;
    cursor: pointer;
    padding: 0;
  }
  .cabcs-campaigns-dot[aria-current="true"] { background: #fe5f1b; }
  @media (max-width: 600px) {
    .cabcs-campaigns-arrow { display: none; }
    .cabcs-campaigns-carousel { padding: 0; }
  }

/* ---- FAQ accordion ---- */
.cabcs-faq{max-width:820px;margin:0 auto}
.cabcs-faq details{border-bottom:1px solid #e0e0e0;background:transparent}
.cabcs-faq details > summary{list-style:none;cursor:pointer;padding:20px 44px 20px 0;font-size:17px;font-weight:700;color:#222;position:relative;line-height:1.4}
.cabcs-faq details > summary::-webkit-details-marker{display:none}
.cabcs-faq details > summary::after{content:"";position:absolute;right:8px;top:50%;width:10px;height:10px;border-right:2px solid #fe5f1b;border-bottom:2px solid #fe5f1b;transform:translateY(-75%) rotate(45deg);transition:transform .2s ease}
.cabcs-faq details[open] > summary::after{transform:translateY(-25%) rotate(-135%);transform:translateY(-25%) rotate(-135deg)}
.cabcs-faq details[open] > summary{color:#fe5f1b}
.cabcs-faq .cabcs-faq-answer{padding:0 0 22px;font-size:15px;color:#666;line-height:1.6}
.cabcs-faq .cabcs-faq-answer a{color:#fe5f1b;text-decoration:underline}
.cabcs-faq-subhead{margin:40px 0 4px;font-size:18px;font-weight:700;color:#fe5f1b;letter-spacing:1px;text-transform:uppercase}
@media (max-width:600px){
  .cabcs-faq details > summary{font-size:16px;padding:18px 36px 18px 0}
  .cabcs-faq .cabcs-faq-answer{font-size:14.5px}
}
/* ===== end CABCS-397-RESTORE-INLINE ===== */

/* ===== CABCS-397-DESIGN-SYSTEM : align page 397 to the site design system (Poppins, #1a1a1a/700 headings, #fe5f1b accent, 11px/2.5px eyebrows) ===== */
.page-id-397 .entry-content [style*="border-color:#e8804a"]{border-color:#fe5f1b !important;}
.page-id-397 .entry-content [style*="background-color:#e8804a"]{background-color:#fe5f1b !important;}
.page-id-397 .entry-content [style*="background:#e8804a"]{background:#fe5f1b !important;}
.page-id-397 .entry-content p[style*="letter-spacing"]{color:#e8804a !important;font-size:13px !important;letter-spacing:2px !important;font-weight:600 !important;line-height:1.5 !important;}
.page-id-397 .entry-content [style*="#9a4a1a"]{color:#e8804a !important;}
.page-id-397 .entry-content h1,.page-id-397 .entry-content h2{font-weight:700 !important;}
.page-id-397 .entry-content h1{font-size:48px !important;line-height:1.25 !important;font-weight:800 !important;}
@media (max-width:781px){.page-id-397 .entry-content h1{font-size:32px !important;}}
/* ===== end CABCS-397-DESIGN-SYSTEM ===== */

/* === Sponsor a Classroom polish (Claude) === */
h1,h2,h3,h4,h5,.wp-block-heading{text-wrap:balance;}
p,.wp-block-paragraph,li{text-wrap:pretty;}
.wp-block-jetpack-contact-form button[type="submit"],
.wp-block-jetpack-contact-form .wp-block-button__link,
.wp-block-jetpack-button button,
.wp-block-jetpack-button .wp-block-button__link{
background-color:#e8804a !important;color:#fff !important;border:none !important;border-radius:100px !important;padding:16px 40px !important;font-weight:600 !important;width:auto !important;display:inline-block !important;cursor:pointer;}
.wp-block-jetpack-contact-form button[type="submit"]:hover,.wp-block-jetpack-button button:hover{opacity:.9;}


/* ===== CABCS-397-POLISH : spacing + readability polish to match site density ===== */
/* Headings always the dark system color (a card heading was set white inline) */
.page-id-397 .entry-content h1,.page-id-397 .entry-content h2,.page-id-397 .entry-content h3,.page-id-397 .entry-content h4{color:#1a1a1a !important;}
/* Card columns: more internal breathing room (was ~28/24) */
.page-id-397 .entry-content .wp-block-column.has-border-color,
.page-id-397 .entry-content .wp-block-column.has-background{padding:32px 28px !important;}
/* Contact form: constrain to a comfortable measure, centered, so it isn't flush to the edges */
.page-id-397 .wp-block-jetpack-contact-form,.page-id-397 form.contact-form{max-width:640px;margin-left:auto;margin-right:auto;}
/* ===== end CABCS-397-POLISH ===== */

/* ===== CABCS-397-SIMPLIFY : one calm, consistent card style + tidy spacing to match the rest of the site ===== */
/* Unified card: white, subtle warm border, soft radius, no shadow, no orange-emphasis borders */
.page-id-397 .entry-content .wp-block-column.has-border-color,
.page-id-397 .entry-content .wp-block-column.has-background,
.page-id-397 .cabcs-campaign-tile{
  background:#ffffff !important;
  border:1px solid #ebebeb !important;
  border-radius:16px !important;
  box-shadow:none !important;
}
.page-id-397 .entry-content .wp-block-column.has-border-color,
.page-id-397 .entry-content .wp-block-column.has-background{ padding:32px 28px !important; }
/* calmer, consistent heading rhythm */
.page-id-397 .entry-content h2{ margin-top:0 !important; margin-bottom:22px !important; }
.page-id-397 .entry-content .wp-block-columns{ gap:28px !important; }
/* ===== end CABCS-397-SIMPLIFY ===== */

/* ===== CABCS-397-HIDE-BADGE : remove the leftover broken "New" badge on the Community-Funded card (paragraph only — never the buttons) ===== */
.page-id-397 .entry-content p[style*="background-color:#e8804a"]{ display:none !important; }
/* ===== end CABCS-397-HIDE-BADGE ===== */

/* ===== CABCS-397-SENDABOOK : match /send-a-book/ patterns (white hero, arrow buttons, orange featured borders) ===== */
.page-id-397 .entry-content > .wp-block-group:first-child{ background-color:transparent !important; border-radius:0 !important; }
.page-id-397 .wp-block-button__link{ padding:12px 26px !important; font-weight:600 !important; }
.page-id-397 .wp-block-button__link::after{ content:" \2192"; }

/* ===== end CABCS-397-SENDABOOK ===== */

/* ===== CABCS-397-SPACING : exact /send-a-book/ section rhythm (hero 80/40) ===== */
.page-id-397 .entry-content > .wp-block-group:first-child{ padding-top:80px !important; padding-bottom:40px !important; }
/* ===== end CABCS-397-SPACING ===== */

/* ===== CABCS-397-WHITEBLOCK ===== */
.page-id-397 .entry-content .wp-block-group:has(> .wp-block-list){ background-color:transparent !important; border-radius:0 !important; }
/* ===== end ===== */