/* Styles specific to shared elements from prototype */
@font-face {
	font-family: 'DM Sans';
	src: url('fonts/DMSans-Regular.ttf') format('truetype');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: 'DM Sans';
	src: url('fonts/DMSans-Italic.ttf') format('truetype');
	font-weight: 400;
	font-style: italic;
}

@font-face {
	font-family: 'DM Sans';
	src: url('fonts/DMSans-Medium.ttf') format('truetype');
	font-weight: 500;
	font-style: normal;
}

@font-face {
	font-family: 'DM Sans';
	src: url('fonts/DMSans-MediumItalic.ttf') format('truetype');
	font-weight: 500;
	font-style: italic;
}

@font-face {
	font-family: 'DM Sans';
	src: url('fonts/DMSans-Bold.ttf') format('truetype');
	font-weight: 700;
	font-style: normal;
}

@font-face {
	font-family: 'DM Sans';
	src: url('fonts/DMSans-BoldItalic.ttf') format('truetype');
	font-weight: 700;
	font-style: italic;
}


/* =========================
	 Instrument Serif
  ========================= */

@font-face {
	font-family: 'Instrument Serif';
	src: url('fonts/InstrumentSerif-Regular.ttf') format('truetype');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: 'Instrument Serif';
	src: url('fonts/InstrumentSerif-Italic.ttf') format('truetype');
	font-weight: 400;
	font-style: italic;
}


/* =========================
	 Playfair Display
  ========================= */

@font-face {
	font-family: 'Playfair Display';
	src: url('fonts/PlayfairDisplay-Regular.ttf') format('truetype');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: 'Playfair Display';
	src: url('fonts/PlayfairDisplay-Italic.ttf') format('truetype');
	font-weight: 400;
	font-style: italic;
}

@font-face {
	font-family: 'Playfair Display';
	src: url('fonts/PlayfairDisplay-SemiBold.ttf') format('truetype');
	font-weight: 600;
	font-style: normal;
}

@font-face {
	font-family: 'Playfair Display';
	src: url('fonts/PlayfairDisplay-Bold.ttf') format('truetype');
	font-weight: 700;
	font-style: normal;
}

#cookiebox {
	border: none !important;
	box-shadow: none !important;
	background-color: transparent !important;
	background-size: 100% 100%;
	z-index: 10000 !important;
	padding: 25px 20px 25px 20px !important;
	bottom: 3px !important;
	left: 5px !important;
	min-height: auto !important;
	width: 390px !important;
}

#cookiebox a {
	text-decoration: none !important;
}

#cookiebox a#cookiebox_accept {
	position: absolute;
	top: 33px;
	right: 30px;
	margin-right: 0px;
}

#cookiebox a#cookiebox_settings {
	position: absolute;
	top: 33px;
	left: 40px;
}

#cookiebox_heading {
	font-size: 24px !important;
	background-color: #F5F5F5 !important;
	display: none;
}

#cookiebox_inner {
	background-color: #F5F5F5 !important;
}

#cookiebox_accept {
	/* font-size: 14px!important;
	background-color: #90A85B!important;
	font-size: 14px!important;
	margin-right: 8px; */
	background: var(--ink);
	color: #fff;
	background-color: black !important;
	border-radius: 22px !important;
	padding: 12px 26px !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	transition: background .2s !important;
	white-space: nowrap !important;
}

#cookiebox_accept:hover {
	background: var(--red) !important;
}

#cookiebox_settings {
	/* font-size: 14px!important;
	background-color: #808080!important;
	font-size: 14px!important; */
	background: var(--ink);
	color: #fff;
	background-color: #808080 !important;
	border-radius: 22px !important;
	padding: 12px 26px !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	transition: background .2s !important;
	white-space: nowrap !important;
}

#cookiebox_close {
	top: 10px !important;
	top: unset !important;
	bottom: 25px !important;
	right: 20px !important;
	background-color: #808080 !important;
	background-color: #8C8C8C !important;
	color: #F5F5F5 !important;
}

#cookiebox_moreinfo {
	background-color: #808080 !important;
	color: #ffffff !important;
	display: none !important;
}

