/**
 * BASE — Typography, Bootstrap Overrides, Navbar, Announcement Bar, Dropdown
 * Sections 2, 3 of main.css (lines 97–563) + Announcement Bar + Navbar Dropdown (lines 3292–3370)
 */

/* ===========================================================================
   2. BASE STYLES & TYPOGRAPHY
   =========================================================================== */

html {
	scroll-behavior: smooth;
	/* Phase C: Force light mode as default — dark mode toggle deferred to future phase */
	color-scheme: light;
}

body {
	background-color: var(--color-surface-page);
	font-family: var(--bs-body-font-family);
	font-size: var(--text-base);
	color: var(--color-text-primary);
	line-height: var(--leading-relaxed);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Display Headings - Serif for Luxury Feel */
h1,
h2,
.display-1,
.display-2,
.display-3,
.display-4,
.display-5,
.display-6,
.h1,
.h2 {
	font-family: var(--font-display);
	font-weight: var(--weight-semi);
	color: var(--color-ink);
	letter-spacing: var(--tracking-tight);
}

h3,
	h4,
	.h3,
	.h4 {
	font-family: var(--font-display);
	font-weight: var(--weight-medium);
	color: var(--color-ink);
}

h5,
h6,
.h5,
.h6 {
	font-family: var(--font-display);
	font-weight: var(--weight-regular);
	color: var(--color-ink);
}

/* Typography refinement */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
	text-wrap: balance;
}

p, li, td, th {
	text-wrap: pretty;
}


/* Links */
a {
	transition: color var(--transition-fast);
}

.skip-to-content {
	position: absolute;
	left: 1rem;
	top: -3.5rem;
	z-index: var(--z-toast);
	padding: 0.75rem 1rem;
	border-radius: var(--radius-sm);
	background: var(--color-surface-card);
	color: var(--color-ink);
	box-shadow: var(--shadow-md);
	text-decoration: none;
	border: 1px solid rgba(197, 163, 90, 0.24);
	transition:
		top var(--transition-fast),
		color var(--transition-fast),
		box-shadow var(--transition-fast);
}

.skip-to-content:focus,
.skip-to-content:focus-visible {
	top: 1rem;
	color: var(--color-link-hover);
	outline: none;
	box-shadow: var(--focus-ring-shadow), var(--shadow-md);
}

/* ===========================================================================
   3. BOOTSTRAP COMPONENT CUSTOMIZATIONS
   =========================================================================== */

/* --- Buttons --- */
.btn {
	font-family: var(--bs-body-font-family);
	font-weight: var(--weight-medium);
	border-radius: 0; /* sharp corners — luxury theme override */
	padding: 0.75rem 1.25rem;
	transition:
		transform var(--transition-fast),
		box-shadow var(--transition-fast),
		background-color var(--transition-fast),
		border-color var(--transition-fast),
		color var(--transition-fast);
}

/* btn-luxury-secondary — thicker border modifier */
.btn-outline-primary.btn-luxury-secondary,
.btn-outline-secondary.btn-luxury-secondary {
	border-width: 2px;
}

.btn-outline-primary.btn-luxury-secondary:hover,
.btn-outline-primary.btn-luxury-secondary:focus-visible,
.btn-outline-secondary.btn-luxury-secondary:hover,
.btn-outline-secondary.btn-luxury-secondary:focus-visible {
	transform: translateY(-1px);
}

/* Strip Bootstrap gradient on outline hover/focus — not in components.css */
.btn-outline-primary:hover,
.btn-outline-primary:focus-visible,
.btn-group .btn-outline-primary:hover,
.btn-group .btn-outline-primary:focus-visible {
	background-image: none;
}

