/* ============================================================
   ClassClobber Modern — Visual Overhaul CSS
   Loads AFTER stylesheet.css to override without touching originals
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@600;700;800&display=swap');

/* --- Design Tokens --- */
:root {
  --cc-blue: #23a1d1;
  --cc-blue-dark: #1b8ab5;
  --cc-blue-light: #e8f4fa;
  --cc-red: #e02b27;
  --cc-gold: #f5a623;
  --cc-text: #4a5568;
  --cc-heading: #1a2b3c;
  --cc-bg: #ffffff;
  --cc-surface: #ffffff;
  --cc-border: #e2e8f0;
  --cc-footer-bg: #1a2b3c;
  --cc-footer-text: #94a3b8;
  --cc-radius: 10px;
  --cc-radius-sm: 6px;
  --cc-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
  --cc-shadow-hover: 0 8px 30px rgba(0, 0, 0, 0.12);
  --cc-transition: 0.25s ease;
}

/* --- 1. Global Typography (with !important to beat Megnor specificity) --- */
body {
  font-family: 'Raleway', sans-serif !important;
  font-size: 15px !important;
  line-height: 1.7;
  color: var(--cc-text);
  background-color: var(--cc-bg);
}

h1, h2, h3, h4, h5, h6,
.box-heading,
.refine-search a,
.caption h4 a,
.product-thumb .caption h4 a,
.product-block .caption h4 a {
  font-family: 'Nunito', sans-serif !important;
  color: var(--cc-heading);
  font-weight: 700;
}

h2 { font-size: 28px; }
h3 { font-size: 22px; }
h4 { font-size: 16px; }

a {
  color: var(--cc-blue);
  transition: color var(--cc-transition);
}
a:hover {
  color: var(--cc-blue-dark);
}

/* --- 2. Top Bar --- */
#top {
  background: var(--cc-heading);
  height: auto;
  padding: 6px 0;
  font-size: 13px;
}
#top a,
#top .phone span {
  color: #cbd5e1;
}
#top a:hover {
  color: #ffffff;
}
#top .dropdown-menu {
  border-radius: var(--cc-radius-sm);
}

/* --- 3. Header / Logo --- */
header {
  background: transparent;
}
#logo {
  margin: 24px 0;
}

/* --- 4. Navigation --- */
/* Keep original OPC080193_4 menu styling from stylesheet.css. */
#menu .main-menu > ul > li > a,
#menu.main-menu .navbar-nav > li.top_level > a,
.main-menu > ul > li > a {
  background-image: none !important;
}

#menu.main-menu .navbar-nav > li.top_level > a,
#menu.responsive-menu > ul > li.top_level > a,
#menu.responsive-menu > ul > li > a {
  text-transform: uppercase;
}

/* --- 5. Feature Pills (header_bottom CMS content) --- */
.content_headercms_bottom {
  padding: 0;
}
.header_cms.container {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin: 12px auto;
  width: auto !important;
  max-width: 1200px;
}
.header_1cms.cont_inner,
.header_2cms.cont_inner,
.header_3cms.cont_inner {
  background: var(--cc-blue-light) !important;
  border-radius: 50px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 24px;
  float: none;
  transition: all var(--cc-transition);
}
.header_1cms.cont_inner:hover,
.header_2cms.cont_inner:hover,
.header_3cms.cont_inner:hover {
  background: var(--cc-blue) !important;
}
.header_1cms.cont_inner:hover .header_cms_text,
.header_2cms.cont_inner:hover .header_cms_text,
.header_3cms.cont_inner:hover .header_cms_text {
  color: #ffffff;
}
.header_content1,
.header_content2,
.header_content3 {
  padding: 10px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.header_cms_text {
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--cc-heading);
  transition: color var(--cc-transition);
}

/* --- 6. Product Cards — THE BIG ONE --- */
.product-thumb,
.product-block {
  background: var(--cc-surface);
  border: none;
  border-radius: var(--cc-radius);
  box-shadow: var(--cc-shadow);
  transition: transform var(--cc-transition), box-shadow var(--cc-transition);
  overflow: hidden;
  margin-bottom: 24px;
}
.product-thumb:hover,
.product-block:hover {
  transform: translateY(-4px);
  box-shadow: var(--cc-shadow-hover);
}
.product-thumb .image,
.product-block .image {
  overflow: hidden;
  border-radius: var(--cc-radius) var(--cc-radius) 0 0;
}
.product-thumb .image img,
.product-block .image img {
  transition: transform 0.4s ease;
}
.product-thumb:hover .image img,
.product-block:hover .image img {
  transform: scale(1.03);
}

/* Product details area */
.product-thumb .product-details,
.product-thumb .caption,
.product-block .product-details,
.product-block .caption {
  padding: 16px;
}
.product-thumb .caption h4,
.product-block .caption h4 {
  font-family: 'Nunito', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--cc-heading);
  margin: 0 0 6px 0;
  line-height: 1.4;
}
.product-thumb .caption h4 a,
.product-block .caption h4 a {
  color: var(--cc-heading);
}
.product-thumb .caption h4 a:hover,
.product-block .caption h4 a:hover {
  color: var(--cc-blue);
  text-decoration: none;
}

/* Price */
.product-thumb .price,
.product-block .price {
  font-family: 'Nunito', sans-serif !important;
  font-size: 18px;
  font-weight: 800;
  color: var(--cc-heading);
  margin: 8px 0;
}
.price-old {
  font-size: 14px;
  color: #94a3b8;
  font-weight: 400;
}
.price-new {
  color: var(--cc-red);
  font-weight: 800;
}