#cookiebox_details {
	font-size: 15px;
	padding-right: 23px !important;
	padding-left: 20px;
	padding-top: 55px;
}

.content_section p {
	font-size: 16px;
	line-height: 1.85;
	color: var(--ink-2);
	margin-bottom: 18px;
}

.page-standard {
	position: relative;
	max-width: 1200px;
	margin: 0 auto
}

/* Home Page */
.vtrack .vcplay {
	left: 50%;
}

/* Blog page */
.share-button {
	/* copying css .share-btn from original.css */
	border: 1.5px solid var(--bdr);
	border-radius: 20px;
	padding: 8px 16px;
	font-size: 12px;
	font-weight: 600;
	background: var(--white);
	cursor: pointer;
	transition: all .15s
}
.share-button:hover {
	/* copying css .share-btn:hover from original.css */
	border-color: var(--red);
	color: var(--red)
}

/* Footer */
.fb-col {
	display: block;
}
.fb-col,
.fb-legal {
	position: unset;
	background: none;
	border: none;
	height: auto;
}
.fb-copy {
	max-width: 580px;
}
.fb-legal {
	padding: 0px;
}

@media screen and (max-width: 1280px) {
	.page-standard {
		max-width: 768px;
	}
}

@media screen and (max-width: 800px) {
	.page-standard {
		max-width: 640px;
	}
}

@media screen and (max-width: 700px) {
	.page-standard {
		max-width: 520px;
	}
}

@media screen and (max-width: 600px) {
	.page-standard {
		padding: 0 30px;
		max-width: 100%;
	}
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

em {
  font-family: 'Playfair Display', serif;
  font-style: italic;
}

:root {
  --red: #E8180A;
  --red-d: #C01008;
  --red-pale: #FFF0EF;
  --pink: #FFE3E6;
  --pink-m: #FFC5CB;
  --pink-s: #FFF5F6;
  --ink: #0F0505;
  --ink-2: #2A1010;
  --mut: #7A5555;
  --sand: #FAF6F1;
  --bdr: #EDE0E0;
  --white: #fff;
  --r: 20px;
	--navy:#0B213E;--mid:#6b5a60;--light:#fff0f2;--border:#f5d0d5;--page:#fff7f8;
	--font-b:'DM Sans',sans-serif;--font-h:'Playfair Display',serif;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--white);
  color: var(--ink);
  overflow-x: hidden;
}

header {
  position: relative;
  z-index: 999;
}

a {
  text-decoration: none;
  color: inherit;
}

img {
  display: block;
  max-width: 100%;
}

button {
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  border: none;
  background: none;
}

.ann {
  position: relative;
  z-index: 501;
  background: var(--ink);
  color: #fff;
  text-align: center;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.ann a {
  color: var(--pink-m);
  font-weight: 700;
  text-decoration: underline;
}

nav {
  background: var(--white);
  border-bottom: 1px solid var(--bdr);
  position: sticky;
  top: 0;
  z-index: 500;
  height: 68px;
  display: flex;
  align-items: center;
  padding: 0 40px;
  gap: 24px;
}

nav.main-nav {
  padding: 0;
}

#mobile_menu_toggle,
#tc-mobile-menu-overlay {
  display: none;
}

#mobile_menu_toggle #mobile_menu_toggle_text {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 40px;
  transition: background .3s linear;
}

#mobile_menu_toggle #mobile_menu_toggle_text:before,
#mobile_menu_toggle #mobile_menu_toggle_text:after {
  content: "";
  position: absolute;
  left: auto;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  margin-top: -6px;
  width: 40px;
  height: 4px;
  background: var(--red);
  box-shadow: 0 9px 0 0 var(--red), 0 18px 0 0 transparent;
  border-radius: 1px;
  transition: transform .3s linear, background-color 0s linear, box-shadow 0s linear;
}

#mobile_menu_toggle.open-nav #mobile_menu_toggle_text:after {
  background-color: transparent;
}

#mobile_menu_toggle #mobile_menu_toggle_text:after {
  box-shadow: 0 9px 0 0 transparent, 0 18px 0 0 var(--red);
}

#mobile_menu_toggle #mobile_menu_toggle_text:after {
  /* background-color: transparent; */
}

