/* Generic 
-------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Roboto+Slab:wght@300;400;500&display=block');
body {
    font-family: "Work Sans", Helvetica, Arial, sans-serif;
    color: rgba(41, 41, 41, 1) /*{Body | Text colour}*/;
    font-weight: 300;
    font-size: 16px /*{Body | Body font size}*/;
    line-height: 1.6;
}
a, a:hover, a:active, .btn-link, .btn-link:hover {
	color: rgba(237, 28, 36, 1) /*{Body | Link colour}*/;
}
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6, .btn {
	font-family: "Work Sans", Helvetica, Arial, sans-serif;
}
h1,
.h1 {
	font-size: 34px /*{Headings|header-1-font-size}*/;
	font-weight: 700;
}
h2,
.h2 {
	font-size: 25px /*{Headings|header-2-font-size}*/;
}
h3,
.h3 {
	font-size: 18px /*{Headings|header-3-font-size}*/;
}
h4,
.h4 {
	font-size: 18px /*{Headings|header-4-font-size}*/;
}
h5,
.h5 {
	font-size: 14px /*{Headings|header-5-font-size}*/;
}
/* Header 
-------------------------------*/
header {
	background-color: rgba(255, 255, 255, 1) /*{Header | Background colour}*/;
}
header .header-topbar {
	border-color: rgba(13, 13, 13, 1) /*{Header | Topbar border colour}*/;
}
header .header-topbar .navbar-nav > li > a,
header .header-topbar .header-phone {
	color: rgba(51, 51, 51, 1) /*{Header | Topbar link colour}*/;
	font-weight: 300;
}
header .btn-header,
header .btn-header:hover {
    color: rgba(61, 61, 61, 1) /*{Header | Account & cart link colour}*/;
}
header .cart-count {
    background-color: rgba(0, 0, 0, 1) /*{buttons | primary-btn-background-colour}*/;
    color: #ffffff /*{buttons | primary-btn-text-colour}*/;
}
.header-menu {
	background-color: rgba(0, 0, 0, 1) /*{Header | Menu background colour}*/;
}
.header-menu .navbar-nav > li > a,
.navbar-mobile a.nav-link {
	color: #ffffff /*{Header | Menu colour}*/;
}
/* Footer 
-------------------------------*/
.wrapper-footer {
	background-color: rgba(43, 43, 43, 1) /*{Footer | Background color}*/;
}
.wrapper-footer h4 {
	color: rgba(255, 255, 255, 1) /*{Footer | Heading colour}*/;
}
.wrapper-footer a, 
.wrapper-footer a:hover, 
.wrapper-footer a:active,
.wrapper-footer * {
	color: rgba(255, 255, 255, 1) /*{Footer | Text colour}*/;
}
footer .nav.list-social i {
    background-color: rgba(43, 43, 43, 1) /*{Footer | Social icon background colour}*/;
    color: rgba(255, 255, 255, 1) /*{Footer | Social icon colour}*/;
}
/* Buttons 
-------------------------------*/
/* Secondary button */
.btn-outline-secondary, .btn-default {
	color: rgba(26, 26, 26, 1) /*{buttons | default-btn-text-colour}*/;
	background-color: rgba(255, 255, 255, 1) /*{buttons | default-btn-background-colour}*/;
	border-color: rgba(255, 255, 255, 1) /*{buttons | default-btn-border-colour}*/;
}
.btn-outline-secondary:hover, .btn-default:hover,
.btn-outline-secondary.disabled, .btn-default:disabled,
.btn-outline-secondary:not(:disabled):not(.disabled):active, .btn-outline-secondary:not(:disabled):not(.disabled).active, .show > .btn-outline-secondary.dropdown-toggle, .btn-default:not(:disabled):not(.disabled):active, .btn-default:not(:disabled):not(.disabled).active, .show > .btn-default.dropdown-toggle {
	color: rgba(0, 0, 0, 1) /*{buttons | default-btn-text-colour-hover}*/;
	background-color: rgba(255, 255, 255, 1) /*{buttons | default-btn-background-colour-hover}*/;
	border-color: rgba(99, 99, 99, 0.45) /*{buttons | default-btn-border-colour-hover}*/;
}
/* Primary button */
.btn-primary {
	color: #ffffff /*{buttons | primary-btn-text-colour}*/; 
	background-color: rgba(0, 0, 0, 1) /*{buttons | primary-btn-background-colour}*/;
	border-color: rgba(0, 0, 0, 1) /*{buttons | primary-btn-border-colour}*/;
}
.btn-primary:hover,
.btn-primary.disabled, .btn-primary:disabled,
.btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active, .show > .btn-primary.dropdown-toggle {
	color: #ffffff /*{buttons | primary-btn-text-colour-hover}*/;
	background-color: rgba(0, 0, 0, 1) /*{buttons | primary-btn-background-colour-hover}*/;
	border-color: rgba(0, 0, 0, 1) /*{buttons | primary-btn-border-colour-hover}*/;
}
/* Success button */
.btn-success {
	color: #ffffff /*{buttons | success-btn-text-colour}*/;
	background-color: rgba(237, 28, 36, 1) /*{buttons | success-btn-background-colour}*/;
	border-color: rgba(237, 28, 36, 1) /*{buttons | success-btn-border-colour}*/;
}
.btn-success:hover,
.btn-success.disabled, .btn-success:disabled,
.btn-success:not(:disabled):not(.disabled):active, .btn-success:not(:disabled):not(.disabled).active, .show > .btn-success.dropdown-toggle {
	color: #ffffff /*{buttons | success-btn-text-colour-hover}*/;
	background-color: rgba(237, 28, 36, 1) /*{buttons | success-btn-background-colour-hover}*/;
	border-color: rgba(237, 28, 36, 1) /*{buttons | success-btn-border-colour-hover}*/;
}
/* Homepage 
-------------------------------*/
#homepage-content {
    background-color: #f8f8f8 /*{Homepage | Content background colour}*/;
}
.container-3 {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 20px; /* desktop gap between columns */
    margin: 0;
    padding: 0;
}
.column {
    flex: 1 1 calc(50% - 20px); /* two columns on desktop */
    padding: 10px;
    box-sizing: border-box;
}
/* Mobile: stack into single column */
@media (max-width: 767px) {
    .container-3 {
        gap: 15px; /* smaller gap for mobile */
    }
    .column {
        flex: 1 1 100%;
        margin-bottom: 0; /* prevent double spacing */
    }
}
/* Remove the padding that creates the big blank space before content */
.tabbable .tab-pane .card-body { padding-top: 0; }
/* Bring the tab bar a bit closer to the content */
.tabbable .nav.nav-tabs { margin-bottom: 10px; }
.clean-list {
  list-style: none;       /* remove default bullets */
  margin: 0;
  padding: 0;
}
.section-title-3 {
  display: inline-block;       /* keeps line same width as text */
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 20px;         /* space below line */
}
.section-title-3::after {
  content: "";
  display: block;              /* sits under the text */
  height: 1px;                 /* line thickness */
  width: 25%;                 /* match title width */
  background-color: #e54b43;   /* brand color */
  margin-top: 10px;            /* space between text and line */
  opacity: 0.7;                /* lighter look */
}
h2.section-title-3,
h3.section-title-3 {
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 20px;
}
.list-clean {
    list-style-position: outside;
    padding-left: 1.2em;
    margin-left: 0;
}
/* List item articles — clean card style */
article.border-bottom {
  border-bottom: none !important;
  background: #fff;
  border: 1px solid #e8e8e8 !important;
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 8px !important;
  display: flex;
  align-items: center;
  gap: 12px;
}