/* --- Cards --- */
.card {
	background: var(--color-surface-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
}

/* Product cards get hover glow effect — no vertical lift for luxury restraint */
.product-card:hover {
	box-shadow: var(--shadow-md);
	border-color: rgba(197, 163, 90, 0.2);
}

.card-img-top {
	border-radius: var(--radius-md) var(--radius-md) 0 0;
	aspect-ratio: 4/3;
	object-fit: cover;
}

.card-title a {
	color: var(--color-ink);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.card-title a:hover {
	color: var(--color-link);
}

/* --- Navbar (Dark Luxury Style) --- */
.navbar-luxury {
	--bs-navbar-color: var(--color-text-inverse);
	--bs-navbar-hover-color: var(--luxury-gold);
	--bs-navbar-active-color: var(--luxury-gold);
	--bs-navbar-bg: transparent;
	background: rgba(10, 10, 10, 0.96);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
	padding: 0;
	z-index: var(--z-navbar);
	transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.navbar-luxury.scrolled {
	padding: 0; /* Slight shrink on inner pages too */
}

/* Homepage: fixed navbar floats over the full-bleed hero */
.navbar-fixed-home {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	z-index: var(--z-navbar);
}

/* Modifier class applied ONLY on the homepage */
.navbar-transparent-home:not(.scrolled) {
	background: transparent !important;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	border-bottom: 1px solid transparent;
	box-shadow: none;
	padding: 1.5rem 0;
}

/* Overrides when the home navbar transitions to scrolled state */
/* Mobile menu treatment for transparent nav */
@media (max-width: 991.98px) {
	.navbar-transparent-home .navbar-collapse {
		background: linear-gradient(180deg, rgba(26, 26, 26, 0.98) 0%, rgba(16, 16, 16, 0.98) 100%);
		backdrop-filter: blur(8px);
		padding: 1rem;
		border-radius: var(--radius-sm);
		margin-top: 1rem;
		box-shadow: 0 18px 38px rgba(0, 0, 0, 0.42), 0 0 0 1px rgba(197, 163, 90, 0.08);
		border: 1px solid rgba(197, 163, 90, 0.32);
	}
}

.navbar-transparent-home.scrolled {
	background: rgba(10, 10, 10, 0.85);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
	padding: 0.75rem 0;
}

.navbar-luxury .navbar-brand {
	display: inline-flex;
	align-items: center;
	font-size: var(--text-xl);
	line-height: var(--leading-none);
	padding: 0.25rem 0;
}

.navbar-luxury .navbar-brand .navbar-brand-mark {
	height: 64px;
	width: auto;
	filter: drop-shadow(0 3px 8px rgba(0, 0, 0, 0.35));
}

.brand-text {
	color: var(--luxury-gold);
	font-family: var(--font-display);
	text-transform: uppercase;
}

.brand-text-navbar {
	font-size: 1.6rem;
	letter-spacing: 2px;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}

.brand-text-footer {
	font-family: 'Playfair Display', serif;
	font-size: 1.25rem;
	letter-spacing: 1px;
	color: var(--luxury-gold);
	text-transform: uppercase;
}

.footer-brand-mark {
	height: 48px;
	width: auto;
}

.footer-address {
	font-style: normal;
	line-height: 1.7;
}

.navbar-luxury .navbar-toggler {
	border-color: var(--luxury-gold);
	padding: 0.4rem 0.65rem;
}

.navbar-luxury .navbar-toggler-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23c5a35a' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-luxury .nav-link {
	color: var(--color-text-inverse);
	font-size: var(--text-sm);
	font-weight: var(--weight-semi);
	padding: 0.7rem 0.9rem;
	position: relative;
	transition: color var(--transition-fast);
}

.navbar-luxury .nav-link::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 10%;
	width: 80%;
	height: 2px;
	background: var(--luxury-gold);
	transform: scaleX(0);
	transform-origin: center;
	transition: transform var(--transition-fast);
}

.navbar-luxury .nav-link:hover::before,
.navbar-luxury .nav-link.active::before {
	transform: scaleX(1);
}

.navbar-luxury .nav-link:hover,
.navbar-luxury .nav-link.active {
	color: var(--luxury-gold);
}

/* Search toggle button — reset browser button defaults, inherit nav-link styles */
.navbar-luxury button.nav-link {
	background: transparent !important;
	border: none;
	cursor: pointer;
	color: inherit;
}

/* ===========================================================================
   NAV ICON BUTTONS — icon-only utility actions (search, wishlist, cart, user)
   =========================================================================== */

.nav-icon-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.4rem;
	height: 2.4rem;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(197, 163, 90, 0.28);
	color: var(--color-text-inverse);
	font-size: 1rem;
	text-decoration: none;
	cursor: pointer;
	transition:
		color var(--transition-fast),
		background var(--transition-fast),
		border-color var(--transition-fast),
		box-shadow var(--transition-fast);
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.24);
}

/* suppress the underline pseudo-element inherited from .nav-link */
.nav-icon-btn::before {
	display: none !important;
}

.nav-icon-btn:hover,
.nav-icon-btn:focus-visible {
	color: var(--luxury-gold-light);
	border-color: rgba(197, 163, 90, 0.6);
	background: rgba(197, 163, 90, 0.12);
	outline: none;
}

.nav-icon-btn.active {
	color: var(--luxury-gold);
	border-color: rgba(197, 163, 90, 0.55);
	background: rgba(197, 163, 90, 0.1);
}

