@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Ysabeau:wght@200;400;600&display=swap');

:root {
  --font-heading: "Cormorant Garamond", serif;
  --font-body: "Ysabeau", sans-serif;
  --body-font-size: calc(16px + 0.3vw);
  --body-line-height: 1.8;
  
  --h1-font-size: calc(4rem + 1vw); 
  --h2-font-size: calc(3rem + 0.5vw); 
  --h3-font-size: calc(2rem + 0.5vw); 
  
  --bs-primary: #8a1c1c; --bs-primary-rgb: 138, 28, 28; 
  --bs-secondary: #c5a059; --bs-secondary-rgb: 197, 160, 89;
  --dark: #333; --dark-rgb: 51, 51, 51;
  
  --bs-body-bg: #f9f7f2; 
  --bs-body-color: #2b2b2b;
  
  --bs-link-color: #1a1a1a; --bs-link-color-rgb: 26, 26, 26;
  --bs-link-hover-color: #8a1c1c; --bs-link-hover-color-rgb: 138, 28, 28;
  
  --bs-border-radius: 0; 
}

/*html, body {overflow-x: hidden; width: 100%; position: relative;}*/
body {font-family: var(--font-body); font-weight: 400; color: var(--bs-body-color); background-color: var(--bs-body-bg);}
section.hero {background-size: cover; background-position: center; width: 100%;  overflow: hidden !important;}
h1, h2, h3, h4, h5, h6, .navbar-brand {font-family: var(--font-heading); color: #111; font-weight: 600; letter-spacing: 0.5px; margin-bottom: 1.5rem;}
h1 {font-weight: 700;}

section {padding: 10rem 0;} 
.bg-semilight {background-color: rgba(249, 247, 242, 0.9); background: linear-gradient(135deg, rgba(215, 210, 200, 0.95) 0%, rgba(249, 247, 242, 0.9) 50%, rgba(215, 210, 200, 0.95) 100%);}

body, .product {background-image: url('page-bg.jpg'); background-repeat: repeat; background-size: 50%; background-position: top left;}
.product {background-color: #ffffff !important; background-image: url('page-bg-invert.jpg'); border-top: 3px solid var(--bs-secondary); box-shadow: inset 0 15px 40px -10px rgba(0,0,0,0.8);}

.letter-spacing-1 {letter-spacing:1px;}
.letter-spacing-2 {letter-spacing:2px;}

section :is(h1, h2):first-child {text-transform: uppercase; margin-bottom: 4rem; position: relative; display: inline-block; padding-bottom: 30px;}
section :is(h1, h2):first-child::after {content: ''; position: absolute; bottom: 0; left: 0; width: 60px; height: 3px; background-color: var(--bs-primary);}
section.text-center :is(h1, h2):first-child::after {left: 50%; transform: translateX(-50%);}

.btn-primary {background-color: var(--bs-primary); border: 1px solid var(--bs-primary); color: #fff; font-family: var(--font-heading); text-transform: uppercase; letter-spacing: 2px; padding: 15px 40px; font-size: 1.1rem; transition: all 0.5s ease;}
.btn-primary:hover {background-color: #000; border-color: #000; color: var(--bs-secondary);}
.btn-secondary {background: transparent; border: 1px solid #1a1a1a; color: #1a1a1a; font-family: var(--font-heading); text-transform: uppercase; letter-spacing: 1px; padding: 12px 30px; transition: all 0.3s;}
.btn-secondary:hover {background: #1a1a1a; color: #fff;}

.badge-status { font-family: var(--font-heading); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 2px; color: var(--bs-secondary);  border: 1px solid var(--bs-secondary); padding: 5px 12px; margin-right: 8px;	background: #ffffff80;	white-space: nowrap; line-height: 2rem;}
.product .badge-status {	background: transparent;}
.badge-status.highlight { background-color: var(--bs-secondary); color: #000;}

header {background-color: rgba(249, 247, 242, 0.95); border-bottom: 1px solid rgba(0,0,0,0.05); transition: all 0.4s ease;}
header .logo-img {width: 380px; transition: width 0.4s ease;}
header.header-scrolled {padding: 0.5rem 0 !important; backdrop-filter: blur(10px); background-color: rgba(249, 247, 242, 0.9);}
header.header-scrolled .logo-img {width: 180px;}
header.header-scrolled .top-bar-info {margin-bottom:0 !important; display: none !important;}
.navbar-nav .nav-link {font-family: var(--font-heading); font-size: 1.2rem; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; color: #1a1a1a !important; margin-left: 1.5rem; transition: color 0.3s;}
.navbar-nav .nav-link:hover {color: var(--bs-primary) !important;}

section.hero {min-height: 90vh; display: flex; align-items: center;}
section.hero h1 {font-size: calc(3rem + 2vw); line-height: 1.1; margin-bottom: 2rem; text-shadow: 0 10px 30px rgba(0,0,0,0.5); color: white;}

.solitaire-item { margin-bottom: 10rem;}
.solitaire-item:last-child {margin-bottom: 0;}
.new-items .solitaire-item:nth-child(even) {flex-direction: row-reverse;}

.solitaire-img-wrapper { position: relative; overflow: hidden; box-shadow: 0 20px 50px rgba(0,0,0,0.15);}
.solitaire-img-wrapper img { transition: transform 1.5s cubic-bezier(0.2, 1, 0.3, 1); width: 100%; display: block;}
.solitaire-item:hover img { transform: scale(1.03);}

.solitaire-content h3 { font-size: 2.5rem; margin-top: 1rem; margin-bottom: 1.5rem; color: #111;}
.solitaire-content p { font-size: 1.1rem; color: #555; margin-bottom: 2rem; max-width: 90%;}
.price-tag-small { font-family: var(--font-heading); font-size: 1.5rem; color: #888; font-style: italic; margin-top: 2rem; display: block;}

.product-price { font-family: var(--font-heading); font-size: 4rem; color: #fff;   font-weight: 400; letter-spacing: -1px;}
.product-price small { font-size: 1rem; color: #888; letter-spacing: 2px; text-transform: uppercase; display: block; margin-bottom: 5px;}
.product .text-white-50 em, .product .text-white-50 strong {color:white;}

footer { background-color: #080808;  color: #888;  padding-top: 6rem;  padding-bottom: 3rem;   border-top: 4px solid var(--bs-secondary);}
footer h5 { color: var(--bs-secondary);  font-family: var(--font-heading); text-transform: uppercase;   letter-spacing: 2px; font-size: 1.1rem; margin-bottom: 2rem;}
footer a {color: #aaa; text-decoration: none; transition: 0.3s;}
footer a:hover {color: #fff;}
footer .bi {color: var(--bs-secondary) !important;}
footer img.rounded-circle { border: 2px solid #333; background: #000; filter: grayscale(100%);}
footer .d-flex:hover img.rounded-circle { border-color: var(--bs-secondary); filter: grayscale(0%);}
.footer-logo { width: 200px; filter: brightness(0) invert(1);  opacity: 0.7; transition: all 0.3s ease;}
.footer-logo:hover {   opacity: 1;}

.category-circle {border-color: #333 !important; background: transparent;}
.category-item:hover .category-circle {border-color: var(--bs-secondary) !important; background: var(--bs-secondary);}
.category-item:hover .small {color: #fff;}

section.sep-mark {  position: relative;  overflow: visible !important;}
section.sep-mark::after { content: ""; position: absolute; bottom: -30px; left: 50%; transform: translateX(-50%); width: 50%; max-width: 600px; height: 2px;   background: linear-gradient(to right, transparent 0%, var(--bs-secondary) 50%, transparent 100%); z-index: 99; opacity: 0.7; pointer-events: none; }

.journal-section { background-color: #080808;   padding-top: 8rem; position: relative; z-index: 5;	padding-bottom: 8rem;}
.journal-item .journal-img-wrapper { overflow: hidden; position: relative; border: 1px solid #222;   transition: border-color 0.4s ease;}
.journal-item img { transition: all 0.6s ease; filter: grayscale(100%);  opacity: 0.8;}
.journal-item h4 {   font-family: var(--font-heading); font-size: 1.3rem; transition: color 0.3s ease;}
.journal-item:hover img { filter: grayscale(0%); transform: scale(1.05); opacity: 1;}
.journal-item:hover .journal-img-wrapper { border-color: var(--bs-secondary); }
.journal-item:hover h4 { color: var(--bs-secondary) !important;}
.journal-section.sep-mark::after { background: linear-gradient(to right, transparent 0%, #333 50%, transparent 100%); bottom: 0; }

.index-thumb { opacity: 0.5; transition: all 0.3s ease; border: 1px solid transparent;}
.index-thumb:hover { opacity: 1; transform: translateY(-5px); border-color: var(--bs-secondary);}
.index-thumb img { filter: grayscale(100%); transition: filter 0.3s;}
.index-thumb:hover img { filter: grayscale(0%);}

.side-nav-dots { position: fixed; right: 30px; top: 50%; transform: translateY(-50%); z-index: 1000;  opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.5s ease, visibility 0.5s; }
.side-nav-dots.show-nav { opacity: 1; visibility: visible; pointer-events: auto;}
.side-nav-dots { position: fixed; right: 30px; top: 50%; transform: translateY(-50%); z-index: 1000;}
.nav-dot { position: relative; display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; text-decoration: none; margin: 5px; }
.dot-circle { width: 8px; height: 8px; background-color: rgba(0,0,0,0.2); border-radius: 50%; transition: all 0.3s ease;}
.nav-label { position: absolute; right: 30px;  top: 50%; transform: translateY(-50%) translateX(10px);  background: #fff; border: 1px solid #ddd; padding: 8px 15px 8px 8px;  display: flex; align-items: center; gap: 10px; box-shadow: 0 5px 20px rgba(0,0,0,0.1); white-space: nowrap;  opacity: 0; visibility: hidden; transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); pointer-events: none; }
.nav-label img { width: 50px; height: 50px; object-fit: cover; border-radius: 2px;}
.nav-label span { font-family: var(--font-heading); font-weight: 600; color: #1a1a1a;}
.nav-label::after { content: ""; position: absolute; right: -5px; top: 50%; transform: translateY(-50%); width: 0;  height: 0;  border-top: 5px solid transparent; border-bottom: 5px solid transparent; border-left: 5px solid #fff; }
.nav-dot:hover .dot-circle, .nav-dot.active .dot-circle { width: 12px; height: 12px; background-color: var(--bs-primary);}
.nav-dot:hover .nav-label { opacity: 1; visibility: visible; transform: translateY(-50%) translateX(0); pointer-events: auto; }

.has-megamenu { position: static !important;}
.megamenu { left: 0; right: 0; width: 100%; margin-top: 0; border-top: 3px solid var(--bs-primary) !important; transform: none !important;}
.group-hover:hover .transition-transform { transform: scale(1.05);}
.group-hover:hover small { color: var(--bs-primary) !important;}
.transition-transform { transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);}

.archive-item { text-align: center; cursor: default; }
.archive-img-wrapper img { filter: grayscale(100%) opacity(0.7); transition: all 0.5s ease;}
.archive-title { font-family: var(--font-heading); font-size: 1.1rem; margin-bottom: 0.2rem; color: #555;  transition: color 0.3s;}
.archive-meta { font-family: var(--font-body); font-size: 0.85rem; color: #999; text-transform: uppercase; letter-spacing: 1px;}
.archive-item:hover img { filter: grayscale(0%) opacity(0.6);}
.archive-item:hover .archive-title { color: #000;}
.sold-label {   position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);   font-family: var(--font-heading); font-size: 0.75rem;  text-transform: uppercase;  letter-spacing: 2px;  color: white; padding: 6px 14px; z-index: 2; pointer-events: none; white-space: nowrap; opacity: 0.8; transition: all 0.3s ease;}
.archive-item:hover .sold-label { font-size: var(--body-font-size); pacity: 1;}
.related-img-wrapper {overflow: hidden; position: relative; aspect-ratio: 3/4; }
.related-img-wrapper img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s cubic-bezier(0.2, 1, 0.3, 1);}
.related-card h4 { font-family: var(--font-heading); font-size: 1.5rem; transition: color 0.3s ease;}
.related-card:hover img {   transform: scale(1.05);}
.related-card:hover h4 { color: var(--bs-primary);}
.badge-status-tiny { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 1px; font-weight: 600;}

.description-collapse {position: relative;  max-height: 100px;  overflow: hidden; transition: max-height 0.6s ease-in-out, mask-image 0.4s, -webkit-mask-image 0.4s; -webkit-mask-image: linear-gradient(to bottom, black 50%, transparent 100%);  mask-image: linear-gradient(to bottom, black 50%, transparent 100%);}
.description-collapse.expanded {  max-height: 2000px;   -webkit-mask-image: none;  mask-image: none;}

.image-container { position: relative; display: block;}
.reservation-ribbon { position: absolute; bottom: -45px;  right: -45px; background: linear-gradient(45deg, rgba(212, 175, 55, 0.9), rgba(249, 226, 125, 0.9)); width: 130px; height: 130px; transform: rotate(-45deg);  display: flex; align-items: flex-start; justify-content: center; z-index: 10; cursor: help;}
.reservation-ribbon span { color: #000; font-weight: bold; font-size: 0.7rem; text-transform: uppercase; margin-top: 25px; letter-spacing: 1.5px; text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.3);}
.image-container::after { content: attr(data-tooltip); position: absolute; bottom: 75px;  right: 15px; background: rgba(0, 0, 0, 0.9); color: #fff; padding: 8px 15px; font-size: 0.85rem; border-radius: 4px; border: 1px solid #d4af37; white-space: nowrap; z-index: 1000; opacity: 0; visibility: hidden; transform: translateY(10px);   transition: all 0.3s ease; pointer-events: none;}
.image-container:has(.reservation-ribbon:hover)::after { opacity: 1; visibility: visible; transform: translateY(0);	font-size: 1rem;}
@supports not selector(:has(*)) { .image-container:hover::after {  opacity: 1;  visibility: visible;  transform: translateY(0); }}

.prod-gallery img { opacity: 0.5;  border: 1px solid var(--dark);  transition: opacity 0.3s ease-in-out, border-color 0.3s ease-in-out;}
.prod-gallery img:hover { opacity: 1;  border: 1px solid var(--bs-secondary);}
.prod-gallery a {background-color: black;  display: block;}
.prod-gallery .col a { display: block; width: 100%;  aspect-ratio: 3 / 4; overflow: hidden; border: 1px solid var(--dark); transition: all 0.3s ease-in-out;}
.prod-gallery img {   width: 100%; height: 100%; object-fit: cover;  object-position: center;   opacity: 0.6; transition: all 0.3s ease-in-out;}
.prod-gallery .col a:hover { border-color: var(--bs-secondary);}
.prod-gallery .col a:hover img { opacity: 1; transform: scale(1.1);}
.pswp__img { border: 1px solid var(--bs-secondary); margin:10px;}

.border-dark { border:1px solid #333;}
.shadow-blend {   border: 1px solid #2c2c2c;  box-shadow: 0 0 30px 5px rgba(0,0,0,0.9);}

.section-intro h1 { margin-bottom: 2rem;}
.section-intro .lead { font-size: 1.25rem; line-height: 1.6; color: #111;}
.samurai-quote { font-family: var(--font-heading); font-size: calc(1.5rem + 0.5vw); font-style: italic; color: var(--bs-primary); max-width: 800px; margin: 0 auto 1rem; line-height: 1.4;}
.text-columns { column-count: 2; column-gap: 4rem; text-align: justify; hyphens: auto; 	font-size: 1.1rem;}

@media (max-width: 991px) {
.horizontal-scroll-mobile { display: flex !important; flex-wrap: nowrap !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; padding-bottom: 30px !important; padding-left: 20px !important; padding-right: 20px !important; margin-left: -12px; margin-right: -12px; scrollbar-width: none;}
.horizontal-scroll-mobile::-webkit-scrollbar { display: none;}
.horizontal-scroll-mobile > [class*="col-"] { flex: 0 0 auto !important; width: 70% !important; scroll-snap-align: center;}
.archive-section .horizontal-scroll-mobile > [class*="col-"] { width: 60% !important;}
.navbar { position: static; }
.navbar-collapse { position: absolute; top: 100%; left: 0; width: 100%; background: white; z-index: 9999; padding: 20px; box-shadow: 0 15px 30px rgba(0,0,0,0.1); border-top: 1px solid #eee; max-height: 85vh; overflow-y: auto;}
.megamenu { position: static !important; display: none;  width: 100% !important; padding: 15px 0 !important; border: none !important;}
.megamenu.show { display: block !important;}
header .container { position: relative;}	
}

@media (max-width: 768px) { 
	.text-columns {  column-count: 1;  column-gap: 0;  column-rule: none;  text-align: left; } 
	section {padding: 5rem 0;}
}