article.border-bottom h4 {
  margin: 0;
  flex: 1;
  font-size: 15px;
}

article.border-bottom h4 a {
  color: #222;
  text-decoration: none;
}

article.border-bottom h4 a:hover {
  color: #555;
}

/* Hide the empty paragraphs Maropost outputs */
article.border-bottom p.text-muted,
article.border-bottom p.clearfix,
article.border-bottom p:empty {
  display: none;
}

/* Share button — restyle as subtle pill */
article.border-bottom .dropdown {
  flex-shrink: 0;
  margin: 0;
}

article.border-bottom .btn.dropdown-toggle {
  background: none;
  border: 1px solid #e0e0e0;
  border-radius: 20px;
  font-size: 11px;
  color: #999;
  padding: 4px 12px;
  box-shadow: none;
  white-space: nowrap;
}

article.border-bottom .btn.dropdown-toggle:hover {
  background: #f5f5f5;
  border-color: #bbb;
  color: #666;
}
article.border-bottom h4 a::after {
  content: " →";
  font-size: 12px;
  color: #aaa;
}
/* Pagination colours */
.page-link {
  color: #000;
  border-color: #c0392b;
}

.page-link:hover {
  color: #922b21;
  background-color: #f5f5f5;
  border-color: #ccc;
}

.page-item.active .page-link {
  background-color: #c0392b;
  border-color: #c0392b;
  color: #fff;
}
.cols-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  align-items: stretch;
}