/* Sale badge */
.saleicon.sale {
  background: var(--cc-red);
  color: #fff;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 12px;
  padding: 4px 12px;
  border-radius: 50px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Button group (add to cart, wishlist, compare) */
.product-thumb .button-group,
.product-block .button-group {
  background: transparent;
  border: none;
  border-top: 1px solid var(--cc-border);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.product-thumb .button-group button,
.product-block .button-group button {
  border: none;
  border-radius: var(--cc-radius-sm);
  font-size: 13px;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--cc-transition);
}
.product-thumb .button-group .addtocart,
.product-block .button-group .addtocart {
  background: var(--cc-blue);
  color: #fff;
  padding: 8px 16px;
  flex: 1;
}
.product-thumb .button-group .addtocart:hover,
.product-block .button-group .addtocart:hover {
  background: var(--cc-blue-dark);
}
.product-thumb .button-group .wishlist,
.product-thumb .button-group .compare,
.product-block .button-group .wishlist,
.product-block .button-group .compare {
  background: var(--cc-bg);
  color: var(--cc-text);
  width: 36px;
  height: 36px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}
.product-thumb .button-group .wishlist:hover,
.product-thumb .button-group .compare:hover,
.product-block .button-group .wishlist:hover,
.product-block .button-group .compare:hover {
  background: var(--cc-blue-light);
  color: var(--cc-blue);
}

/* --- 7. Star Ratings --- */
.rating .fa-stack {
  font-size: 14px;
  width: 1.4em;
  height: 1.4em;
  line-height: 1.4em;
}
.rating .fa-star {
  color: #d4d4d8;
  font-size: 14px;
}
.rating .fa-stack .fa-star + .fa-star {
  color: var(--cc-gold);
}

/* --- 8. Category Page --- */
.category .page-title {
  font-family: 'Nunito', sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: var(--cc-heading);
  margin-bottom: 20px;
}

/* School/category pages: reduce title block whitespace before category image */
body[class*="product-category-"] .content-top-breadcum {
  margin-bottom: 8px !important;
  padding: 6px 0 4px !important;
}

/* Filter bar */
.category_filter {
  background: var(--cc-surface);
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  padding: 12px 16px;
  margin-bottom: 24px;
}
.category_filter .btn-default {
  border-radius: var(--cc-radius-sm);
  border-color: var(--cc-border);
}
.category_filter .btn-default:hover,
.category_filter .btn-default:focus {
  background: var(--cc-blue-light);
  border-color: var(--cc-blue);
  color: var(--cc-blue);
}
.category_filter .form-control {
  border-radius: var(--cc-radius-sm);
  border-color: var(--cc-border);
  font-size: 14px;
  height: 38px;
}

/* Product grid layout */
.category-product .product-layout {
  padding: 0 12px;
  margin-bottom: 24px;
}

/* Category list (subcategories) */
.category_list ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
}
.category_list ul li a {
  display: inline-block;
  padding: 6px 16px;
  background: var(--cc-blue-light);
  border-radius: 50px;
  color: var(--cc-blue);
  font-weight: 600;
  font-size: 14px;
  transition: all var(--cc-transition);
}
.category_list ul li a:hover {
  background: var(--cc-blue);
  color: #fff;
  text-decoration: none;
}

/* --- 9. Product Page --- */
/* Ensure all product page text uses Raleway (body) */
#content.productpage {
  font-family: 'Raleway', sans-serif !important;
}
/* Headings + prices use Nunito */
.productpage .page-title {
  font-family: 'Nunito', sans-serif !important;
  font-size: 26px;
  font-weight: 800;
  color: var(--cc-heading);
}
.productpage .product-title {
  font-family: 'Nunito', sans-serif !important;
  font-size: 22px;
  font-weight: 800;
}
.productpage .product-right h4 {
  font-family: 'Nunito', sans-serif !important;
  font-size: 28px;
  font-weight: 800;
  color: var(--cc-heading);
}
#content .product-right .product-price,
#content .product-right .special-price,
#content .product-right .old-price {
  font-family: 'Nunito', sans-serif !important;
}
.productpage .product-right .special-price {
  font-size: 28px;
  font-weight: 800;
  color: var(--cc-red);
}

/* Add to Cart button — make it POP */
#button-cart {
  background: var(--cc-blue) !important;
  border: none !important;
  color: #fff !important;
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 16px;
  padding: 14px 24px;
  border-radius: var(--cc-radius);
  width: auto !important;
  flex: 1;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: all var(--cc-transition);
  box-shadow: 0 4px 12px rgba(35, 161, 209, 0.3);
}
#button-cart:hover {
  background: var(--cc-blue-dark) !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(35, 161, 209, 0.4);
}

/* Product option form */
.productpage .form-group label {
  font-weight: 600;
  font-size: 15px;
  color: var(--cc-heading);
}
.productpage .form-control,
.productpage input.form-control,
.productpage select.form-control,
.productpage textarea.form-control {
  border-radius: var(--cc-radius-sm) !important;
  border-color: var(--cc-border);
  font-family: 'Raleway', sans-serif !important;
  font-size: 15px !important;
  padding: 10px 14px !important;
  height: auto !important;
}
.productpage .form-control:focus {
  border-color: var(--cc-blue);
  box-shadow: 0 0 0 3px rgba(35, 161, 209, 0.15);
}

/* Qty row — align label, input and button on one line */
.productpage .form-group:has(#input-quantity) {
  display: flex !important;
  align-items: center !important;
  gap: 12px;
  flex-wrap: wrap;
}
.control-label.qty {
  float: none !important;
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  white-space: nowrap;
}
#input-quantity {
  float: none !important;
  width: 60px !important;
  height: auto !important;
  padding: 12px 8px !important;
  font-size: 16px !important;
  text-align: center;
  border-radius: var(--cc-radius-sm);
  border: 1px solid var(--cc-border);
  margin: 0 !important;
}

/* Wishlist / Compare buttons */
.wish-comp {
  display: flex !important;
  gap: 10px;
}
.wish-comp .btn-default {
  border-radius: var(--cc-radius-sm);
  border-color: var(--cc-border);
  color: var(--cc-text);
  font-weight: 600;
  padding: 10px 22px !important;
  transition: all var(--cc-transition);
}
.wish-comp .btn-default i {
  margin-right: 8px;
}
.wish-comp .btn-default:hover {
  border-color: var(--cc-blue);
  color: var(--cc-blue);
  background: var(--cc-blue-light);
}

/* Tabs (Description / Reviews) */
.product-tab .nav-tabs {
  border-bottom: 2px solid var(--cc-border);
}
.product-tab .nav-tabs > li > a {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: var(--cc-text);
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  padding: 12px 20px;
  transition: all var(--cc-transition);
}
.product-tab .nav-tabs > li > a:hover {
  border-color: var(--cc-blue);
  color: var(--cc-blue);
  background: transparent;
}
.product-tab .nav-tabs > li.active > a,
.product-tab .nav-tabs > li.active > a:hover,
.product-tab .nav-tabs > li.active > a:focus {
  border: none;
  border-bottom: 2px solid var(--cc-blue);
  color: var(--cc-blue);
  background: transparent;
}
.product-tab .tab-content {
  padding: 20px 0;
  font-size: 15px;
  line-height: 1.7;
}