#mobile_menu_toggle.open-nav #mobile_menu_toggle_text:before {
  transform: rotate(45deg);
  top: 63%;
  left: 4px;
  box-shadow: 0 9px 0 0 transparent;
}

#mobile_menu_toggle.open-nav #mobile_menu_toggle_text:after {
  transform: rotate(-45deg);
  top: 30%;
  right: 8px;
}

#tc-mobile-menu-overlay {
  position: fixed;
  z-index: 150;
  width: 100%;
  top: 68px;
  top: 108px;
  right: 0;
  height: 100%;
  padding-bottom: 120px;
  background: rgba(0, 0, 0, 0.7);
  width: 100%;
  height: 100%;
}

.nl-text {
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: -.01em;
}

.nl-text em {
  color: var(--red);
}

.ncta {
  background: var(--red);
  color: #fff;
  border-radius: 24px;
  padding: 10px 22px;
  font-size: 13px;
  font-weight: 700;
  transition: background .15s;
  display: inline-block;
}

.nav-acts.nav-acts-mobile .ncta {
  display: none;
}

.ncta:hover {
  background: var(--red-d);
}

.nav-links {
  display: flex;
  align-items: center;
  list-style: none;
  flex: 1;
  gap: 4px;
}

.nav-links a {
  font-size: 14px;
  font-weight: 500;
  color: var(--mut);
  padding: 0 12px;
  height: 68px;
  display: flex;
  align-items: center;
  transition: color .15s;
}

.nav-links a:hover,
.nav-links a.act {
  color: var(--red);
}

.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(232, 24, 10, .15);
  border: 1px solid rgba(232, 24, 10, .3);
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 11px;
  font-weight: 700;
  color: var(--pink-m);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.hero-pill::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--red);
  animation: pulse 2s infinite;
}

@keyframes pulse {

  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .3;
    transform: scale(.8);
  }
}

.btn-solid {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ink);
  color: #fff;
  border-radius: 24px;
  padding: 13px 28px;
  font-size: 14px;
  font-weight: 600;
  transition: all .2s;
}

.btn-solid:hover {
  background: var(--red);
  transform: translateY(-2px);
}

.btn-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1.5px solid var(--ink);
  color: var(--ink);
  border-radius: 24px;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 600;
  transition: all .2s;
}

.btn-line:hover {
  border-color: var(--red);
  color: var(--red);
}

.eye {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--red);
  display: block;
}

.sec-h2 {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(26px, 4vw, 46px);
  color: var(--ink);
  line-height: 1.1;
  font-weight: 400;
}

.sec-h2 em {
  color: var(--red);
}

.sec-p {
  font-size: 15px;
  color: var(--mut);
  line-height: 1.75;
  max-width: 520px;
}

.sec-hdr {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 40px;
  gap: 20px;
  flex-wrap: wrap;
}

.chips {
  display: flex;
  gap: 7px;
  overflow-x: auto;
  scrollbar-width: none;
  padding-bottom: 2px;
}

.chips::-webkit-scrollbar {
  display: none;
}

.chip {
  flex-shrink: 0;
  background: #fff;
  border: 1.5px solid var(--bdr);
  border-radius: 20px;
  padding: 7px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-2);
  transition: all .15s;
  white-space: nowrap;
}

.chip.active,
.chip:hover {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}

.tcard {
  background: var(--white);
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--bdr);
  transition: transform .22s, box-shadow .22s;
  cursor: pointer;
  display: flex;
  flex-direction: column;
}

.tcard:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(232, 24, 10, .1);
}

.tcard:hover .tcph {
  transform: scale(1.06);
}

.tcard:hover .tc-arrow {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}

.nl-form {
  display: flex;
  gap: 8px;
  margin: 0 auto;
}

.nl-form input {
  flex: 1;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  outline: none;
}

.nl-form input:focus {
  border-color: var(--red);
}

.nl-form button {
  border-radius: 12px;
  font-size: 14px;
  font-weight: 700;
  transition: background .15s;
  white-space: nowrap;
}

.footer-simple {
  background: #080202;
  padding: 40px;
  text-align: center;
}