@media (max-width: 600px) {
  .cols-2 { grid-template-columns: 1fr; }
}
.cols-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 equal-width columns */
  gap: 20px;                             /* space between columns */
  padding: 20px;                         /* padding around the container */
}

.cols-3 .col {
  background: #fff;        /* optional, for testing */
  border: 1px solid #ddd;  /* optional, for testing */
  padding: 15px;           /* inner padding for each column */
  text-align: center;      /* optional */
}
.cols-4 {
  --gap: 16px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
  align-items: stretch;
}

@media (max-width: 992px) {
  .cols-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .cols-4 {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}
.cols-5 {
  --gap: 16px;                         /* default gap for desktop */
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--gap);
   align-items: stretch;
}
}
/* Responsive breakpoints */
@media (max-width: 992px) {
  .cols-5 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .cols-5 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .cols-5 {
    grid-template-columns: 1fr;   /* single column */
    gap: 8px;                     /* reduce gap so it looks like normal spacing */
  }
}
.feat-card {
  background: #fff;
  border: 1px solid #e0e0e0;
  border-top: 3px solid #ed1c24;
  border-radius: 6px;
  padding: 20px;
  text-align: left;
}
 
.feat-card .feat-icon {
  font-size: 28px;
  line-height: 1;
  margin-bottom: 12px;
  display: block;
}
 
.feat-card h3 {
  font-size: 16px;
  font-weight: 700;
  color: #000;
  margin: 0 0 10px;
  line-height: 1.3;
}
 
.feat-card p {
  font-size: 14px;
  color: #444;
  line-height: 1.6;
  margin: 0;
  font-weight: 300;
}
.sg-table-wrap { overflow-x: auto; margin-top: 16px; }

.sg-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.sg-table th {
  text-align: left;
  background: #111;
  color: #fff;
  padding: 10px 14px;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .04em;
}

.sg-table td {
  padding: 9px 14px;
  border-bottom: 1px solid #e8e8e8;
  color: #333;
  vertical-align: top;
}

.sg-table tr:last-child td { border-bottom: none; }

.sg-table tr:nth-child(even) td { background: #f9f9f9; }

.sg-code {
  font-family: monospace;
  font-size: 12px;
  color: #ed1c24;
  font-weight: 700;
}
.sg-divider {
  border: none;
  border-top: 1px solid #e8e8e8;
  margin: 32px 0;
}
.sg-dark {
  background: #111;
  border-radius: 8px;
  padding: 24px;
  margin-top: 16px;
}

.sg-dark h3 {
  color: #fff;
  margin: 0 0 10px;
}

.sg-dark p {
  color: #bbb;
  font-size: 14px;
  margin: 0 0 14px;
  line-height: 1.6;
}

.sg-dark a {
  color: #ed1c24;
  font-weight: 600;
}

.sg-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sg-tag {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  font-size: 13px;
  padding: 6px 14px;
  border-radius: 20px;
}
.sg-box {
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  overflow: hidden;
}

.sg-box-head {
  background: #111;
  color: #fff;
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 700;
}

.sg-box ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sg-box li {
  padding: 8px 14px;
  font-size: 13px;
  color: #333;
  border-bottom: 1px solid #f0f0f0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.sg-box li:last-child {
  border-bottom: none;
}

.sg-box li::before {
  content: "→";
  color: #ed1c24;
  font-weight: 700;
  font-size: 12px;
  flex-shrink: 0;
}
.sg-check-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 16px;
}

.sg-check-item {
  background: #f4f4f4;
  border-radius: 6px;
  padding: 14px 16px;
  font-size: 14px;
  color: #333;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  line-height: 1.5;
}

.sg-check-item::before {
  content: "✓";
  color: #4caf50;
  font-weight: 700;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

@media (max-width: 600px) {
  .sg-check-grid { grid-template-columns: 1fr; }
}
.sg-alert {
  border-left: 4px solid #ed1c24;
  background: #fff8f8;
  border-radius: 0 6px 6px 0;
  padding: 16px 20px;
  margin: 16px 0;
  font-size: 14px;
  line-height: 1.7;
  color: #333;
}

.sg-alert strong {
  color: #ed1c24;
}
.plain-card {
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 20px;
}

.plain-card h3 {
  margin: 0 0 12px;
  font-weight: 700;
  color: #000;
}

.plain-card p {
  font-size: 14px;
  color: #333;
  line-height: 1.6;
  margin: 0;
}
.sg-info-box {
  background: #f4f4f4;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 16px 20px;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-top: 16px;
  font-size: 14px;
  color: #333;
  line-height: 1.6;
}

.sg-info-box .sg-info-icon {
  font-size: 28px;
  flex-shrink: 0;
  margin-top: 2px;
}