/* Related products heading */
.box.related .box-heading,
.box .box-heading {
  font-family: 'Nunito', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: var(--cc-heading);
  border: none;
  border-bottom: 2px solid var(--cc-border);
  padding-bottom: 12px;
  margin-bottom: 20px;
}

/* --- 10. Breadcrumbs --- */
.breadcrumb {
  background: transparent;
  padding: 12px 0;
  font-size: 13px;
  margin-bottom: 16px;
}
.breadcrumb > li > a {
  color: var(--cc-text);
}
.breadcrumb > li + li::before {
  color: #cbd5e1;
}
/* Product page: back link to parent category */
.cc-back-link {
  padding: 12px 0;
  font-size: 14px;
  margin-bottom: 8px;
}
.cc-back-link a {
  color: var(--cc-blue);
  text-decoration: none;
  font-weight: 600;
  transition: color var(--cc-transition);
}
.cc-back-link a:hover {
  color: var(--cc-blue-dark);
}

/* --- 11. Footer --- */
footer {
  background: var(--cc-footer-bg);
  margin-top: 40px;
}
#footer {
  padding: 48px 0 24px;
}
#footer h5 {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 16px;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 20px;
}
#footer .column ul li {
  margin-bottom: 8px;
}
#footer .column ul li a {
  color: var(--cc-footer-text);
  font-size: 14px;
  transition: color var(--cc-transition);
}
#footer .column ul li a:hover {
  color: #ffffff;
  text-decoration: none;
}

/* Footer left (company info) */
.content_footer_left {
  color: var(--cc-footer-text);
  font-size: 14px;
  line-height: 1.7;
}
.content_footer_left a {
  color: var(--cc-blue);
}
.content_footer_left a:hover {
  color: #ffffff;
}

/* Footer bottom */
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 20px 0;
  margin-top: 32px;
}
#bottom-footer ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px 20px;
}
#bottom-footer ul li a {
  color: var(--cc-footer-text);
  font-size: 13px;
}
#bottom-footer ul li a:hover {
  color: #ffffff;
}
#powered {
  text-align: center;
  color: rgba(255, 255, 255, 0.3);
  font-size: 12px;
  margin-top: 16px;
}

/* --- 12. Buttons (global) --- */
.btn-primary {
  background-color: var(--cc-blue);
  border-color: var(--cc-blue);
  border-radius: var(--cc-radius-sm);
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  transition: all var(--cc-transition);
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: var(--cc-blue-dark);
  border-color: var(--cc-blue-dark);
}

/* --- 13. Forms --- */
.form-control {
  border-radius: var(--cc-radius-sm);
  border-color: var(--cc-border);
  font-size: 15px;
  padding: 8px 14px;
  transition: border-color var(--cc-transition), box-shadow var(--cc-transition);
}
.form-control:focus {
  border-color: var(--cc-blue);
  box-shadow: 0 0 0 3px rgba(35, 161, 209, 0.15);
}

/* Search bar */
.header-search .search input.form-control {
  border-radius: 50px;
  padding: 8px 20px;
  font-size: 14px;
}

/* --- 14. Pagination --- */
.pagination > li > a,
.pagination > li > span {
  border-radius: var(--cc-radius-sm) !important;
  margin: 0 2px;
  color: var(--cc-text);
  border-color: var(--cc-border);
  font-weight: 600;
}
.pagination > li.active > a,
.pagination > li.active > span {
  background-color: var(--cc-blue);
  border-color: var(--cc-blue);
}

/* --- 15. Content-top breadcrumb banner (kill the dark grey bar) --- */
.content-top-breadcum {
  background: var(--cc-bg) !important;
  background-image: none !important;
  min-height: 0 !important;
  padding: 12px 0 !important;
  margin-bottom: 20px !important;
  border-bottom: none !important;
}
.content-top-breadcum .page-title,
.content-top-breadcum h1,
.content-top-breadcum h2,
#title-content h1,
#title-content h2 {
  font-family: 'Nunito', sans-serif !important;
  color: var(--cc-heading) !important;
  font-size: 24px !important;
  font-weight: 800 !important;
  text-shadow: none !important;
  margin: 0 !important;
}

/* --- 16. Page title banner --- */
h2.page-title {
  font-family: 'Nunito', sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: var(--cc-heading);
  border: none;
  padding-bottom: 12px;
  margin-bottom: 24px;
}

/* --- 17. Alert/notice bars --- */
.alert-info {
  border-radius: var(--cc-radius-sm);
}

/* --- 18. Contact page --- */
.information-contact .panel {
  border-radius: var(--cc-radius);
}

/* --- 19. Mobile refinements --- */
@media (max-width: 767px) {
  body {
    font-size: 14px;
  }
  h2.page-title {
    font-size: 22px;
  }
  .product-thumb .price,
  .product-block .price {
    font-size: 16px;
  }
  .product-thumb .button-group,
  .product-block .button-group {
    padding: 8px 12px;
  }
  .product-thumb .button-group .addtocart,
  .product-block .button-group .addtocart {
    font-size: 12px;
    padding: 6px 12px;
  }
  #footer {
    padding: 32px 0 16px;
  }
  #footer .column {
    margin-bottom: 24px;
  }
}

/* --- 20. Smooth scroll & global transitions --- */
html {
  scroll-behavior: smooth;
}

/* ============================================================
   PHASE 2 ADDITIONS
   ============================================================ */

/* --- 21. Hide old Megnor sprite icon containers --- */
.cms_img {
  display: none !important;
}

/* --- 22. Feature pill Font Awesome icons --- */
.header_content1 i,
.header_content2 i,
.header_content3 i,
.header_content1 .fa,
.header_content2 .fa,
.header_content3 .fa {
  display: none !important;
}

.header_content1::before,
.header_content2::before,
.header_content3::before {
  font-family: 'FontAwesome';
  font-size: 20px;
  line-height: 1;
  color: var(--cc-blue);
  transition: color var(--cc-transition);
  display: inline-block;
}

.header_content1::before { content: '\f095'; }
.header_content2::before { content: '\f02f'; }
.header_content3::before { content: '\f0d1'; }

.header_1cms.cont_inner:hover .header_content1::before,
.header_2cms.cont_inner:hover .header_content2::before,
.header_3cms.cont_inner:hover .header_content3::before {
  color: #ffffff;
}

.header_content1 .fa,
.header_content2 .fa,
.header_content3 .fa {
  font-size: 20px;
  color: var(--cc-blue);
  transition: color var(--cc-transition);
}
.header_1cms.cont_inner:hover .fa,
.header_2cms.cont_inner:hover .fa,
.header_3cms.cont_inner:hover .fa {
  color: #ffffff;
}