.footer-simple p {
  font-size: 12px;
  color: rgba(255, 255, 255, .25);
}

.footer-simple a {
  color: rgba(255, 255, 255, .4);
  margin: 0 8px;
}

.footer-simple a:hover {
  color: var(--pink-m);
}

.footer-links {
  background: var(--ink);
  padding: 32px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}

.footer-links p {
  font-size: 12px;
  color: rgba(255, 255, 255, .3);
}

.f-links {
  display: flex;
  gap: 16px;
}

.f-links a {
  font-size: 12px;
  color: rgba(255, 255, 255, .4);
  transition: color .15s;
}

.f-links a:hover {
  color: var(--pink-m);
}

.footer-home {
  background: var(--ink);
  padding: 64px 40px 32px;
}

.footer-home .f-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.footer-home .f-logo {
  font-family: 'Instrument Serif', serif;
  font-size: 26px;
  color: #fff;
  font-weight: 400;
  margin-bottom: 14px;
}

.footer-home .f-logo em {
  color: var(--pink-m);
}

.footer-home .f-brand p {
  font-size: 13px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.8;
  max-width: 270px;
  margin-bottom: 20px;
}

.footer-home .f-social {
  display: flex;
  gap: 8px;
}

.footer-home .fsoc {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .14);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: rgba(255, 255, 255, .5);
  transition: all .15s;
}

.footer-home .fsoc:hover {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}

.footer-home .f-col h5 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255, 255, 255, .28);
  margin-bottom: 14px;
}

.footer-home .f-col a {
  display: block;
  font-size: 13px;
  color: rgba(255, 255, 255, .48);
  margin-bottom: 8px;
  transition: color .15s;
}

.footer-home .f-col a:hover {
  color: var(--pink-m);
}

.footer-home .f-nl {
  display: flex;
  gap: 7px;
  margin-top: 6px;
}

.footer-home .f-nl input {
  flex: 1;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .13);
  border-radius: 11px;
  padding: 10px 14px;
  color: #fff;
  font-size: 13px;
  font-family: 'DM Sans', sans-serif;
  outline: none;
}

.footer-home .f-nl input::placeholder {
  color: rgba(255, 255, 255, .28);
}

.footer-home .f-nl input:focus {
  border-color: rgba(232, 24, 10, .45);
}

.footer-home .f-nl button {
  background: var(--red);
  color: #fff;
  border-radius: 11px;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  transition: background .15s;
  white-space: nowrap;
}

.footer-home .f-nl button:hover {
  background: var(--red-d);
}

.footer-home .f-bot {
  max-width: 1200px;
  margin: 0 auto;
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 12px;
  color: rgba(255, 255, 255, .3);
}

.footer-home .fbadge {
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 7px;
  padding: 3px 9px;
  font-size: 10px;
}

.featured-card,
.bc,
.dep-card,
.rel-card {
  background: var(--white);
  overflow: hidden;
  border: 1px solid var(--bdr);
  cursor: pointer;
}

.fc-img,
.bc-img,
.dc-img,
.rel-img {
  overflow: hidden;
  position: relative;
}

.fc-img img,
.bc-img img,
.dc-img img,
.rel-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 1100px) {
  .footer-home .f-grid {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }
}

@media (max-width: 768px) {
  body {
    position: relative;
  }

  header {
    position: fixed;
    width: 100%;
  }

  nav {
    justify-content: start;
  }

  #mobile_menu_toggle {
    display: block;
    margin: 0 0 0 auto;
  }

  .open-nav #tc-mobile-menu-overlay {
    display: block;
  }

  nav.main-nav {
    display: block;
    position: absolute;
    top: 68px;
    right: -310px;
    width: 300px;
    height: 100vh;
    background-color: var(--pink);
    overflow: auto;
    transition: right .3s linear;
  }

  nav.open-nav nav.main-nav {
    right: 0;
  }

  .nav-links {
    display: block;
  }

  .nav-links a {
    height: 52px;
    padding: 0 16px
  }

  .nav-acts.nav-acts-mobile .ncta {
    display: block;
  }

  nav.main-nav .ncta {
    text-align: center;
    width: calc(100% - 24px);
    margin: 20px auto 0 12px;
  }


  .footer-home .f-grid {
    grid-template-columns: 1fr;
  }

  .footer-home {
    padding: 48px 20px 24px;
  }
}