/* Badge counter */
.nav-icon-badge {
	position: absolute;
	top: -0.3rem;
	right: -0.3rem;
	min-width: 1.1rem;
	height: 1.1rem;
	padding: 0 0.25rem;
	border-radius: 999px;
	background: var(--luxury-gold);
	color: var(--luxury-black);
	font-size: 0.65rem;
	font-weight: var(--weight-semi);
	line-height: 1.1rem;
	text-align: center;
	pointer-events: none;
}

/* Dropdown header showing user email */
.dropdown-header-user {
	display: block;
	padding: 0.55rem 1.1rem;
	font-size: var(--text-xs);
	color: rgba(245, 245, 245, 0.55);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 220px;
}

/* quickSearchToggle uses .nav-icon-btn — ID kept for JS targeting only, no styles needed */

@media (max-width: 991.98px) {
	.navbar-transparent-home:not(.scrolled) {
		padding: 1rem 0;
	}

	.navbar-luxury .navbar-brand .navbar-brand-mark {
		height: 50px;
	}

	.brand-text-navbar {
		font-size: 1.4rem;
	}
}

/* --- Forms --- */
.form-control,
.form-select {
	background-color: var(--color-surface-card);
	border-radius: var(--radius-sm);
	border-color: var(--color-border-soft);
	padding: 0.625rem 1rem;
	transition:
		border-color var(--transition-fast),
		box-shadow var(--transition-fast),
		background-color var(--transition-fast);
}

.form-label {
	font-weight: var(--weight-medium);
	color: var(--color-ink);
}

.form-control:focus,
.form-select:focus {
	border-color: var(--luxury-gold);
	box-shadow: var(--focus-ring-shadow);
}

/* Password Toggle Addon Styling inside Input Group */
.login-password-group .password-toggle {
	border-color: var(--color-border-soft);
	background-color: transparent !important;
	transition: border-color var(--transition-fast), color var(--transition-fast);
}
.login-password-group:focus-within .password-toggle {
	border-color: var(--luxury-gold);
}
.login-password-group:focus-within .form-control {
    border-color: var(--luxury-gold);
	box-shadow: var(--focus-ring-shadow);
}
.login-password-group .form-control:focus {
    box-shadow: none; /* Shadow handled by group focus-within if needed */
}

/* --- Badges --- */
.badge.bg-primary {
	background: var(--gradient-gold) !important;
}

/* --- Modal --- */
.modal-content {
	background: var(--color-surface-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-lg);
	box-shadow: 0 25px 50px rgba(0, 0, 0, 0.25);
}

.modal-header {
	border-bottom-color: var(--color-border-subtle);
}

.modal-footer {
	border-top-color: var(--color-border-subtle);
}

/* --- Quick View Modal --- */
.modal-luxury .modal-header {
	background: var(--gradient-premium-dark);
	color: var(--color-text-inverse);
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.modal-luxury .modal-title {
	font-family: var(--font-display);
	color: var(--luxury-gold);
}

.modal-luxury .btn-close {
	filter: invert(1);
	opacity: 0.8;
}

.modal-luxury .btn-close:hover {
	opacity: 1;
}

.modal-luxury .modal-body {
	padding: var(--space-md);
}

.quick-view-image {
	width: 100%;
	height: auto;
	aspect-ratio: 4/3;
	max-height: 400px;
	object-fit: cover;
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
}

.quick-view-details {
	padding: 0.5rem 0;
}

.quick-view-details h3 {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	color: var(--color-ink);
	margin-bottom: 0.5rem;
}

.quick-view-price {
	font-size: var(--text-xl);
	font-weight: var(--weight-bold);
	color: var(--luxury-gold-dark);
}

.text-luxury-primary {
	color: var(--luxury-gold) !important;
}

.error-icon-display {
	font-size: 6rem;
	line-height: 1;
	opacity: 0.35;
}

.error-section {
	min-height: 60vh;
	display: flex;
	align-items: center;
}

.error-eyebrow {
	letter-spacing: 0.15em;
	font-size: 0.8rem;
	text-transform: uppercase;
}

.error-title {
	font-size: 2.25rem;
}

/* --- Accordion --- */
.accordion-button {
	font-family: var(--bs-body-font-family);
	font-weight: var(--weight-medium);
	font-size: var(--text-base);
	padding: 1rem 1.25rem;
}

.accordion-button:not(.collapsed) {
	background-color: var(--luxury-gold-extra-light);
	color: var(--luxury-gold-dark);
}

.accordion-button:focus-visible {
	box-shadow: var(--focus-ring-shadow);
	border-color: var(--luxury-gold);
	outline: none;
}

/* Better keyboard navigation */
.accordion-button:focus-visible {
	box-shadow: 0 0 0 4px rgba(197, 163, 90, 0.25);
	border-color: var(--luxury-gold);
}

/* Enhanced keyboard accessibility for accordion */
.accordion-header:focus-within {
	z-index: var(--z-raised);
}

/* Accordion header h2 styling */
.accordion-header h2 {
	font-family: var(--font-display);
	font-size: var(--text-md);
	font-weight: var(--weight-semi);
	margin: 0;
	width: 100%;
}

.accordion-button:not(.collapsed) .accordion-header h2 {
	color: var(--luxury-gold-dark);
}

/* --- Breadcrumb --- */
.breadcrumb-item a {
	color: var(--color-link);
}

.breadcrumb-item.active {
	color: var(--color-text-secondary);
}

/* ===========================================================================
   ANNOUNCEMENT BAR
   =========================================================================== */

.announcement-bar {
	background: var(--luxury-black);
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--text-sm);
	padding: 0.45rem 0;
	letter-spacing: var(--tracking-wide);
}