/* --- 23. Warning bar (cc-warning class for future re-enable) --- */
.cc-warning {
  font-family: 'Nunito', sans-serif !important;
  font-size: 16px;
  font-weight: 700;
  color: #d32f2f;
  text-align: center;
  padding: 10px 0;
  margin: 0;
}
/* Override any inline styles on the warning bar */
.content_headercms_bottom span[style],
.content_headercms_bottom p[style] {
  font-family: 'Nunito', sans-serif !important;
}

/* --- 24. Footer contact block --- */
#footer_aboutus_block {
  color: var(--cc-footer-text);
  font-size: 14px;
}
#footer_aboutus_block h5 {
  font-family: 'Nunito', sans-serif !important;
  font-weight: 800;
  font-size: 16px;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 20px;
}
#footer_aboutus_block ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
#footer_aboutus_block ul li {
  margin-bottom: 6px;
  color: var(--cc-footer-text);
  line-height: 1.6;
}
#footer_aboutus_block ul li.tm-about-logo {
  margin-bottom: 14px;
}
#footer_aboutus_block ul li.tm-about-logo img {
  max-width: 180px;
  height: auto;
}
#footer_aboutus_block ul li.phoneno::before {
  font-family: 'FontAwesome';
  content: '\f095';
  margin-right: 8px;
  color: var(--cc-blue);
}
#footer_aboutus_block ul li.email::before {
  font-family: 'FontAwesome';
  content: '\f0e0';
  margin-right: 8px;
  color: var(--cc-blue);
}
#footer_aboutus_block ul li.address::before {
  font-family: 'FontAwesome';
  content: '\f041';
  margin-right: 8px;
  color: var(--cc-blue);
}
#footer_aboutus_block ul li a {
  color: var(--cc-blue);
}
#footer_aboutus_block ul li a:hover {
  color: #ffffff;
  text-decoration: none;
}

/* --- 25. Homepage sections — consistent fonts/colours --- */
.banner_bottom_cms,
.home_testiminial,
.video_cms,
.bannerbottom_cms,
.home-page-cms {
  font-family: 'Raleway', sans-serif !important;
  color: var(--cc-text);
}
.banner_bottom_cms h2,
.banner_bottom_cms h3,
.home_testiminial h2,
.home_testiminial h3,
.video_cms h2,
.video_cms h3,
.bannerbottom_cms h2,
.bannerbottom_cms h3,
.home-page-cms h2,
.home-page-cms h3 {
  font-family: 'Nunito', sans-serif !important;
  color: var(--cc-heading) !important;
  font-weight: 800;
}

/* --- 26. Megnor tab headings on homepage --- */
.main-tab .tab-head h3,
.main-tab .tab-head .heading,
.megnortabs h3,
#tab_default_1,
#tab_default_2,
#tab_default_3,
.main-tab .nav-tabs > li > a {
  font-family: 'Nunito', sans-serif !important;
  color: var(--cc-heading);
  font-weight: 700;
}
.main-tab .nav-tabs > li.active > a {
  color: var(--cc-blue) !important;
  border-bottom-color: var(--cc-blue) !important;
}

/* --- 27. Stronger overrides for Megnor high-specificity selectors --- */
.category .page-title,
.productpage .page-title,
.account-page .page-title,
.information-page .page-title,
.checkout-page .page-title {
  font-family: 'Nunito', sans-serif !important;
  color: var(--cc-heading) !important;
  font-weight: 800 !important;
}
.productpage .product-right h1,
.productpage .product-right h2,
.productpage .product-right h3,
.productpage .product-right h4 {
  font-family: 'Nunito', sans-serif !important;
  color: var(--cc-heading) !important;
}

/* --- 28. Mobile refinements for Phase 2 --- */
@media (max-width: 767px) {
  .header_cms.container {
    flex-direction: column;
    gap: 6px;
  }
  .header_1cms.cont_inner,
  .header_2cms.cont_inner,
  .header_3cms.cont_inner {
    width: 100% !important;
    text-align: center;
  }
  .content-top-breadcum {
    padding: 8px 0 !important;
    margin-bottom: 12px !important;
  }
  .content-top-breadcum .page-title,
  .content-top-breadcum h1,
  .content-top-breadcum h2,
  #title-content h1,
  #title-content h2 {
    font-size: 20px !important;
  }
}

/* ============================================================
   PHASE 3 ADDITIONS — "Wow Factor"
   ============================================================ */

/* --- 29. Restyle the dark top bar to light --- */
#top {
  background: var(--cc-surface) !important;
  border-bottom: 1px solid var(--cc-border) !important;
  padding: 8px 0 !important;
  height: auto !important;
}
#top a,
#top .phone span,
#top .phone a {
  color: var(--cc-text) !important;
}
#top a:hover {
  color: var(--cc-blue) !important;
}
#top .header-search .search input.form-control {
  border: 1px solid var(--cc-border) !important;
  background: var(--cc-bg) !important;
  color: var(--cc-text) !important;
}
#top .header-cart .btn-inverse,
#top .header-cart .btn-block {
  background-color: transparent !important;
  border: none !important;
}
#top .header-cart .btn-inverse:hover {
  opacity: 0.8;
}
#top .header-right .account-toggle,
#top #top-links .dropdown > a {
  color: var(--cc-text) !important;
}
/* Cart badge counter */
#top .header-cart .cart-total,
#top .header-cart .badge,
#cart-total {
  color: var(--cc-heading) !important;
}

/* --- 30. "Please Select School" — School Grid --- */
.cc-school-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 20px 0;
}
.cc-school-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--cc-surface);
  border-radius: var(--cc-radius);
  box-shadow: var(--cc-shadow);
  padding: 24px 16px 20px;
  text-decoration: none !important;
  transition: transform var(--cc-transition), box-shadow var(--cc-transition);
  overflow: hidden;
}
.cc-school-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cc-shadow-hover);
  text-decoration: none !important;
}
.cc-school-card .cc-school-img {
  width: 100%;
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  overflow: hidden;
}
.cc-school-card .cc-school-img img {
  max-width: 100%;
  max-height: 120px;
  width: auto;
  object-fit: contain;
}
.cc-school-card h3 {
  font-family: 'Nunito', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--cc-heading) !important;
  text-align: center;
  margin: 0;
  line-height: 1.3;
}
.cc-school-card:hover h3 {
  color: var(--cc-blue) !important;
}
/* Placeholder icon for schools without images */
.cc-school-card--no-img .cc-school-img {
  background: var(--cc-blue-light);
  border-radius: var(--cc-radius-sm);
}
.cc-school-card--no-img .cc-school-img .fa {
  font-size: 48px;
  color: var(--cc-blue);
}

