@font-face {
font-family: Montserrat;
font-weight: 500;
font-style: normal;
font-display: swap;
src: url(//snusvikings.co.uk/cdn/fonts/montserrat/montserrat_n5.07ef3781d9c78c8b93c98419da7ad4fbeebb6635.woff2) format("woff2"),
url(//snusvikings.co.uk/cdn/fonts/montserrat/montserrat_n5.adf9b4bd8b0e4f55a0b203cdd84512667e0d5e4d.woff) format("woff");
}
@font-face {
font-family: Montserrat;
font-weight: 700;
font-style: normal;
font-display: swap;
src: url(//snusvikings.co.uk/cdn/fonts/montserrat/montserrat_n7.3c434e22befd5c18a6b4afadb1e3d77c128c7939.woff2) format("woff2"),
url(//snusvikings.co.uk/cdn/fonts/montserrat/montserrat_n7.5d9fa6e2cae713c8fb539a9876489d86207fe957.woff) format("woff");
}
:root {
--sv-teal: #0d6884;
--sv-teal-dark: #0b5e77;
--sv-text: #222;
--sv-muted: #747474;
--sv-line: #e1e1e1;
--sv-panel: #f4f4f4;
--sv-page: 1200px;
--sv-reading: 820px;
--sv-radius: 8px;
--sv-shadow: 0 2px 10px rgb(0 0 0 / 0.07);
}
*,
*::before,
*::after {
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
margin: 0;
background: #fff;
color: var(--sv-text);
font-family: Montserrat, Arial, sans-serif;
font-size: 15px;
font-weight: 500;
line-height: 1.45;
}
.site-header {
position: sticky;
top: 0;
z-index: 60;
}
a {
color: inherit;
text-decoration-thickness: 1px;
text-underline-offset: 2px;
}
img,
iframe {
display: block;
max-width: 100%;
}
h1,
h2,
h3,
h4 {
margin: 0 0 14px;
font-weight: 700;
line-height: 1.17;
letter-spacing: 0;
}
h1 {
font-size: clamp(30px, 3vw, 44px);
}
h2 {
font-size: 23px;
}
h3 {
font-size: 17px;
}
p {
margin: 0 0 16px;
}
.screen-reader-text,
.skip-link {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
}
.skip-link:focus {
z-index: 50;
width: auto;
height: auto;
padding: 10px 14px;
clip: auto;
background: #fff;
}
.visually-hidden {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
}
.announcement {
--announcement-text-color: 255 255 255;
--announcement-marquee-duration: 28s;
display: block;
background: #171717;
color: rgb(var(--announcement-text-color));
font-family: "Courier New", ui-monospace, SFMono-Regular, Menlo, Monaco, monospace;
font-size: 15px;
font-weight: 700;
}
.announcement .container {
max-width: var(--sv-page);
margin: 0 auto;
}
.announcement a {
color: inherit;
}
.announcement__row {
display: flex;
align-items: center;
min-height: 24px;
padding: 0 20px;
}
.announcement__col--left {
flex: 1 1 auto;
min-width: 0;
overflow: hidden;
}
.announcement__marquee {
display: flex;
width: 100%;
overflow: hidden;
}
.announcement__col--left .announcement__marquee {
-webkit-mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
}
.announcement__track {
display: flex;
flex-shrink: 0;
align-items: center;
gap: clamp(38px, 6vw, 72px);
min-width: max-content;
padding-inline-end: clamp(38px, 6vw, 72px);
animation: announcement-marquee var(--announcement-marquee-duration) linear infinite;
will-change: transform;
}
.announcement__item {
display: inline-flex;
flex: 0 0 auto;
align-items: center;
gap: 7px;
white-space: nowrap;
}
.announcement__item p {
display: inline;
margin: 0;
}
.announcement__icon {
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
height: var(--announcement-icon-size, 20px);
line-height: 0;
}
.announcement__icon img,
.announcement__icon svg {
display: block;
width: auto;
height: var(--announcement-icon-size, 20px);
max-width: calc(var(--announcement-icon-size, 20px) * 2);
}
.announcement__text {
display: inline;
}
@media (hover: hover) {
.announcement__marquee:hover .announcement__track {
animation-play-state: paused;
}
}
@keyframes announcement-marquee {
from { transform: translateX(0); }
to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
.announcement__track {
flex-wrap: wrap;
justify-content: center;
gap: 16px;
padding-inline-end: 0;
animation: none;
transform: none;
}
}
.header-main {
background: var(--sv-teal);
color: #fff;
}
.header-main__inner {
display: grid;
grid-template-columns: 210px minmax(280px, 1fr) 140px;
gap: 36px;
align-items: center;
max-width: var(--sv-page);
min-height: 74px;
margin: 0 auto;
padding: 0 20px;
}
.brand {
display: inline-flex;
width: max-content;
max-width: 210px;
text-decoration: none;
}
.brand img {
width: 170px;
height: auto;
}
.site-search {
position: relative;
display: flex;
align-items: center;
gap: 10px;
height: 44px;
border-radius: 8px;
background: rgb(255 255 255 / 0.12);
color: rgb(255 255 255 / 0.88);
padding: 0 18px;
}
.site-search__icon {
display: inline-flex;
color: rgb(255 255 255 / 0.88);
line-height: 0;
}
.site-search input[type="search"] {
width: 100%;
border: 0;
outline: 0;
background: transparent;
color: #fff;
font: inherit;
font-size: 16px;
}
.site-search input[type="search"]::placeholder {
color: rgb(255 255 255 / 0.65);
}
.site-search__clear {
display: inline-grid;
place-items: center;
width: 28px;
height: 28px;
border: 0;
background: transparent;
color: #fff;
cursor: pointer;
font-size: 28px;
line-height: 1;
}
.product-predictive-search {
position: absolute;
top: calc(100% + 14px);
left: 0;
z-index: 60;
display: grid;
grid-template-columns: minmax(0, 1.5fr) minmax(220px, 0.75fr);
width: min(760px, calc(100vw - 32px));
min-height: 320px;
overflow: hidden;
border: 1px solid rgb(255 255 255 / 0.16);
border-radius: 0 0 8px 8px;
background: var(--sv-teal);
color: #fff;
box-shadow: 0 22px 44px rgb(0 0 0 / 0.22);
}
.product-predictive-search[hidden] {
display: none;
}
.predictive-search__main,
.predictive-search__suggestions {
min-width: 0;
padding: 28px 30px;
}
.predictive-search__suggestions {
background: rgb(255 255 255 / 0.05);
}
.predictive-search__tabs {
display: flex;
gap: 28px;
margin-bottom: 28px;
}
.predictive-search__tabs button {
border: 0;
border-bottom: 2px solid transparent;
background: transparent;
color: rgb(255 255 255 / 0.72);
cursor: pointer;
font: inherit;
font-weight: 800;
padding: 0 0 8px;
}
.predictive-search__tabs button.is-active {
border-color: #fff;
color: #fff;
}
.predictive-search__panel {
display: none;
}
.predictive-search__panel.is-active {
display: block;
}
.predictive-search__panel ul,
.predictive-search__suggestions ul {
display: grid;
gap: 24px;
margin: 0;
padding: 0;
list-style: none;
}
.predictive-result {
display: grid;
grid-template-columns: 64px minmax(0, 1fr);
gap: 18px;
align-items: center;
color: #fff;
text-decoration: none;
}
.predictive-result__media {
width: 64px;
height: 64px;
border-radius: 50%;
object-fit: cover;
}
.predictive-result__info {
display: grid;
gap: 6px;
min-width: 0;
}
.predictive-result__title {
font-size: 18px;
line-height: 1.25;
}
.predictive-result__price,
.predictive-result__vendor {
color: #fff;
font-size: 15px;
}
.predictive-result__vendor {
text-transform: uppercase;
}
.predictive-search__suggestions h3 {
margin: 0 0 28px;
color: #fff;
font-size: 18px;
}
.predictive-search__item--suggestion a,
.predictive-search__item--view-all button {
border: 0;
background: transparent;
color: #fff;
cursor: pointer;
font: inherit;
font-weight: 400;
text-align: left;
text-decoration: none;
}
.predictive-search__item--suggestion a {
font-weight: 400;
}
.predictive-search__item--suggestion mark {
background: transparent;
color: inherit;
font-weight: 800;
}
.predictive-search__item--view-all button {
padding: 0;
font-weight: 400;
text-decoration: underline;
text-underline-offset: 4px;
}
.predictive-search__empty {
color: rgb(255 255 255 / 0.78);
font-size: 15px;
font-weight: 400;
line-height: 1.4;
padding: 8px 0;
}
.predictive-search__empty--full {
grid-column: 1 / -1;
padding: 32px 38px;
color: #fff;
font-size: clamp(14px, 1.4vw, 15px);
font-weight: 400;
}
.header__icons {
display: flex;
justify-content: center;
align-items: center;
gap: 27px;
}
.header__icon {
position: relative;
display: inline-flex;
align-items: center;
justify-content: center;
width: 32px;
height: 32px;
color: #fff;
text-decoration: none;
}
.header__icon .icon {
width: 30px;
height: 30px;
}
.header__cart-count {
position: absolute;
top: -6px;
right: -11px;
display: grid;
place-items: center;
min-width: 22px;
height: 22px;
padding: 0 5px;
border-radius: 50%;
background: #fff;
color: var(--sv-teal);
font-size: 12px;
font-weight: 700;
line-height: 1;
}
.primary-nav {
position: relative;
max-width: var(--sv-page);
min-height: 40px;
margin: 0 auto;
padding: 0 20px;
}
.primary-menu {
display: flex;
align-items: center;
gap: 28px;
min-height: 40px;
margin: 0;
padding: 0;
list-style: none;
}
.mobile-menu-link {
display: none;
}
.primary-menu a {
display: block;
color: #fff;
font-size: 15px;
font-weight: 700;
text-decoration: none;
}
.primary-menu > li > a {
position: relative;
padding: 11px 0 10px;
}
.primary-menu > li > a.is-active::after,
.primary-menu > li:hover > a::after {
content: "";
position: absolute;
right: 0;
bottom: 0;
left: 0;
height: 2px;
background: #fff;
}
.chev {
display: inline-flex;
vertical-align: middle;
margin-left: 5px;
}
.chev svg {
width: 20px;
height: 20px;
}
.diamond {
font-size: 14px;
}
.primary-menu .nav-contact {
margin-left: auto;
}
.nav-contact a {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
min-width: 112px;
border-radius: 8px;
background: rgb(255 255 255 / 0.02);
}
.nav-contact svg {
flex: 0 0 17px;
}
.nav-toggle {
display: none;
}
.nav-toggle span[aria-hidden="true"] {
display: block;
width: 23px;
height: 2px;
background: currentColor;
transition: transform 180ms ease, opacity 180ms ease;
}
.nav-toggle span[aria-hidden="true"] + span[aria-hidden="true"] {
margin-top: 5px;
}
.nav-toggle.is-open span[aria-hidden="true"]:nth-of-type(1) {
transform: translateY(7px) rotate(45deg);
}
.nav-toggle.is-open span[aria-hidden="true"]:nth-of-type(2) {
opacity: 0;
}
.nav-toggle.is-open span[aria-hidden="true"]:nth-of-type(3) {
transform: translateY(-7px) rotate(-45deg);
}
.mobile-submenu-back,
.mobile-submenu-title {
display: none;
}
.mega-panel,
.category-menu {
position: absolute;
top: 100%;
z-index: 40;
visibility: hidden;
opacity: 0;
pointer-events: none;
transition: opacity 120ms ease;
}
.nav-item:hover .mega-panel,
.nav-item:focus-within .mega-panel,
.nav-item:hover .category-menu,
.nav-item:focus-within .category-menu {
visibility: visible;
opacity: 1;
pointer-events: auto;
}
.mega-panel {
left: 50%;
width: 100vw;
min-height: 344px;
transform: translateX(-50%);
border-top: 1px solid rgb(0 0 0 / 0.2);
background: #fff;
color: #111;
box-shadow: 0 8px 16px rgb(0 0 0 / 0.08);
}
.mega-inner {
display: grid;
grid-template-columns: 300px minmax(0, 1fr);
gap: 36px;
max-width: var(--sv-page);
margin: 0 auto;
padding: 36px 20px;
}
.mega-sidebar {
display: flex;
flex-direction: column;
}
.mega-all {
display: flex;
align-items: center;
justify-content: center;
height: 42px;
margin-bottom: 20px;
border: 0;
border-radius: 6px;
background: var(--sv-teal);
color: #fff;
cursor: pointer;
font: inherit;
font-weight: 700;
text-decoration: none;
white-space: nowrap;
}
.mega-all:hover,
.mega-tab.mega-all:hover {
background: #3589a2;
}
.mega-tab {
display: flex;
align-items: center;
justify-content: space-between;
height: 64px;
border: 0;
border-top: 1px solid #111;
background: transparent;
color: #111;
cursor: pointer;
font: inherit;
font-size: 16px;
text-align: left;
}
.mega-tab.mega-all {
justify-content: center;
height: 42px;
margin-bottom: 20px;
border: 0;
border-radius: 6px;
background: var(--sv-teal);
color: #fff;
font-weight: 700;
text-align: center;
}
.mega-tab:last-child {
border-bottom: 1px solid #111;
}
.mega-tab.is-active {
color: var(--sv-teal);
}
.mega-all.is-active {
color: #fff;
}
.mega-tab span {
display: inline-flex;
}
.mega-tab svg {
width: 24px;
height: 24px;
}
.mega-pane {
display: none;
}
.mega-pane.is-active {
display: block;
}
.mega-promo-grid {
display: grid;
grid-template-columns: repeat(2, minmax(330px, 1fr));
gap: 10px;
align-items: stretch;
margin: 0;
padding: 0;
list-style: none;
}
.mega-product-card {
display: grid;
grid-template-columns: 76px minmax(0, 1fr);
align-items: center;
min-height: 92px;
height: 100%;
overflow: hidden;
border: 1px solid #dedede;
border-radius: 5px;
background: #fff;
color: #222;
}
.mega-product-card__media {
position: relative;
display: grid;
place-items: center;
padding: 10px 0 10px 12px;
color: #222;
text-decoration: none;
}
.mega-product-card__media img {
width: 58px;
height: 58px;
border-radius: 50%;
object-fit: contain;
box-shadow: 0 2px 8px rgb(0 0 0 / 0.15);
}
.card-badge,
.product-card-label {
position: absolute;
z-index: 2;
border-radius: 999px;
padding: 4px 8px;
font-size: 10px;
font-weight: 700;
line-height: 1;
text-transform: uppercase;
white-space: nowrap;
}
.card-badge {
background: #000;
color: #fff;
}
.card-badge--strength {
left: 12px;
bottom: 12px;
background: var(--sv-teal);
}
.card-badge--from {
top: 12px;
left: 12px;
}
.product-card-label {
top: 12px;
right: 12px;
}
.product-card-label--silver {
background: linear-gradient(90deg, rgb(160 165 172) 0%, rgb(225 230 238) 50%, rgb(180 185 192) 100%);
color: #0a0000;
}
.product-card-label--offer {
background: linear-gradient(90deg, #2b2b2b 0%, #d95f02 50%, #f77f00 100%);
color: #fff;
}
.mega-product-card .card-badge,
.mega-product-card .product-card-label {
display: none;
}
.mega-product-card__meta {
padding: 11px 18px 11px 14px;
}
.mega-product-card__meta a {
color: #222;
text-decoration: none;
}
.mega-product {
display: grid;
grid-template-columns: 76px minmax(0, 1fr);
gap: 16px;
align-items: center;
min-height: 92px;
padding: 14px 18px;
border: 1px solid #dedede;
border-radius: 5px;
color: #111;
text-decoration: none;
}
.mega-product img {
width: 58px;
height: 58px;
border-radius: 50%;
object-fit: contain;
box-shadow: 0 2px 8px rgb(0 0 0 / 0.15);
}
.mega-product__body,
.mega-product__vendor,
.mega-product__title,
.mega-product__price {
display: block;
}
.mega-product__vendor {
display: none;
}
.mega-product__rating {
display: block;
color: var(--sv-teal);
font-size: 20px;
line-height: 1;
}
.mega-product__title {
margin-top: 3px;
font-size: 15px;
line-height: 1.25;
}
.mega-product__price {
margin-top: 2px;
font-size: 15px;
}
.mega-browse {
float: left;
width: 96px;
margin: 0 10px 18px 0;
color: #111 !important;
font-size: 14px;
line-height: 1.4;
text-decoration: none;
}
.brand-grid {
display: grid;
grid-template-columns: repeat(8, minmax(74px, 1fr));
gap: 36px 22px;
}
.brand-dot,
.flavour-dot,
.strength-grid a {
color: #111;
text-align: center;
text-decoration: none;
}
.brand-dot__image {
display: grid;
place-items: center;
width: 78px;
height: 78px;
margin: 0 auto 12px;
border-radius: 50%;
}
.brand-dot__image img {
width: 78px;
height: 78px;
border-radius: 50%;
object-fit: contain;
}
.brand-dot__image.is-missing {
border: 1px solid #e5e5e5;
background: #f7f7f7;
}
.brand-dot__image.is-missing::before {
content: attr(data-label);
max-width: 62px;
color: var(--sv-teal);
font-size: 12px;
font-weight: 700;
line-height: 1.1;
}
.brand-dot span:last-child,
.flavour-dot span {
display: block;
color: #111;
font-size: 14px;
font-weight: 500;
line-height: 1.25;
}
.strength-grid {
display: flex;
gap: 34px;
padding-top: 36px;
}
.strength-grid a {
width: 94px;
}
.strength-grid img {
width: 88px;
height: 48px;
margin: 0 auto 18px;
object-fit: contain;
}
.strength-bars {
display: flex;
justify-content: center;
gap: 5px;
height: 40px;
margin-bottom: 20px;
}
.strength-bars i {
display: block;
width: 11px;
height: 22px;
border-radius: 3px;
background: #b9b9b9;
}
.strength-bars--light i:nth-child(-n+1),
.strength-bars--medium i:nth-child(-n+3),
.strength-bars--strong i:nth-child(-n+4) {
background: #000;
}
.strength-grid strong {
display: block;
font-size: 14px;
font-weight: 500;
line-height: 1.35;
}
.flavour-grid {
display: grid;
grid-template-columns: repeat(8, minmax(80px, 1fr));
gap: 38px 28px;
padding-top: 6px;
}
.flavour-dot img {
width: 78px;
height: 78px;
margin: 0 auto 12px;
object-fit: contain;
}
.category-menu {
left: 360px;
width: 310px;
padding: 20px 32px;
background: #fff;
box-shadow: 0 8px 16px rgb(0 0 0 / 0.12);
}
.category-menu a {
display: block;
padding: 12px 0;
color: #111;
font-size: 16px;
text-decoration: none;
}
.page-shell {
max-width: var(--sv-page);
margin: 0 auto;
padding: 24px 20px 74px;
}
.home-guides {
padding-top: 42px;
}
.breadcrumbs {
display: flex;
align-items: center;
gap: 9px;
margin-bottom: 58px;
color: #555;
font-size: 12px;
}
.breadcrumbs a {
text-decoration: none;
}
.archive-intro,
.guide-hero {
max-width: 1040px;
margin-bottom: 56px;
}
.archive-intro h1,
.guide-hero h1 {
margin-bottom: 16px;
}
.intro-copy {
max-width: 1080px;
font-size: 17px;
}
.share-row {
display: flex;
align-items: center;
gap: 18px;
margin-top: 24px;
font-size: 22px;
}
.share-row strong {
font-size: 15px;
}
.featured-wrap {
margin-bottom: 58px;
}
.guide-library-intro {
display: flex;
justify-content: space-between;
align-items: flex-start;
gap: 24px;
margin: 0 0 26px;
}
.guide-library-intro p {
max-width: 640px;
margin: 0;
color: #333;
font-size: 15px;
}
.guide-topic-chips {
display: flex;
flex-wrap: wrap;
justify-content: flex-end;
gap: 8px;
}
.guide-topic-chips a {
display: inline-flex;
min-height: 34px;
align-items: center;
border: 1px solid var(--sv-line);
border-radius: 999px;
background: #fff;
color: #222;
padding: 0 12px;
font-size: 13px;
text-decoration: none;
}
.guide-discovery {
position: relative;
}
.guide-home-hub {
margin-bottom: 64px;
}
.guide-home-hub .archive-intro {
margin-bottom: 28px;
}
.guide-home-hub .archive-intro h2 {
margin-bottom: 12px;
font-size: clamp(30px, 4vw, 48px);
}
.guide-discovery__intro {
max-width: 720px;
margin-bottom: 20px;
color: #222;
font-size: 16px;
}
.guide-finder {
display: grid;
grid-template-columns: minmax(260px, 1fr) auto;
gap: 14px;
align-items: center;
margin: 0 0 26px;
padding: 16px;
border: 1px solid var(--sv-line);
border-radius: var(--sv-radius);
background: #f8f8f8;
}
.guide-search {
display: flex;
align-items: center;
gap: 11px;
min-height: 48px;
border: 1px solid #d9d9d9;
border-radius: 7px;
background: #fff;
padding: 0 15px;
color: var(--sv-teal);
}
.guide-search input {
width: 100%;
border: 0;
outline: 0;
background: transparent;
color: #111;
font: inherit;
}
.guide-search input::placeholder {
color: #777;
}
.guide-filter-bar {
grid-column: 1 / -1;
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.guide-filter {
display: inline-flex;
align-items: center;
min-height: 36px;
border: 1px solid #d7d7d7;
border-radius: 999px;
background: #fff;
color: #222;
cursor: pointer;
padding: 0 14px;
font: inherit;
font-size: 13px;
font-weight: 700;
}
.guide-filter.is-active {
border-color: var(--sv-teal);
background: var(--sv-teal);
color: #fff;
}
.guide-topic-select {
display: flex;
align-items: center;
gap: 9px;
min-height: 48px;
color: #555;
font-size: 13px;
font-weight: 700;
}
.guide-topic-select select {
min-width: 170px;
height: 42px;
border: 1px solid #d9d9d9;
border-radius: 7px;
background: #fff;
color: #111;
padding: 0 10px;
font: inherit;
}
.guide-results {
min-height: 160px;
transition: opacity 160ms ease;
}
.guide-discovery.is-loading .guide-results {
opacity: 0.45;
}
.guide-results-status {
min-height: 20px;
margin: -12px 0 16px;
color: var(--sv-muted);
font-size: 13px;
}
.guide-empty-state {
padding: 34px;
border: 1px dashed #cfcfcf;
border-radius: var(--sv-radius);
background: #fff;
text-align: center;
}
.guide-empty-state h2 {
font-size: 22px;
}
.error-hero {
max-width: 760px;
margin: 26px auto 44px;
text-align: center;
}
.error-hero h1 {
font-size: clamp(36px, 6vw, 62px);
}
.error-hero p {
font-size: 17px;
}
.error-actions {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 12px;
margin-top: 24px;
}
.btn--teal {
background: var(--sv-teal);
color: #fff;
}
.btn--outline {
border: 1px solid #111;
background: #fff;
color: #111;
}
.guide-feature-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 30px 24px;
}
.guide-section-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 24px;
width: 100%;
}
.guide-section-card {
display: flex;
flex-direction: column;
border: 1px solid var(--sv-line);
border-radius: var(--sv-radius);
background: #fff;
padding: 18px 18px 24px;
box-shadow: var(--sv-shadow);
overflow: hidden;
}
.guide-section-card__image {
display: block;
width: 100%;
aspect-ratio: 1.86;
margin-bottom: 20px;
border-radius: calc(var(--sv-radius) - 2px);
background: var(--sv-panel);
object-fit: cover;
}
.guide-section-card h2 {
font-size: 24px;
}
.guide-section-card a {
display: inline-flex;
margin-top: 8px;
color: var(--sv-teal);
font-weight: 700;
text-decoration-thickness: 1px;
text-underline-offset: 4px;
}
.guide-card {
min-width: 0;
}
.guide-card__image {
display: block;
margin-bottom: 14px;
overflow: hidden;
text-decoration: none;
}
.guide-card__image img {
width: 100%;
aspect-ratio: 1.78;
object-fit: cover;
background: var(--sv-panel);
}
.guide-card__meta,
.guide-card__byline,
.guide-meta,
.eyebrow,
.caption {
color: var(--sv-muted);
font-size: 14px;
}
.guide-card__title {
margin-bottom: 10px;
font-size: 20px;
}
.guide-card__title a {
text-decoration: none;
}
.guide-card p {
font-size: 16px;
}
.guide-card--featured {
display: grid;
grid-template-columns: minmax(380px, 1.25fr) minmax(300px, 0.9fr);
gap: 34px;
align-items: center;
}
.guide-card--featured .guide-card__image {
margin: 0;
}
.guide-card--featured .guide-card__title {
font-size: 22px;
}
.round-arrow {
display: grid;
place-items: center;
width: 58px;
height: 58px;
margin-top: 28px;
border: 3px solid #252525;
border-radius: 50%;
font-size: 30px;
text-decoration: none;
}
.guide-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 38px 32px;
}
.guide-grid--scroll {
display: flex;
gap: 18px;
overflow-x: auto;
padding-bottom: 12px;
}
.guide-grid--scroll .guide-card {
flex: 0 0 245px;
}
.pagination,
.nav-links {
display: flex;
justify-content: center;
align-items: center;
gap: 18px;
margin-top: 58px;
padding-top: 28px;
border-top: 1px solid var(--sv-line);
}
.page-numbers {
text-decoration: none;
}
.page-numbers.current {
display: grid;
place-items: center;
width: 26px;
height: 26px;
border-radius: 4px;
background: var(--sv-teal);
color: #fff;
}
.guide-single {
max-width: 980px;
}
.guide-hero {
margin-bottom: 34px;
}
.guide-single .guide-hero {
max-width: var(--sv-reading);
margin-right: auto;
margin-left: auto;
text-align: center;
}
.eyebrow {
margin-bottom: 10px;
color: var(--sv-teal);
font-weight: 700;
text-transform: uppercase;
}
.answer-summary {
max-width: 860px;
margin: 22px auto;
padding: 18px 22px;
border-left: 5px solid var(--sv-teal);
background: #f7f7f7;
font-size: 17px;
}
.guide-featured-image {
max-width: var(--sv-reading);
margin: 0 auto 18px;
}
.guide-featured-image img {
width: 100%;
border-radius: var(--sv-radius);
}
.entry-content {
max-width: var(--sv-reading);
margin-right: auto;
margin-left: auto;
}
.article-byline {
max-width: var(--sv-reading);
margin: 0 auto 34px;
color: var(--sv-muted);
font-size: 14px;
text-align: center;
}
.entry-content > * + * {
margin-top: 16px;
}
.entry-content ul,
.entry-content ol {
margin: 16px 0;
padding-left: 22px;
}
.entry-content li {
margin: 5px 0;
padding-left: 2px;
}
.entry-content li::marker {
color: #111;
}
.entry-content a {
color: var(--sv-text);
font-weight: 700;
}
.entry-content h2 {
margin-top: 34px;
padding-top: 6px;
font-size: 24px;
}
.entry-content h3 {
margin-top: 26px;
font-size: 18px;
}
.entry-content figure {
margin: 28px 0;
}
.entry-content figcaption,
.wp-caption-text {
margin-top: 8px;
color: var(--sv-muted);
font-size: 13px;
text-align: center;
}
.entry-content blockquote {
margin: 24px 0;
padding: 18px 22px;
border-left: 5px solid var(--sv-teal);
background: #f7f7f7;
}
.entry-content table {
width: 100%;
border-collapse: collapse;
font-size: 14px;
}
.entry-content table th,
.entry-content table td {
padding: 13px 14px;
border: 1px solid var(--sv-line);
text-align: left;
vertical-align: top;
}
.entry-content table th {
background: #f7f7f7;
font-weight: 700;
}
.entry-content > table,
.entry-content .wp-block-table {
display: block;
overflow-x: auto;
}
.latest-guides {
max-width: 100%;
}
.section-heading {
display: flex;
justify-content: space-between;
align-items: end;
gap: 20px;
margin-bottom: 18px;
border-bottom: 2px solid #222;
}
.section-heading a {
align-self: flex-start;
margin-top: 4px;
padding-bottom: 4px;
font-size: 13px;
}
.section-intro {
max-width: 760px;
margin-bottom: 20px;
}
.btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 44px;
margin-top: 8px;
padding: 0 24px;
border-radius: 8px;
background: #fff;
color: #222;
font-weight: 700;
text-decoration: none;
}
.back-to-top {
border-top: 1px solid var(--sv-line);
text-align: center;
}
.back-to-top a {
display: inline-block;
padding: 28px 20px;
font-size: 13px;
font-weight: 700;
text-decoration: none;
}
.site-footer {
background: var(--sv-teal);
color: #fff;
}
.footer-inner {
display: grid;
grid-template-columns: 1.1fr 0.8fr 0.9fr 1.35fr;
gap: 66px;
max-width: var(--sv-page);
min-height: 640px;
margin: 0 auto;
padding: 70px 20px 44px;
}
.site-footer h2 {
margin-bottom: 18px;
font-size: 19px;
}
.footer-accordion__toggle {
width: 100%;
border: 0;
background: transparent;
color: inherit;
padding: 0;
font: inherit;
font-weight: 700;
text-align: left;
}
.site-footer h3 {
margin-top: 34px;
font-size: 14px;
}
.site-footer p,
.footer-menu a,
.legal-menu a {
color: #fff;
font-size: 15px;
text-decoration: none;
}
.footer-menu,
.legal-menu {
margin: 0;
padding: 0;
list-style: none;
}
.footer-menu li + li {
margin-top: 18px;
}
.newsletter-form {
display: grid;
grid-template-columns: 1fr 44px;
max-width: 285px;
margin-top: 22px;
border-radius: 6px;
overflow: hidden;
background: #fff;
}
.newsletter-form input,
.newsletter-form button {
height: 48px;
border: 0;
background: #fff;
font: inherit;
}
.newsletter-form input {
min-width: 0;
padding: 0 18px;
}
.newsletter-form button {
font-size: 26px;
cursor: pointer;
}
.age-warning {
display: flex;
align-items: center;
gap: 10px;
max-width: 340px;
margin-bottom: 28px;
font-size: 12px;
font-weight: 700;
line-height: 1;
}
.age-warning strong {
display: grid;
place-items: center;
flex: 0 0 42px;
height: 42px;
border: 3px solid #fff;
border-radius: 50%;
font-size: 24px;
}
.socials {
display: flex;
gap: 20px;
}
.socials a {
display: inline-flex;
color: #fff;
font-size: 28px;
text-decoration: none;
}
.socials svg {
width: 24px;
height: 24px;
}
.payments {
grid-column: 1 / 3;
align-self: end;
display: flex;
gap: 8px;
}
.payments img {
width: 38px;
height: 24px;
border-radius: 2px;
}
.footer-bottom {
grid-column: 1 / -1;
display: flex;
justify-content: space-between;
gap: 20px;
padding-top: 36px;
border-top: 1px solid rgb(255 255 255 / 0.24);
}
.footer-bottom p {
margin: 0;
font-size: 11px;
}
.legal-menu {
display: flex;
flex-wrap: wrap;
gap: 14px;
}
.legal-menu a {
font-size: 11px;
}
.fixed-rewards,
.sv-chat-btn {
position: fixed;
z-index: 20;
display: flex;
align-items: center;
justify-content: center;
background: #000;
color: #fff;
box-shadow: 0 4px 12px rgb(0 0 0 / 0.2);
}
.fixed-rewards {
left: 20px;
bottom: 34px;
gap: 10px;
min-width: 112px;
height: 46px;
border-radius: 999px;
font-size: 14px;
}
.sv-chat-btn {
right: 22px;
bottom: 34px;
width: 56px;
height: 56px;
border-radius: 50%;
border: 0;
cursor: pointer;
padding: 0;
}
.sv-chat-btn svg {
width: 26px;
height: 26px;
fill: #fff;
}
@media (max-width: 980px) {
body.mobile-menu-open {
overflow: hidden;
}
.header-main__inner {
grid-template-columns: minmax(0, 1fr) auto auto;
gap: 18px;
min-height: 64px;
padding-top: 16px;
}
.site-search {
grid-column: 1 / -1;
order: 4;
margin-bottom: 12px;
}
.primary-nav {
min-height: auto;
padding-bottom: 0;
}
.nav-toggle {
display: inline-flex;
flex-direction: column;
justify-content: center;
width: 28px;
min-height: 38px;
align-items: center;
border: 0;
background: transparent;
color: #fff;
padding: 0;
}
.primary-menu {
display: none;
flex-direction: column;
align-items: flex-start;
gap: 0;
padding: 10px 0 18px;
}
.primary-menu.is-open {
display: flex;
}
.primary-nav.is-open {
max-width: none;
min-height: calc(100vh - 153px);
background: #fff;
color: #111;
padding-right: 20px;
padding-left: 20px;
overflow: hidden;
}
.primary-menu.is-open > li {
width: 100%;
}
.primary-menu.is-open > li:not(.nav-contact):not(.mobile-menu-link) > a {
display: flex;
align-items: center;
justify-content: space-between;
min-height: 43px;
border-bottom: 1px solid #111;
color: #111;
font-size: 16px;
font-weight: 700;
padding: 0;
}
.primary-menu.is-open > li > a::after {
display: none;
}
.primary-menu.is-open .chev {
margin-left: auto;
transform: rotate(-90deg);
}
.primary-menu .nav-contact {
margin-left: 0;
}
.primary-menu.is-open .nav-contact {
margin-top: 22px;
}
.primary-menu.is-open .nav-contact a {
min-width: 118px;
min-height: 34px;
width: max-content;
border-radius: 6px;
background: var(--sv-teal);
color: #fff;
font-size: 16px;
padding: 0 15px;
}
.mobile-menu-link {
display: none;
}
.primary-menu.is-open .mobile-menu-link {
display: block;
}
.primary-menu.is-open .mobile-menu-link a {
display: block;
color: #111;
font-size: 16px;
font-weight: 500;
padding: 8px 0;
text-decoration: none;
}
.primary-nav.is-submenu-open .primary-menu {
min-height: 520px;
}
.primary-nav.is-submenu-open .primary-menu > li {
display: none;
}
.primary-nav.is-submenu-open .primary-menu > li.is-mobile-submenu-open {
display: block;
}
.primary-menu.is-open > li.is-mobile-submenu-open > a {
display: none;
}
.primary-menu.is-open > li.is-mobile-submenu-open > .mega-panel,
.primary-menu.is-open > li.is-mobile-submenu-open > .category-menu {
display: block;
animation: mobile-submenu-in 180ms ease both;
}
.primary-menu.is-open > li:not(.is-mobile-submenu-open) > .mega-panel,
.primary-menu.is-open > li:not(.is-mobile-submenu-open) > .category-menu {
display: none !important;
}
.mobile-submenu-back {
display: inline-flex;
align-items: center;
gap: 10px;
min-height: 42px;
border: 0;
background: transparent;
color: var(--sv-teal);
padding: 0;
font: inherit;
font-weight: 700;
}
.mobile-submenu-back span {
font-size: 24px;
font-weight: 500;
line-height: 1;
}
.mobile-submenu-title {
display: block;
margin: 8px 0 13px;
padding-bottom: 13px;
border-bottom: 1px solid #111;
color: #111;
font-size: 22px;
}
.primary-menu.is-open .mega-panel {
color: #111;
background: #fff;
}
.primary-menu.is-open .mega-inner {
display: flex;
flex-direction: column;
gap: 20px;
padding: 0;
}
.primary-menu.is-open .mega-sidebar {
order: 2;
}
.primary-menu.is-open .mega-content {
order: 1;
}
.primary-menu.is-open .mega-tab {
width: 100%;
height: 44px;
border-top: 1px solid #111;
color: #111;
font-size: 16px;
font-weight: 700;
}
.primary-menu.is-open .mega-tab:last-child {
border-bottom: 1px solid #111;
}
.primary-menu.is-open .mega-tab.mega-all {
height: 44px;
margin: 0 0 20px;
border: 0;
color: #fff;
}
.primary-menu.is-open .mega-promo-grid {
grid-template-columns: 1fr;
gap: 10px;
}
.primary-menu.is-open .brand-grid,
.primary-menu.is-open .flavour-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 28px 20px;
}
.primary-menu.is-open .mega-browse {
float: none;
display: block;
width: auto;
margin: 0;
text-align: center;
font-size: 16px;
font-weight: 700;
}
.primary-menu.is-open .strength-grid {
justify-content: space-between;
gap: 18px;
padding-top: 22px;
}
.primary-menu.is-open .category-menu {
width: auto;
padding: 0;
color: #111;
background: #fff;
}
.primary-menu.is-open .category-menu a {
min-height: 44px;
border-bottom: 1px solid #111;
color: #111;
font-size: 16px;
font-weight: 700;
padding: 11px 0;
}
@keyframes mobile-submenu-in {
from {
opacity: 0;
transform: translateX(32px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
.mega-panel,
.category-menu {
position: static;
display: none;
visibility: visible;
opacity: 1;
pointer-events: auto;
width: auto;
min-height: 0;
transform: none;
box-shadow: none;
}
.primary-menu.is-open .nav-item:hover .mega-panel,
.primary-menu.is-open .nav-item:focus-within .mega-panel,
.primary-menu.is-open .nav-item:hover .category-menu,
.primary-menu.is-open .nav-item:focus-within .category-menu {
display: block;
}
.mega-inner {
grid-template-columns: 1fr;
padding: 20px 0;
}
.brand-grid,
.flavour-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.guide-card--featured,
.footer-inner {
grid-template-columns: 1fr;
}
.guide-section-grid,
.guide-grid,
.guide-feature-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.guide-library-intro {
display: block;
}
.guide-finder {
grid-template-columns: 1fr;
}
.guide-topic-select {
align-items: flex-start;
flex-direction: column;
}
.guide-topic-select select {
width: 100%;
}
.guide-topic-chips {
justify-content: flex-start;
margin-top: 14px;
}
.footer-inner {
min-height: 0;
gap: 34px;
}
.payments,
.footer-bottom {
grid-column: auto;
}
.footer-bottom {
flex-direction: column;
}
}
@media (max-width: 640px) {
body {
font-size: 14px;
}
.announcement {
font-size: 15px;
}
.header-main__inner {
grid-template-columns: minmax(0, 1fr) auto auto;
gap: 10px;
padding: 14px 15px 0;
}
.header__icons {
display: flex;
gap: 14px;
justify-content: flex-end;
}
.brand img {
width: 164px;
}
.header__icon {
width: 28px;
height: 30px;
}
.header__icon .icon {
width: 26px;
height: 26px;
}
.site-search {
height: 41px;
margin: 3px 0 12px;
padding: 0 17px;
}
.site-search input[type="search"] {
font-size: 17px;
}
.product-predictive-search {
top: calc(100% + 10px);
left: -1px;
grid-template-columns: 1fr;
width: calc(100vw - 30px);
max-height: calc(100vh - 150px);
overflow-y: auto;
}
.predictive-search__main,
.predictive-search__suggestions {
padding: 24px 22px;
}
.predictive-result {
grid-template-columns: 54px minmax(0, 1fr);
}
.predictive-result__media {
width: 54px;
height: 54px;
}
.primary-menu {
padding: 0 0 16px;
}
.breadcrumbs {
margin-bottom: 32px;
}
.archive-intro,
.guide-hero {
margin-bottom: 36px;
}
.guide-section-grid,
.guide-grid,
.guide-feature-grid {
grid-template-columns: 1fr;
}
.answer-summary {
padding: 20px;
}
.fixed-rewards span {
display: none;
}
.fixed-rewards {
min-width: 48px;
width: 48px;
}
.footer-inner {
display: block;
padding: 48px 16px 34px;
}
.site-footer h2 {
margin-bottom: 18px;
font-size: 20px;
}
.footer-newsletter p {
max-width: 450px;
font-size: 16px;
}
.newsletter-form {
max-width: none;
margin: 24px 0 22px;
}
.newsletter-form input,
.newsletter-form button {
height: 48px;
}
.footer-accordion {
border-bottom: 1px solid rgb(255 255 255 / 0.24);
}
.footer-accordion h2 {
margin: 0;
}
.footer-accordion__toggle {
position: relative;
display: flex;
justify-content: space-between;
align-items: center;
min-height: 76px;
font-size: 20px;
}
.footer-accordion__toggle::after {
content: "+";
font-size: 28px;
font-weight: 500;
line-height: 1;
}
.footer-accordion.is-open .footer-accordion__toggle::after {
content: "-";
}
.footer-accordion .footer-menu {
display: none;
padding: 0 0 22px;
}
.footer-accordion.is-open .footer-menu {
display: block;
}
.footer-company {
margin-top: 38px;
}
.footer-company > h2,
.footer-company > h3,
.footer-company > p:not(.socials),
.footer-company .socials,
.payments,
.footer-bottom {
display: none;
}
.age-warning {
max-width: 360px;
margin-bottom: 0;
}
}