@media screen and (max-width: 480px) {
  .nav-acts.nav-acts-mobile .ncta {
    display: none;
  }

  #mobile_menu_toggle #mobile_menu_toggle_text {
    top: 3px;
  }

  #tc-mobile-menu-overlay,
  .open-nav #tc-mobile-menu-overlay {
    display: none;
  }

  nav.main-nav {
    width: 100%;
    right: -100%;
  }
}

.page-404 {
  position: relative;
  height: calc(100vh - 199px);
}

.page-404 .header {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0, 0, 0, 0.5);
  color: white;
  border: none;
  padding: 15px;
  cursor: pointer;
  font-size: 18px;
  border-radius: 50%;
}

.btn:hover {
  background: rgba(0, 0, 0, 0.8);
}

.btn-prev {
  left: 10px;
}

.btn-next {
  right: 10px;
}

.revrow,
.review-slider-container {
  position: relative;
}

/* Update your existing revrow properties */
.revrow {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scrollbar-width: none;
  padding-bottom: 4px;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
}

/* New layout mechanics wrapper */
.slider-viewport-wrapper {
  position: relative;
  /* Context parent anchor for absolute positioning */
  width: 100%;
}

/* Floating overlay layout properties */
.s-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 1px solid var(--bdr);
  background: var(--white);
  color: var(--ink);
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  /* Ensures buttons float over the cards */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  /* Clean pop shadow overlay */
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}

/* Positions buttons on edges. Change to negative value (e.g. -23px) to hang off edge */
.s-prev {
  left: -50px;
}

.s-next {
  right: -50px;
}

/* Micro interaction states combo */
.s-btn:hover {
  background: var(--sand);
  border-color: var(--ink);
}

.s-btn:active {
  transform: translateY(-50%) scale(0.95);
}

#vtrack-prev {
  left: -25px;
}

#vtrack-next {
  right: -25px;
}

.blog-hero, .filter-hero {
  background: var(--ink);
  padding: 80px 40px;
  text-align: center;
  position: relative;
  overflow: hidden
}

.blog-hero::before, 
.filter-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(232, 24, 10, .15) 0%, transparent 65%)
}

.blog-hero::after, 
.filter-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 30%, rgba(255, 197, 203, .06) 0%, transparent 60%)
}

.blog-hero-inner, 
.filter-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 700px;
  margin: 0 auto
}

.blog-hero .eye,
.filter-hero .eye {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--pink-m);
  display: block;
  margin-bottom: 16px
}

.blog-hero h1,
.filter-hero h1 {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(40px, 6vw, 72px);
  color: #fff;
  font-weight: 400;
  line-height: 1.05;
  margin-bottom: 16px
}

.blog-hero h1 em,
.filter-hero h1 em {
  font-style: italic;
  color: var(--pink-m)
}

.blog-hero p,
.filter-hero p {
  font-size: 16px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.8;
  max-width: 480px;
  margin: 0 auto 32px
}

.filter-bar {
  background: var(--sand);
  border-bottom: 1px solid var(--bdr);
  padding: 14px 40px;
  position: sticky;
  top: 68px;
  z-index: 100
}

.filter-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap
}

.filter-lbl {
  font-size: 11px;
  font-weight: 700;
  color: var(--mut);
  text-transform: uppercase;
  letter-spacing: .1em;
  white-space: nowrap
}

.chip {
  flex-shrink: 0;
  background: var(--white);
  border: 1.5px solid var(--bdr);
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-2);
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap
}

.chip.active,
.chip:hover {
  background: var(--red);
  color: #fff;
  border-color: var(--red)
}

.search-input {
  flex: 1;
  min-width: 180px;
  max-width: 280px;
  border: 1.5px solid var(--bdr);
  border-radius: 20px;
  padding: 8px 16px;
  font-size: 13px;
  outline: none;
  font-family: 'DM Sans', sans-serif
}

.search-input:focus {
  border-color: var(--red)
}

.blog-section {
  padding: 64px 40px;
  max-width: 1200px;
  margin: 0 auto
}