/* --- 31. Centre-align category banners on school pages --- */
/* Override theme display:none on .category_thumb .category_description */
.category_thumb {
  text-align: center !important;
  overflow: hidden !important;
}
.category_thumb .category_description {
  display: none !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  text-align: center !important;
  padding: 0 !important;
}
/* Keep school grid visible on "Please Select School" page */
.category_thumb .category_description:has(.cc-school-grid) {
  display: block !important;
}
/* Override col-sm-10 width limit on description */
.category_thumb .col-sm-10.category_description {
  width: 100% !important;
  max-width: 100% !important;
}
.category_thumb .col-sm-2.category_img {
  width: 100% !important;
  float: none !important;
  text-align: center !important;
  margin-bottom: 10px !important;
}
.category_description img,
.category_img img {
  max-width: 100% !important;
  height: auto !important;
  margin: 0 auto !important;
  display: inline-block !important;
}

/* Tighten school/category hero image block above product grid */
#content.category .category_thumb .category_img {
  margin-bottom: 6px !important;
}

#content.category .category_thumb .category_img .img-thumbnail {
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  width: auto !important;
  max-width: min(100%, 560px) !important;
  max-height: 260px !important;
  object-fit: contain !important;
  display: block !important;
}

/* --- 32. Homepage hero mobile fix --- */
.common-home .content_top img {
  max-width: 100% !important;
  height: auto !important;
}
.common-home #content img {
  max-width: 100%;
  height: auto;
}

/* --- 33. "Find Your School" CTA section --- */
.cc-find-school-cta {
  background: var(--cc-blue-light);
  padding: 48px 20px;
  text-align: center;
  margin: 0 -15px;
}
.cc-find-school-cta h2 {
  font-family: 'Nunito', sans-serif !important;
  font-size: 32px !important;
  font-weight: 800 !important;
  color: var(--cc-heading) !important;
  margin: 0 0 12px 0;
}
.cc-find-school-cta p {
  font-size: 17px;
  color: var(--cc-text);
  margin: 0 0 24px 0;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}
.cc-cta-btn {
  display: inline-block;
  background: var(--cc-blue) !important;
  color: #fff !important;
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 18px;
  padding: 14px 36px;
  border-radius: 50px;
  text-decoration: none !important;
  transition: all var(--cc-transition);
  box-shadow: 0 4px 12px rgba(35, 161, 209, 0.3);
}
.cc-cta-btn:hover {
  background: var(--cc-blue-dark) !important;
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(35, 161, 209, 0.4);
  text-decoration: none !important;
}
.cc-cta-btn .fa {
  margin-left: 8px;
}

/* --- 34. Footer cleanup — hide irrelevant links --- */
/* EXTRAS column: hide Brands (1st), Gift Certificates (2nd), Affiliates (3rd) */
#footer .row > :nth-child(3) ul li:nth-child(1),
#footer .row > :nth-child(3) ul li:nth-child(2),
#footer .row > :nth-child(3) ul li:nth-child(3) {
  display: none;
}
/* Bottom bar: hide Affiliates (2nd), Gift Certificates (3rd), Brands (4th) */
#bottom-footer ul li:nth-child(2),
#bottom-footer ul li:nth-child(3),
#bottom-footer ul li:nth-child(4) {
  display: none;
}
/* Fix OpenCart branding */
#powered {
  font-size: 0 !important;
  color: transparent !important;
}
#powered::after {
  content: 'Class Clobber \00a9  2026';
  font-size: 12px;
  color: rgba(255, 255, 255, 0.3);
  font-family: 'Raleway', sans-serif;
}

/* --- 35. Size Guide — card grid layout --- */
.cc-size-guide {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
  margin: 8px 0 32px;
}
.cc-size-section {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  overflow: hidden;
}
.cc-size-section h3 {
  font-family: 'Nunito', sans-serif;
  font-size: 16px;
  font-weight: 800;
  padding: 14px 20px;
  margin: 0;
  background: none;
  border-bottom: 1px solid var(--cc-border);
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--cc-heading);
}
.cc-cat-dot {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cc-size-section table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}
.cc-size-section thead th {
  background: var(--cc-bg);
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 20px;
  text-align: left;
  color: var(--cc-muted);
  white-space: nowrap;
  border-bottom: 1px solid var(--cc-border);
}
.cc-size-section tbody td {
  padding: 7px 20px;
  font-size: 14px;
  white-space: nowrap;
  border-bottom: 1px solid var(--cc-border);
  color: var(--cc-text);
}
.cc-size-section tbody tr:last-child td {
  border-bottom: none;
}
.cc-size-section tbody tr:hover td {
  background: var(--cc-blue-light);
}
/* Generic table styling for other information pages */
#content table:not(.cc-size-section table) {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0 24px;
  font-size: 14px;
}
#content table:not(.cc-size-section table) th,
#content table:not(.cc-size-section table) td {
  padding: 10px 16px;
  text-align: left;
  border-bottom: 1px solid var(--cc-border);
}
@media (max-width: 767px) {
  .cc-size-guide {
    grid-template-columns: 1fr;
  }
}

/* --- 36. Product card Add-to-Cart on hover --- */
.product-thumb .button-group {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s ease;
}
.product-thumb:hover .button-group {
  opacity: 1;
  transform: translateY(0);
}

/* --- 37. Consistent button styling (kill black buttons) --- */
/* Target action buttons inside #content only — avoid cart/search sprites */
#content .btn-primary,
#content .btn-default:not(#grid-view):not(#list-view),
a.btn.btn-primary {
  background-color: var(--cc-blue) !important;
  border-color: var(--cc-blue) !important;
  color: #fff !important;
  border-radius: var(--cc-radius-sm);
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  transition: all var(--cc-transition);
}
#content .btn-primary:hover,
#content .btn-default:not(#grid-view):not(#list-view):hover,
a.btn.btn-primary:hover {
  background-color: var(--cc-blue-dark) !important;
  border-color: var(--cc-blue-dark) !important;
  color: #fff !important;
}
/* Keep grid/list toggle buttons - don't override their sprite backgrounds */
.wish-comp .btn-default {
  background-color: transparent !important;
  color: var(--cc-text) !important;
  border-color: var(--cc-border) !important;
}
.wish-comp .btn-default:hover {
  background-color: var(--cc-blue-light) !important;
  color: var(--cc-blue) !important;
  border-color: var(--cc-blue) !important;
}