.announcement-bar-message {
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.announcement-bar-message i {
	color: var(--luxury-gold);
}

.announcement-bar-link {
	color: var(--luxury-gold-light);
	text-decoration: none;
	font-weight: var(--weight-medium);
	transition: color var(--transition-fast);
}

.announcement-bar-link:hover {
	color: #ffffff;
}

.announcement-bar-right {
	font-size: var(--text-xs);
}

.announcement-bar-right a {
	color: rgba(255, 255, 255, 0.55);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.announcement-bar-right a:hover {
	color: rgba(255, 255, 255, 0.9);
}

/* ===========================================================================
   NAVBAR SHOP DROPDOWN
   =========================================================================== */

.dropdown-menu-luxury {
	--dropdown-bg-start: rgba(26, 26, 26, 0.98);
	--dropdown-bg-end: rgba(16, 16, 16, 0.98);
	--dropdown-border: rgba(197, 163, 90, 0.32);
	--dropdown-text: rgba(245, 245, 245, 0.94);
	--dropdown-hover-bg: rgba(197, 163, 90, 0.14);
	--dropdown-active-bg: rgba(197, 163, 90, 0.2);
	--dropdown-divider: rgba(197, 163, 90, 0.24);
	--dropdown-focus-ring: rgba(197, 163, 90, 0.34);

	border: 1px solid rgba(197, 163, 90, 0.32);
	border-radius: var(--radius-sm);
	box-shadow: 0 18px 38px rgba(0, 0, 0, 0.42), 0 0 0 1px rgba(197, 163, 90, 0.08);
	padding: 0.35rem 0;
	min-width: 220px;
	background: linear-gradient(180deg, var(--dropdown-bg-start) 0%, var(--dropdown-bg-end) 100%);
	backdrop-filter: blur(8px);
	border-color: var(--dropdown-border);
	overflow: hidden;
}

.dropdown-menu-luxury .dropdown-item {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	font-size: var(--text-sm);
	padding: 0.7rem 1.1rem;
	color: var(--dropdown-text);
	font-weight: var(--weight-medium);
	letter-spacing: var(--tracking-wide);
	transition: background var(--transition-fast), color var(--transition-fast);
}

.dropdown-menu-luxury .dropdown-item:hover,
.dropdown-menu-luxury .dropdown-item:focus {
	background: var(--dropdown-hover-bg);
	color: #ffffff;
}

.dropdown-menu-luxury .dropdown-item:focus-visible {
	outline: none;
	box-shadow: inset 0 0 0 2px var(--dropdown-focus-ring);
}

.dropdown-menu-luxury .dropdown-item:active {
	background: var(--dropdown-active-bg);
	color: #ffffff;
}

.dropdown-menu-luxury .dropdown-divider {
	border-color: var(--dropdown-divider);
	margin: 0.2rem 0;
}

.dropdown-menu-luxury .text-luxury-gold {
	color: var(--luxury-gold) !important;
}

.dropdown-menu-luxury .dropdown-item i {
	width: 1.1rem;
	text-align: center;
	font-size: var(--text-sm);
}

/* ===========================================================================
   BUTTON RADIUS — Theme-level override (rounded-0)
   Single source of truth: declared once here, not repeated below.
   =========================================================================== */

/* ===========================================================================
   ACCESSIBILITY — Reduced motion
   =========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.fade-in-up {
		opacity: 1;
		transform: none;
		transition: none;
		animation: none;
	}

	.hero-title,
	.hero-subtitle,
	.hero-cta {
		animation: none;
		opacity: 1;
	}
}

/* ===========================================================================
   PROSE MEASURE — Optimal reading width (65–75ch)
   Apply to long-form copy containers for comfortable reading.
   =========================================================================== */

.prose-measure {
	max-width: 65ch;
}