.featured-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 24px;
  margin-bottom: 56px;
  transition: transform .25s, box-shadow .25s;
  cursor: pointer
}

.featured-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 24px 60px rgba(232, 24, 10, .1)
}

.fc-img {
  height: 420px;
  position: relative
}

.fc-img img {
  transition: transform .5s
}

.featured-card:hover .fc-img img {
  transform: scale(1.04)
}

.fc-cat {
  position: absolute;
  top: 20px;
  left: 20px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 5px 12px;
  border-radius: 20px
}

.fc-body {
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: center
}

.fc-meta {
  font-size: 12px;
  color: var(--mut);
  margin-bottom: 14px
}

.fc-title {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(24px, 3vw, 36px);
  color: var(--ink);
  margin-bottom: 14px;
  line-height: 1.15;
  font-weight: 400
}

.fc-title em {
  font-style: italic;
  color: var(--red)
}

.fc-exc {
  font-size: 15px;
  color: var(--mut);
  line-height: 1.75;
  margin-bottom: 24px
}

.fc-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--red);
  transition: gap .2s
}

.featured-card:hover .fc-link {
  gap: 12px
}

.grid-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px
}

.grid-hdr h2 {
  font-family: 'Instrument Serif', serif;
  font-size: 28px;
  font-weight: 400
}

.grid-hdr h2 em {
  font-style: italic;
  color: var(--red)
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px
}

.bc {
  border-radius: 18px;
  transition: transform .22s, box-shadow .22s;
  display: flex;
  flex-direction: column
}

.bc:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(232, 24, 10, .09)
}

.bc-img {
  height: 200px;
  position: relative
}

.bc-img img {
  transition: transform .4s
}

.bc:hover .bc-img img {
  transform: scale(1.06)
}

.bc-cat {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--red);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: 10px
}

.bc-body {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column
}

.bc-meta {
  font-size: 11px;
  color: var(--mut);
  margin-bottom: 8px
}

.bc-title {
  font-family: 'Instrument Serif', serif;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 8px;
  line-height: 1.25;
  font-weight: 400;
  flex: 1
}

.bc-exc {
  font-size: 12.5px;
  color: var(--mut);
  line-height: 1.6;
  margin-bottom: 14px
}

.bc-read {
  font-size: 12px;
  font-weight: 700;
  color: var(--red)
}

.bc:hover .bc-read {
  text-decoration: underline
}

.hide {
  display: none !important
}

.nl-sec {
  background: var(--ink);
  padding: 72px 40px;
  text-align: center
}

.nl-sec h2 {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(32px, 5vw, 52px);
  color: #fff;
  font-weight: 400;
  margin-bottom: 12px
}

.nl-sec h2 em {
  font-style: italic;
  color: var(--pink-m)
}

.nl-sec p {
  font-size: 15px;
  color: rgba(255, 255, 255, .45);
  margin-bottom: 28px
}

.nl-form {
  max-width: 440px;
  margin: 0 auto
}

.nl-form input {
  flex: 1;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .15);
  border-radius: 12px;
  padding: 13px 16px;
  color: #fff;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif
}

.nl-form input::placeholder {
  color: rgba(255, 255, 255, .3)
}

.nl-form input:focus {
  border-color: var(--red)
}

.nl-form button {
  background: var(--red);
  color: #fff;
  padding: 13px 22px;
  font-size: 14px
}

.nl-form button:hover {
  background: var(--red-d)
}

@media screen and (max-width:1280px) {
  .s-prev {
    left: -20px;
  }

  .s-next {
    right: -20px;
  }
}

@media(max-width:900px) {

  .featured-card {
    grid-template-columns: 1fr
  }

  .fc-img {
    height: 260px
  }

  .fc-body {
    padding: 28px
  }

  .blog-grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .blog-section {
    padding: 40px 20px
  }

  .filter-bar {
    padding: 12px 20px
  }
}

@media(max-width:600px) {
  .blog-grid {
    grid-template-columns: 1fr
  }

  .blog-hero,
  .filter-hero {
    padding: 56px 24px
  }

  .nl-form {
    flex-direction: column
  }
}