/* --- 38. Sticky header fix (scroll-triggered) --- */
/* Nav bar: light background, compact */
.nav-container.fixed {
  background: var(--cc-surface) !important;
  border-bottom: 1px solid var(--cc-border) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
}
/* Sticky header: consistent height, everything vertically centred */
.nav-container.fixed {
  height: 50px !important;
}
.nav-container.fixed .nav-inner,
.nav-container.fixed .nav-inner > .container {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
}
.nav-container.fixed .nav-inner > .container::before {
  content: '';
  flex-shrink: 0;
  width: 80px;
  height: 30px;
  background: url('../../../../../image/catalog/class-clobber-logo.png') no-repeat center / contain;
  margin-right: 12px;
}
.nav-container.fixed #menu.main-menu {
  flex: 1 !important;
  height: auto !important;
  display: flex !important;
  align-items: center !important;
}
.nav-container.fixed #menu ul {
  display: flex !important;
  align-items: center !important;
  float: none !important;
}
.nav-container.fixed .main-menu > ul > li {
  float: none !important;
}
.nav-container.fixed .main-menu > ul > li > a,
.nav-container.fixed .nav-responsive span {
  color: var(--cc-heading) !important;
  background: none !important;
  background-image: none !important;
  padding: 10px 20px !important;
}
.nav-container.fixed .main-menu > ul > li > a:hover,
.nav-container.fixed .main-menu > ul > li > a:focus {
  color: var(--cc-blue) !important;
}

.nav-container.responsive-active,
.nav-container.fixed.responsive-active {
  background: var(--cc-surface) !important;
  border-bottom: 1px solid var(--cc-border) !important;
}

.nav-container.responsive-active .nav-responsive,
.nav-container.fixed.responsive-active .nav-responsive {
  background: var(--cc-surface) !important;
  border: 1px solid var(--cc-border) !important;
}

.nav-container.responsive-active .nav-responsive span,
.nav-container.fixed.responsive-active .nav-responsive span {
  color: var(--cc-heading) !important;
  background: none !important;
  background-image: none !important;
}
/* Search/cart area: match nav height, vertically centred */
.header-right.header-right-fixed {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  height: 50px !important;
  padding: 0 15px 0 0 !important;
  display: flex !important;
  align-items: center !important;
}
/* Keep search input visible (theme collapses to width:0) */
.header-right.header-right-fixed #search .input-lg {
  width: 180px !important;
  border: 1px solid var(--cc-border) !important;
  background-color: var(--cc-bg) !important;
  color: var(--cc-text) !important;
}
.header-right.header-right-fixed #search:hover .input-lg,
.header-right.header-right-fixed #search .input-lg:focus {
  width: 180px !important;
  background-color: var(--cc-bg) !important;
  border-color: var(--cc-blue) !important;
}
/* Search icon: keep dark sprite (theme shifts to white on hover) */
.header-right.header-right-fixed #search .btn-lg {
  background-position: 8px 5px !important;
}
.header-right.header-right-fixed #search .btn-lg:hover {
  background-position: 8px -45px !important;
}
/* Cart: full size, just prevent white-variant hover */
.header-right.header-right-fixed #cart > .btn:hover {
  background-position: 0 -39px !important;
  opacity: 0.8 !important;
}

/* --- 39. Mobile navigation polish --- */
@media (max-width: 991px) {
  .nav-container,
  .nav-container.fixed {
    background: var(--cc-surface) !important;
    border-bottom: 1px solid var(--cc-border) !important;
  }

  .nav-container.fixed .nav-inner > .container::before {
    content: none !important;
    display: none !important;
  }

  .nav-container.fixed #menu.main-menu {
    border-bottom: none !important;
  }

  .nav-responsive,
  .nav-container .nav-responsive,
  .nav-container.fixed .nav-responsive {
    background: var(--cc-surface) !important;
    border: 1px solid var(--cc-border) !important;
  }

  .nav-responsive span,
  .nav-container.fixed .nav-responsive span {
    color: var(--cc-heading) !important;
    background: none !important;
    background-image: none !important;
  }

  #menu .navbar-nav > li > a {
    padding: 12px 16px !important;
    border-bottom: 1px solid var(--cc-border) !important;
  }
}

@media (max-width: 767px) {
  /* School grid: 2 columns on tablet, 1 on phone */
  .cc-school-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .cc-find-school-cta {
    padding: 32px 16px;
  }
  .cc-find-school-cta h2 {
    font-size: 24px !important;
  }
  .cc-cta-btn {
    font-size: 16px;
    padding: 12px 28px;
  }
}
@media (max-width: 480px) {
  .cc-school-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   PHASE 4 ADDITIONS — Homepage Slider & CTA Modernisation
   ============================================================ */

/* --- 40. Homepage Owl Carousel Slider --- */
.main-slider {
  position: relative;
  margin: 0 -15px 16px;
  border-radius: 0;
  overflow: hidden;
}
.main-slider .owl-carousel {
  margin-bottom: 0 !important;
}
.main-slider .owl-controls {
  margin-top: 0 !important;
}
.main-slider .owl-carousel .item img {
  width: 100%;
  height: auto;
  display: block;
}
/* Navigation arrows — high specificity to beat Megnor theme */
.main-slider .owl-carousel .owl-buttons .owl-prev,
.main-slider .owl-carousel .owl-buttons .owl-next {
  position: absolute;
  top: 50% !important;
  transform: translateY(-50%);
  background: transparent !important;
  color: #ffffff !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: all var(--cc-transition);
  box-shadow: none;
  margin: 0 !important;
  padding: 6px !important;
  border: none !important;
  z-index: 10;
}
.main-slider:hover .owl-carousel .owl-buttons .owl-prev,
.main-slider:hover .owl-carousel .owl-buttons .owl-next {
  opacity: 1;
}
.main-slider .owl-carousel .owl-buttons .owl-prev:hover,
.main-slider .owl-carousel .owl-buttons .owl-next:hover {
  background: transparent !important;
  color: #fff !important;
  opacity: 1;
}
.main-slider .owl-carousel .owl-buttons .owl-prev {
  left: 12px;
}
.main-slider .owl-carousel .owl-buttons .owl-next {
  right: 12px;
}
.main-slider .owl-carousel .owl-buttons div i {
  font-size: 40px !important;
  line-height: 1 !important;
  display: block;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}
/* Pagination dots */
.main-slider .owl-controls .owl-pagination {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: max-content;
  padding: 0 !important;
  margin: 0 !important;
  z-index: 10;
}
.main-slider .owl-controls .owl-page {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
}
.main-slider .owl-controls .owl-page span {
  display: block !important;
  width: 12px !important;
  height: 12px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.6) !important;
  border: 2px solid #fff !important;
  transition: all var(--cc-transition);
  font-size: 0 !important;
  line-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
.main-slider .owl-controls .owl-page.active span,
.main-slider .owl-controls .owl-page:hover span {
  background: var(--cc-blue) !important;
  border-color: var(--cc-blue) !important;
  transform: scale(1.2);
}
/* Hide spinner overlay */
.main-slider #spinner {
  display: none !important;
}

/* --- 41. Modernised "Find Your School" CTA --- */
.cc-find-school-cta {
  background: linear-gradient(135deg, var(--cc-blue-light) 0%, #f0f7ff 100%);
  padding: 56px 20px;
  text-align: center;
  margin: 0 -15px;
  border-top: 3px solid var(--cc-blue);
}
.cc-cta-inner {
  max-width: 600px;
  margin: 0 auto;
}
.cc-find-school-cta h2 {
  font-size: 36px !important;
  margin: 0 0 16px 0;
}
.cc-cta-subtitle {
  font-size: 18px;
  color: var(--cc-text);
  margin: 0 0 28px 0;
  line-height: 1.6;
}

/* --- 42. Slider mobile --- */
@media (max-width: 767px) {
  .main-slider {
    margin: 0 -15px 12px;
  }
  .main-slider .owl-carousel .owl-buttons .owl-prev,
  .main-slider .owl-carousel .owl-buttons .owl-next {
    width: auto !important;
    height: auto !important;
    display: flex !important;
    padding: 4px !important;
  }
  .main-slider .owl-carousel .owl-buttons div i {
    font-size: 32px !important;
    line-height: 1 !important;
  }
  .main-slider .owl-carousel .owl-buttons .owl-prev {
    left: 6px;
  }
  .main-slider .owl-carousel .owl-buttons .owl-next {
    right: 6px;
  }
  .main-slider .owl-controls .owl-pagination {
    bottom: 16px;
  }
  .main-slider .owl-controls .owl-page span {
    width: 10px !important;
    height: 10px !important;
  }
  .cc-find-school-cta {
    padding: 36px 16px;
  }
  .cc-find-school-cta h2 {
    font-size: 28px !important;
  }
  .cc-cta-subtitle {
    font-size: 16px;
  }
}

/* ============================================================
   PHASE 5 ADDITIONS — Account, Info, Contact, Cart Polish
   ============================================================ */

.cc-page-shell {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  box-shadow: var(--cc-shadow);
  padding: 28px;
  margin-bottom: 26px;
}

.cc-page-header {
  margin-bottom: 24px;
}

.cc-page-header .page-title {
  margin: 0 0 8px;
}

.cc-page-lead {
  margin: 0;
  color: #6b7280;
  font-size: 15px;
}

.cc-link-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cc-link-list li {
  border-top: 1px solid #eef2f7;
}

.cc-link-list li:first-child {
  border-top: 0;
}

.cc-link-list a {
  display: block;
  padding: 10px 0;
  font-weight: 600;
}

/* Account */
.cc-account-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.cc-account-card {
  background: #f8fafc;
  border: 1px solid #e7edf5;
  border-radius: var(--cc-radius-sm);
  padding: 18px;
}

.cc-account-card h2 {
  margin: 0 0 10px;
  font-size: 18px;
}

.cc-account-card-full {
  grid-column: span 2;
}

/* Login */
.cc-login-grid .cc-auth-card {
  border: 1px solid #e7edf5;
  border-radius: var(--cc-radius-sm);
  box-shadow: none;
  margin-bottom: 0;
  min-height: 300px;
}

.cc-login-grid .cc-auth-card h2 {
  margin-top: 0;
  margin-bottom: 10px;
}

.cc-auth-form .btn-primary {
  margin-top: 8px;
}

.cc-forgot-link {
  display: inline-block;
  margin-top: 6px;
  font-size: 13px;
}

/* Contact */
.cc-contact-section {
  margin-bottom: 24px;
}

.cc-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 18px;
}

.cc-contact-section h2 {
  margin: 0 0 14px;
  font-size: 22px;
}

.cc-contact-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 16px;
}

.cc-contact-card {
  background: #f8fafc;
  border: 1px solid #e7edf5;
  border-radius: var(--cc-radius-sm);
  padding: 18px;
}

.cc-contact-item {
  border-top: 1px solid #e9edf3;
  padding-top: 12px;
  margin-top: 12px;
}

.cc-contact-item:first-of-type {
  border-top: 0;
  margin-top: 0;
  padding-top: 0;
}

.cc-contact-item h3 {
  font-size: 16px;
  margin: 0 0 6px;
}

.cc-contact-item p,
.cc-contact-item address {
  margin: 0;
  line-height: 1.6;
}

.cc-contact-image {
  margin-bottom: 14px;
}

.cc-contact-image .img-thumbnail {
  border-radius: var(--cc-radius-sm);
  border-color: #d9e3ef;
  width: 100%;
}

.cc-contact-form {
  background: #f8fafc;
  border: 1px solid #e7edf5;
  border-radius: var(--cc-radius-sm);
  padding: 16px 16px 10px;
  margin-top: 14px;
}

.cc-contact-form legend {
  border-bottom: 0;
  margin-bottom: 10px;
  font-size: 20px;
  font-family: 'Nunito', sans-serif;
  color: var(--cc-heading);
}

.cc-contact-form-card {
  display: flex;
  flex-direction: column;
}

.cc-contact-form-card .cc-page-lead {
  margin-bottom: 2px;
}

.cc-contact-primary {
  height: 100%;
}

.cc-contact-item-map a {
  font-weight: 700;
}

.cc-contact-section .panel {
  border-color: #dce7f2;
  box-shadow: none;
}

.cc-contact-section .panel-heading {
  background: #f8fafc;
}

/* Information / size guide shell */
.cc-information-body {
  font-size: 15px;
  line-height: 1.75;
}

.cc-information-shell .cc-information-body,
.cc-information-shell .cc-information-body * {
  font-family: 'Raleway', sans-serif !important;
  color: #334155 !important;
}

.cc-information-shell .cc-information-body p,
.cc-information-shell .cc-information-body li,
.cc-information-shell .cc-information-body td,
.cc-information-shell .cc-information-body th {
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.cc-information-shell .cc-information-body p {
  margin: 0 0 14px !important;
}

.cc-information-shell .cc-information-body ul,
.cc-information-shell .cc-information-body ol {
  margin: 0 0 16px 20px !important;
  padding: 0 !important;
}

.cc-information-shell .cc-information-body li {
  margin: 0 0 8px !important;
}

.cc-information-shell .cc-information-body b,
.cc-information-shell .cc-information-body strong {
  font-family: 'Nunito', sans-serif !important;
  color: #0f172a !important;
}

.cc-information-shell .cc-information-body h1,
.cc-information-shell .cc-information-body h2,
.cc-information-shell .cc-information-body h3,
.cc-information-shell .cc-information-body h4 {
  font-family: 'Nunito', sans-serif !important;
  color: #0f172a !important;
  line-height: 1.35 !important;
}

.cc-information-body h2,
.cc-information-body h3,
.cc-information-body h4 {
  margin-top: 20px;
  margin-bottom: 10px;
}

.cc-information-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  display: block;
  overflow-x: auto;
}

.cc-information-body table td,
.cc-information-body table th {
  border: 1px solid #dde5ef;
  padding: 8px;
  min-width: 120px;
}

.cc-information-shell .cc-information-body a {
  color: var(--cc-blue) !important;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.cc-information-shell .cc-information-body a:hover {
  color: var(--cc-blue-dark) !important;
}

.cc-information-shell .cc-page-header {
  border-bottom: 1px solid #e2e8f0;
  padding-bottom: 14px;
  margin-bottom: 18px;
}

.cc-information-shell.cc-information-4 .cc-information-body p:first-child {
  font-family: 'Nunito', sans-serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
}

.cc-size-guide-intro {
  max-width: 780px;
  margin-bottom: 20px;
}

.cc-size-guide {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}

.cc-size-section {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbfe 100%);
  border: 1px solid #dbe7f2;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.cc-size-section h3 {
  margin: 0;
  padding: 16px 18px;
  background: #eff7fc;
  border-bottom: 1px solid #dbe7f2;
  font-size: 18px;
}

.cc-size-section table {
  width: 100%;
  margin: 0;
  border-collapse: collapse;
}

.cc-size-section thead th {
  background: #f8fafc;
  color: #526173;
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.cc-size-section tbody td,
.cc-size-section thead th {
  border: 0;
  border-bottom: 1px solid #e6eef6;
  padding: 10px 18px;
}

.cc-size-section tbody tr:last-child td {
  border-bottom: 0;
}

.cc-size-section tbody tr:hover td {
  background: #f2f8fc;
}

/* Sitemap */
.cc-sitemap-grid {
  margin-left: -8px;
  margin-right: -8px;
}

.cc-sitemap-card {
  padding-left: 8px;
  padding-right: 8px;
}

.cc-sitemap-card > ul {
  list-style: none;
  margin: 0;
  padding: 14px;
  background: #f8fafc;
  border: 1px solid #e7edf5;
  border-radius: var(--cc-radius-sm);
}

.cc-sitemap-card ul ul {
  margin-top: 6px;
}

/* Cart */
.cc-cart-weight {
  font-size: 18px;
  color: #6b7280;
  font-weight: 600;
}

.cc-cart-shell .shopping-cart thead td {
  background: #f8fafc;
  font-family: 'Nunito', sans-serif;
  color: var(--cc-heading);
}

.cc-cart-shell .shopping-cart td {
  vertical-align: middle;
}

.cc-cart-totals td {
  background: #f8fafc;
}

.cc-btn-secondary {
  border-color: var(--cc-border);
  color: var(--cc-heading);
  font-weight: 700;
}

.cc-btn-secondary:hover,
.cc-btn-secondary:focus {
  background: var(--cc-blue);
  border-color: var(--cc-blue);
  color: #fff;
}

@media (max-width: 991px) {
  .cc-account-grid {
    grid-template-columns: 1fr;
  }

  .cc-account-card-full {
    grid-column: span 1;
  }

  .cc-contact-grid {
    grid-template-columns: 1fr;
  }

  .cc-contact-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .cc-page-shell {
    padding: 18px;
  }

  .cc-contact-form {
    padding: 14px 10px 8px;
  }

  .cc-contact-form .control-label {
    text-align: left;
    margin-bottom: 6px;
  }
}

/* ============================================================
   PHASE 6 ADDITIONS — Sidebar Modules + Homepage Coherence
   ============================================================ */

.cc-side-card {
  border: 1px solid #dbe7f2;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
  background: #fff;
}

.cc-side-card .box-heading {
  background: #f4f9fd;
  border-bottom: 1px solid #dbe7f2;
  padding: 12px 14px;
  margin: 0;
}

.cc-side-card .box-heading h3 {
  margin: 0;
  font-size: 16px;
  font-family: 'Nunito', sans-serif;
  color: var(--cc-heading);
}

.cc-side-links {
  padding: 8px 12px;
}

.cc-side-links .list-group-item,
.cc-category-links li > a {
  border: 0;
  border-bottom: 1px solid #eaf0f7;
  border-radius: 0;
  padding: 10px 4px;
  font-weight: 600;
  color: #415164;
  background: transparent;
}

.cc-side-links .list-group-item:last-child,
.cc-category-links li:last-child > a {
  border-bottom: 0;
}

.cc-side-links .list-group-item:hover,
.cc-category-links li > a:hover,
.cc-category-links li > a.active {
  color: var(--cc-blue);
  background: transparent;
}

.cc-category-links {
  margin: 0;
  padding: 0;
  list-style: none;
}

.cc-category-links ul {
  margin: 0 0 0 12px;
  padding: 0;
}

.cc-home-slideshow .owl-controls .owl-pagination .owl-page span {
  text-indent: -9999px;
}

/* Reduce large legacy gap before homepage product tabs */
.common-home .hometab {
  padding-top: 20px !important;
}

.cc-contact-shell .panel-group {
  margin-bottom: 0;
}

.cc-contact-shell .panel-title a {
  display: block;
  font-weight: 700;
  color: var(--cc-heading);
}

.cc-contact-shell .panel-title a:hover,
.cc-contact-shell .panel-title a:focus {
  color: var(--cc-blue);
}
