:root {
	--font-main: "Inter", "Helvetica Neue", Arial, sans-serif;
	--light: #ffffff;
	--dark: #111111;
}
body {
	margin: 0;
	padding: 0;
	font-family: var(--font-main);
	background: #000000;
}
.hero {
	position: relative;
	height: 100vh;
	width: 100%;
	overflow: hidden;
	display: flex;
	align-items: center;
}
.hero-video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
}
.overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.45);
	z-index: 2;
}
.hero-content {
	 opacity: 0;
	position: relative;
	z-index: 3;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 85%;
	max-width: 1400px;
	margin: 0 auto;
	animation: heroFade 1.2s ease forwards;
}
@keyframes heroFade {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.left .logo {
	width: 200px;
	filter: drop-shadow(0 0 8px rgba(0,0,0,0.4));
}
.right {
	max-width: 450px;
}
.right h1 {
	color: var(--light);
	font-size: 2.8rem;
	line-height: 1.2;
	margin-bottom: 1rem;
	font-weight: 700;
}
.right p {
	color: var(--light);
	margin-bottom: 2rem;
	font-size: 1.1rem;
	opacity: .9;
}
.cta {
	background: #00D1B2;
	color: #0A0A0A;
	padding: 12px 28px;
	font-weight: 600;
	text-decoration: none;
	border-radius: 50px;
	transition: .3s ease;
}
.cta:hover {
	background: #7DFFE0;
}
.products {
	background: #0A0A0A;
	padding: 80px 40px;
	color: #fff;
	text-align: center;
}
.products h2 {
	color: #fff;
	font-size: 2.4rem;
	font-weight: 700;
}
.product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 30px;
	max-width: 1200px;
	margin: 0 auto;
}
.product-card {
	background: #131313;
	padding: 40px 20px;
	border-radius: 12px;
	border: 1px solid rgba(255,255,255,0.08);
	font-size: 1.1rem;
	opacity: 0.85;
	transition: 0.3s ease;
}
.product-card:hover {
	transform: translateY(-5px);
	opacity: 1;
	border-color: #00D1B2;
}
.product-name {
	font-size: 1.7rem;
	font-weight: 700;
	margin: 20px 0 10px;
	color: #fff;
}
.product-price {
	font-size: 1.3rem;
	font-weight: 700;
	margin: 20px 0 10px;
	color: #fff;
}
.floating-strip {
	background-color: #111111;
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 0px;
}
.float-img {
	width: 150px;
	height: 120px;
	object-fit: cover;
	border-radius: 10px;
	opacity: 1;
	transition: opacity 0.6s ease;
	/* Gentle floating effect */
	animation: drift 10s ease-in-out infinite alternate;
}
@keyframes drift {
	0% {
		transform: translateY(0px);
	}
	100% {
		transform: translateY(-6px);
	}
}
/* fade-out class added during teleport */
.fade {
	opacity: 0;
}
.cards-container {
	margin-top: 110px;
	display: flex;
	gap: 40px;
	justify-content: center;
	flex-wrap: wrap;
}
/* Base card */
.card {
	background: white;
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}
.card:hover {
	scale: 1.05;
	box-shadow: 0 12px 25px rgba(0,0,0,0.2);
	transition: 0.35s ease;
}
.card-1,.card-3 {
	width: 320px;
	height: 420px;
	display: flex;
	flex-direction: column;
}
/* top label section */
.top-section {
	background: #dcdcdc;
	padding: 30px;
	font-size: 34px;
	font-weight: bold;
	text-align: center;
	clip-path: polygon(0 0, 100% 0, 100% 65%, 0 100%);
}
/* bottom image section */
.image-section {
	flex: 1;
	background-size: cover;
	background-position: center;
	clip-path: polygon(0 0, 100% 30%, 100% 100%, 0% 100%);
}
.img-1 {
	background-image: url("images/download\ \(1\).png");
}
.img-3 {
	background-image: url("images/download\ \(3\).png");
}
/* ----------------- CARD 2 ------------------ */
.card-2 {
	width: 420px;
	height: 450px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 55% 45%;
	position: relative;
	overflow: hidden;
	border-radius: 18px;
}
/* Curved text */
.curved-text {
	position: absolute;
	top: 8%;
	left: 50%;
	transform: translateX(-50%);
	width: 90%;
	height: 160px;
	pointer-events: none;
	z-index: 10;
}
.curved-text text {
	font-size: 48px;
	font-weight: 900;
	fill: white;
	text-shadow: 0 4px 10px rgba(0,0,0,0.45);
	letter-spacing: 3px;
}
/* top shaped image */
.top-image {
	grid-column: 1 / 3;
	background-size: cover;
	background-position: center;
	clip-path: polygon(0 0, 100% 0, 100% 65%, 50% 85%, 0 65%);
}
/* bottom images */
.bottom-image {
	background-size: cover;
	background-position: center;
}
.top-image {
	background-image: url("images/y9DpT.jpg");
}
.left-img {
	background-image: url("images/download\ \(4\).png");
}
.right-img {
	background-image: url("images/download\ \(3\).png");
}
body.body-BG.scrolled {
	background: #ffffff;
	transition: background 1s ease;
}
/* NAV WRAPPER */
.nav-container {
	width: 100%;
	position: fixed;
	top: 20px;
	z-index: 999;
	display: flex;
	justify-content: center;
}
/* MAIN NAV */
.nav {
	width: 78%;
	padding: 24px 48px;
	background: transparent;
	backdrop-filter: blur(0px);
	border-radius: 20px;
	border: 1px solid rgba(255,255,255,0.12);
	/* remove glow, increase inset depth */
	box-shadow:inset 0 0 20px rgba(255,255,255,0.05);
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: 0.35s ease;
}
/* WHEN SCROLLED */
.nav.scrolled {
	background: #ffffff;
	border: 1px solid #e2e2e2;
	box-shadow:inset 0 0 12px rgba(0,0,0,0.05),0 4px 20px rgba(0,0,0,0.06);
	padding: 18px 44px;
}
/* LOGO */
.logo {
	font-family: var(--font-main);
	font-size: 2rem;
	font-weight: 900;
	letter-spacing: 1.8px;
	color: var(--light);
	transition: 0.3s ease;
}
.logo-img {
	width: auto;
	height: 120px;
	border-radius: 15px;
	padding: none;
}
.nav.scrolled .logo {
	color: var(--dark);
}
/* NAV LINKS */
.nav-links {
	display: flex;
	gap: 55px;
	/* center + bigger spacing */
	list-style: none;
}
.nav-links a {
	font-family: var(--font-main);
	font-size: 1.15rem;
	/* bigger nav buttons */
	font-weight: 600;
	color: var(--light);
	text-decoration: none;
	letter-spacing: 0.4px;
	padding: 6px 4px;
	/* thicker click area */
	position: relative;
	transition: color 0.3s ease, opacity 0.3s ease;
}
.nav.scrolled .nav-links a {
	color: var(--dark);
}
/* UNDERLINE ANIMATION */
.nav-links a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 0%;
	height: 2px;
	background: currentColor;
	transition: width 0.3s ease;
	opacity: 0.9;
}
.nav-links a:hover::after {
	width: 100%;
}
.nav-links a:hover {
	opacity: 1;
}
.cart-img {
	width: 38px;
	height: 38px;
	filter: invert(1);
	transition: transform 0.3s ease, filter 0.3s ease;
	cursor: pointer;
}
.nav.scrolled .cart-img {
	filter: invert(0);
}
.cart-img:hover {
	transform: scale(1.1);
}
.cart-img:active {
	transform: scale(0.95);
	transition-duration: 0.1s;
}
/* ===================== FOOTER ===================== */
.footer {
	background: #0A0A0A;
	padding: 80px 50px 40px;
	color: var(--light);
	border-top: 1px solid rgba(255,255,255,0.08);
	box-shadow:inset 0 0 30px rgba(255,255,255,0.04);
}
.footer-inner {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 60px;
}
.footer-col h3 {
	font-size: 1.3rem;
	font-weight: 700;
	margin-bottom: 20px;
	letter-spacing: 0.5px;
}
.footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.footer-col ul li {
	margin-bottom: 12px;
}
.footer-col ul a {
	color: rgba(255,255,255,0.85);
	text-decoration: none;
	font-size: 1rem;
	transition: 0.3s ease;
	position: relative;
}
.footer-col ul a:hover {
	color: #00D1B2;
}
/* Hover underline */
.footer-col ul a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 0%;
	height: 2px;
	background: #00D1B2;
	transition: width .3s ease;
}
.footer-col ul a:hover::after {
	width: 100%;
}
/* Brand column */
.footer-brand {
	max-width: 300px;
}
.footer-logo {
	font-size: 1.8rem;
	font-weight: 900;
	letter-spacing: 2px;
	margin-bottom: 12px;
}
.footer-brand p {
	opacity: 0.85;
	font-size: 1rem;
	line-height: 1.5;
}
/* Bottom small bar */
.footer-bottom {
	margin-top: 60px;
	text-align: center;
	padding-top: 25px;
	border-top: 1px solid rgba(255,255,255,0.07);
	opacity: 0.8;
}
.footer-bottom p {
	font-size: 0.95rem;
}
/* ================= CONTACT PAGE ================= */
.contact-shell {
	margin: 0;
	font-family: var(--font-main);
	background: #000;
	color: #fff;
}
/* MAIN STAGE */
.contact-stage {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
/* ATMOSPHERIC OVERLAY */
.contact-stage-overlay {
	position: absolute;
	inset: 0;
	background:radial-gradient(circle at top,rgba(0,209,178,0.18),rgba(0,0,0,0.92));
	z-index: 1;
}
/* CONTENT GRID */
.contact-stage-inner {
	position: relative;
	z-index: 2;
	width: 85%;
	max-width: 1100px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}
/* LEFT COPY */
.contact-copy h1 {
	font-size: 3rem;
	font-weight: 800;
	margin-bottom: 1rem;
}
.contact-copy p {
	font-size: 1.1rem;
	line-height: 1.6;
	opacity: 0.9;
	max-width: 420px;
}
/* FORM PANEL */
.contact-panel {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 22px;
	padding: 48px;
	backdrop-filter: blur(14px);
	box-shadow:inset 0 0 22px rgba(255,255,255,0.05),0 30px 70px rgba(0,0,0,0.65);
}
.checkout-input,.checkout-textarea,select.checkout-input {
	background: linear-gradient(180deg,rgba(255,255,255,0.08),rgba(255,255,255,0.04));
	border: 1px solid rgba(255,255,255,0.18);
	box-shadow:inset 0 1px 1px rgba(255,255,255,0.06),inset 0 -1px 2px rgba(0,0,0,0.4);
	transition:border-color 0.25s ease,box-shadow 0.25s ease,background 0.25s ease;
}
/* Hover (very subtle) */
.checkout-input:hover,.checkout-textarea:hover,select.checkout-input:hover {
	background: rgba(255,255,255,0.09);
	border-color: rgba(255,255,255,0.28);
}
/* Focus (clean, confident) */
.checkout-input:focus,.checkout-textarea:focus,select.checkout-input:focus {
	background: rgba(255,255,255,0.12);
	border-color: #00d1b2;
	box-shadow:0 0 0 2px rgba(0,209,178,0.25),inset 0 1px 2px rgba(255,255,255,0.1);
}
/* Placeholder clarity */
.checkout-input::placeholder,.checkout-textarea::placeholder {
	color: rgba(255,255,255,0.5);
}
/* BUTTON */
.contact-action-btn {
	margin-top: 8px;
	width: 100%;
	background: #00D1B2;
	color: #0a0a0a;
	border: none;
	border-radius: 50px;
	padding: 15px;
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
	transition: 0.3s ease;
}
.contact-action-btn:hover {
	background: #7DFFE0;
	transform: translateY(-2px);
}
/* RESPONSIVE */
@media (max-width: 900px) {
	.contact-stage-inner {
		grid-template-columns: 1fr;
		gap: 50px;
	}
	.contact-copy h1 {
		font-size: 2.4rem;
	}
}
.about-shell {
	font-family: var(--font-main);
	background: #000;
	color: #fff;
}
/* HERO */
.about-hero {
	position: relative;
	min-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.about-hero-overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top, rgba(0,209,178,0.22), rgba(0,0,0,0.92));
	z-index: 1;
}
.about-hero-inner {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	width: 85%;
	text-align: center;
}
.about-hero-inner h1 {
	font-size: 3.2rem;
	font-weight: 900;
	margin-bottom: 1rem;
}
.about-hero-inner p {
	max-width: 600px;
	margin: 0 auto;
	font-size: 1.15rem;
	line-height: 1.6;
	opacity: 0.9;
}
/* STORY SECTION */
.about-story {
	padding: 100px 50px;
	background: #0a0a0a;
}
.about-story-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}
.about-story-copy h2 {
	font-size: 2.6rem;
	font-weight: 800;
	margin-bottom: 1.2rem;
}
.about-story-copy p {
	font-size: 1.05rem;
	line-height: 1.7;
	opacity: 0.88;
}
.about-story-image {
	height: 420px;
	border-radius: 20px;
	background-size: cover;
	background-position: center;
	box-shadow: 0 25px 60px rgba(0,0,0,0.6);
}
/* VALUES */
.about-values {
	padding: 100px 40px;
	background: #000;
	text-align: center;
}
.about-values h2 {
	font-size: 2.5rem;
	font-weight: 800;
	margin-bottom: 60px;
}
.about-values-grid {
	max-width: 1100px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 35px;
}
.about-value-card {
	background: #131313;
	border-radius: 18px;
	padding: 40px 30px;
	border: 1px solid rgba(255,255,255,0.08);
	transition: 0.35s ease;
}
.about-value-card:hover {
	transform: translateY(-6px);
	border-color: #00d1b2;
}
.about-value-card h3 {
	font-size: 1.4rem;
	margin-bottom: 12px;
	font-weight: 700;
}
.about-value-card p {
	font-size: 1rem;
	opacity: 0.85;
	line-height: 1.6;
}
/* CTA */
.about-cta {
	padding: 120px 40px;
	background: radial-gradient(circle at top, rgba(0,209,178,0.18), #000);
	text-align: center;
}
.about-cta h2 {
	font-size: 2.7rem;
	font-weight: 900;
	margin-bottom: 1.2rem;
}
.about-cta p {
	max-width: 520px;
	margin: 0 auto 2.2rem;
	font-size: 1.1rem;
	opacity: 0.9;
}
.about-cta a {
	display: inline-block;
	background: #00d1b2;
	color: #0a0a0a;
	padding: 14px 34px;
	border-radius: 50px;
	font-weight: 700;
	text-decoration: none;
	transition: 0.3s ease;
}
.about-cta a:hover {
	background: #7dffe0;
	transform: translateY(-2px);
}
/* RESPONSIVE */
@media (max-width: 900px) {
	.about-story-inner {
		grid-template-columns: 1fr;
		gap: 50px;
	}
	.about-hero-inner h1 {
		font-size: 2.4rem;
	}
}
.community-shell {
	font-family: var(--font-main);
	background: #0b0b0b;
	color: #f5f5f5;
}
/* HERO */
.community-hero {
	min-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}
.community-hero-overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top, rgba(255,255,255,0.08), rgba(0,0,0,0.95));
	z-index: 1;
}
.community-hero-inner {
	position: relative;
	z-index: 2;
	max-width: 900px;
	width: 85%;
	text-align: center;
}
.community-hero-inner h1 {
	font-size: 3.4rem;
	font-weight: 900;
	margin-bottom: 1rem;
	letter-spacing: 1px;
}
.community-hero-inner p {
	font-size: 1.2rem;
	opacity: 0.85;
	max-width: 620px;
	margin: 0 auto;
	line-height: 1.6;
}
/* PATHWAYS */
.community-paths {
	padding: 120px 50px;
	background: #0f0f0f;
}
.community-paths-inner {
	max-width: 1200px;
	margin: 0 auto;
}
.community-paths-title {
	text-align: center;
	font-size: 2.6rem;
	font-weight: 800;
	margin-bottom: 70px;
}
.community-paths-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 40px;
}
.community-path-card {
	background: #151515;
	border-radius: 20px;
	padding: 44px 36px 50px;
	border: 1px solid rgba(255,255,255,0.08);
	transition: 0.35s ease;
	position: relative;
	cursor: pointer;
}
.community-path-card:hover {
	transform: translateY(-8px);
	border-color: rgba(255,255,255,0.35);
}
.community-path-card h3 {
	font-size: 1.5rem;
	font-weight: 800;
	margin-bottom: 14px;
}
.community-path-card p {
	font-size: 1rem;
	line-height: 1.6;
	opacity: 0.85;
	margin-bottom: 30px;
}
.community-path-link {
	font-weight: 700;
	letter-spacing: 0.6px;
	font-size: 0.95rem;
	text-transform: uppercase;
	opacity: 0.9;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.community-path-link span {
	transition: transform 0.3s ease;
}
.community-path-card:hover .community-path-link span {
	transform: translateX(6px);
}
.community-path-card a {
	color: inherit;
	text-decoration: none;
	position: absolute;
	inset: 0;
	border-radius: 20px;
}
/* VALUES */
.community-values {
	padding: 120px 40px;
	background: #0b0b0b;
	text-align: center;
}
.community-values-inner {
	max-width: 900px;
	margin: 0 auto;
}
.community-values h2 {
	font-size: 2.4rem;
	font-weight: 800;
	margin-bottom: 40px;
}
.community-values p {
	font-size: 1.15rem;
	line-height: 1.7;
	opacity: 0.85;
}
/* RESPONSIVE */
@media (max-width: 900px) {
	.community-hero-inner h1 {
		font-size: 2.4rem;
	}
}
.shop-shell {
	width: 100%;
	font-family: var(--font-main);
	background: #000;
	color: #fff;
}
/* HERO */
.shop-hero {
	position: relative;
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}
.shop-hero-overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top, rgba(21, 0, 209, 0.22), rgba(0,0,0,0.92));
}
.shop-hero-inner {
	position: relative;
	z-index: 2;
	width: 85%;
	max-width: 900px;
}
.shop-hero-inner h1 {
	font-size: 3.2rem;
	font-weight: 900;
	margin-bottom: 1rem;
}
.shop-hero-inner p {
	font-size: 1.15rem;
	opacity: 0.9;
	margin-bottom: 2.5rem;
}
/* SEARCH BAR */
.shop-search input {
	width: 100%;
	max-width: 480px;
	justify-content: center;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.18);
	padding: 16px 20px;
	border-radius: 50px;
	font-size: 1rem;
	color: #fff;
	outline: none;
	backdrop-filter: blur(12px);
	transition: 0.3s ease;
}
.shop-search input:focus {
	border-color: #00d1b2;
	box-shadow: 0 0 0 2px rgba(0,209,178,0.25);
}
.shop-products {
	padding: auto 50px;
	background: #0a0a0a;
}
.shop-grid {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 35px;
}
/* CARD */
.shop-card {
	background: #131313;
	margin-bottom: 25px;
	border-radius: 18px;
	padding: 22px;
	border: 1px solid rgba(255,255,255,0.08);
	transition: 0.35s ease;
	text-align: center;
}
.shop-card:hover {
	transform: translateY(-8px);
	border-color : #00d1b2;
}
.shop-card-img {
	height: 260px;
	border-radius: 14px;
	background-size: cover;
	background-position: center;
	margin-bottom: 20px;
}
.shop-card h3 {
	color: #fff;
	font-size: 1.3rem;
	font-weight: 700;
	margin-bottom: 8px;
}
.shop-card p {
	color: #fff;
	opacity: 0.85;
	margin-bottom: 18px;
}
/* BUTTON */
.shop-btn {
	display: inline-block;
	background: #00d1b2;
	color: #0a0a0a;
	padding: 12px 28px;
	border-radius: 50px;
	font-weight: 700;
	text-decoration: none;
	transition: 0.3s ease;
}
.shop-btn:hover {
	background: #7dffe0;
	transform: translateY(-2px);
}
/* RESPONSIVE */
@media (max-width: 800px) {
	.shop-hero-inner h1 {
		font-size: 2.4rem;
	}
}
/* ===================== PREMIUM PRODUCT PAGE ===================== */
.product-stage {
	position: relative;
	min-height: 100vh;
	padding: 180px 40px 140px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.product-stage-overlay {
	position: absolute;
	inset: 0;
	background:radial-gradient(circle at top,rgba(0,209,178,0.25),rgba(0,0,0,0.92));
	z-index: 1;
}
.product-stage-inner {
	position: relative;
	z-index: 2;
	max-width: 1300px;
	width: 100%;
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 100px;
	align-items: center;
}
/* IMAGE */
.product-visual {
	display: flex;
	justify-content: center;
}
.product-image-shell {
	position: relative;
	width: 100%;
	max-width: 520px;
	padding: 28px;
	border-radius: 28px;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.14);
	backdrop-filter: blur(18px);
	box-shadow:inset 0 0 25px rgba(255,255,255,0.05),0 60px 120px rgba(0,0,0,0.75);
}
.product-image-shell::after {
	content: "";
	position: absolute;
	inset: -1px;
	border-radius: inherit;
	background: linear-gradient(140deg,rgba(0,209,178,0.5),transparent 60%);
	opacity: 0.35;
	pointer-events: none;
}
.product-image-shell img {
	width: 100%;
	height: 460px;
	object-fit: cover;
	border-radius: 20px;
}
/* TEXT */
.product-info h1 {
	font-size: 3.4rem;
	font-weight: 900;
	line-height: 1.1;
	margin-bottom: 16px;
}
.product-eyebrow {
	display: block;
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #00d1b2;
	margin-bottom: 16px;
}
.product-price {
	font-size: 1.8rem;
	font-weight: 800;
	color: #7dffe0;
	margin-bottom: 26px;
}
.product-description {
	font-size: 1.08rem;
	line-height: 1.75;
	opacity: 0.88;
	max-width: 460px;
	margin-bottom: 40px;
}
/* OPTIONS */
.product-options {
	display: flex;
	gap: 14px;
	margin-bottom: 38px;
}
.option {
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.18);
	color: #fff;
	padding: 12px 18px;
	border-radius: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: 0.25s ease;
}
.option:hover,.option.active {
	background: #00d1b2;
	color: #0a0a0a;
	border-color: #00d1b2;
}
/* CTA */
.product-cta {
	background: #00d1b2;
	color: #0a0a0a;
	border: none;
	padding: 16px 44px;
	font-size: 1.05rem;
	font-weight: 900;
	border-radius: 50px;
	cursor: pointer;
	transition: 0.3s ease;
}
.product-cta:hover {
	background: #7dffe0;
	transform: translateY(-3px);
}
/* META */
.product-meta {
	margin-top: 18px;
	font-size: 0.95rem;
	opacity: 0.7;
}
/* RESPONSIVE */
@media (max-width: 900px) {
	.product-stage-inner {
		grid-template-columns: 1fr;
		gap: 70px;
	}
	.product-info h1 {
		font-size: 2.5rem;
	}
	.product-image-shell img {
		height: 360px;
	}
}
.product-image {
	width: 90px;
	height: 90px;
	border-radius: 20px;
	object-fit: cover;
}


.cart-page {
	max-width: 1100px;
	padding: 190px 40px 80px;
	color: #fff;
	margin: 0 auto;
}
.cart-page h1 {
	font-size: 2.5rem;
	margin-bottom: 40px;
}
.cart-items {
	display: flex;
	flex-direction: column;
	gap: 25px;
}
.cart-item {
	display: grid;
	grid-template-columns: 120px 1fr auto;
	gap: 25px;
	align-items: center;
	background: #131313;
	padding: 20px;
	border-radius: 16px;
	border: 1px solid rgba(255,255,255,0.08);
}
.cart-item img {
	width: 120px;
	height: 120px;
	object-fit: cover;
	border-radius: 12px;
}
.cart-item h3 {
	margin-bottom: 6px;
}
.cart-item-price {
	opacity: 0.85;
}
.cart-qty {
	display: flex;
	align-items: center;
	gap: 10px;
}
.cart-qty button {
	background: #00d1b2;
	border: none;
	border-radius: 50%;
	width: 28px;
	height: 28px;
	font-weight: bold;
	cursor: pointer;
}
.cart-remove {
	color: #ff5a5a;
	cursor: pointer;
	font-weight: 600;
}
.cart-summary {
	margin-top: 40px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.cart-checkout {
	background: #00ffe1;
	color: #0a0a0a;
	border: none;
	width: auto;
	padding: 14px 36px;
	border-radius: 50px;
	font-weight: 800;
	cursor: pointer;
}
*, *::before, *::after {
	box-sizing: border-box;
}
/* Overlay */
.popup-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 1000;
}
.popup-overlay.active {
	display: flex;
}
/* Newsletter container (popup box) */
.newsletter-container {
	position: relative;
	justify-content: center;
	width: 100%;
	max-width: 380px;
	max-height: calc(100vh - 48px);
	padding: 20px;
	overflow-y: auto;
	overscroll-behavior: contain;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	background: #020617;
	border: 1px solid #334155;
	border-radius: 10px;
}
/* Close button */
.close-btn {
	position: absolute;
	top: 8px;
	right: 10px;
	font-size: 20px;
	background: none;
	border: none;
	color: #94a3b8;
	cursor: pointer;
}
.close-btn:hover {
	color: #e5e7eb;
}
/* Title */
.newsletter-container h2 {
	margin: 0 0 14px;
	font-size: 18px;
	font-weight: 600;
	color: #e5e7eb;
	text-align: center;
}
/* Input */
.newsletter-container input {
	width: 100%;
	padding: 11px 13px;
	margin-bottom: 12px;
	border-radius: 8px;
	border: 1px solid #334155;
	background: transparent;
	color: #e5e7eb;
	font-size: 14px;
}
.newsletter-container input::placeholder {
	color: #94a3b8;
}
.newsletter-container input:focus {
	outline: none;
	border-color: #38bdf8;
}
/* Button */
.newsletter-container button[type="submit"] {
	width: 100%;
	padding: 11px;
	border-radius: 9px;
	border: 1px solid #38bdf8;
	background: transparent;
	color: #38bdf8;
	font-weight: 600;
	font-size: 14px;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}
.newsletter-container button:hover:not(:disabled) {
	background-color: #38bdf8;
	color: #020617;
}
.newsletter-container button:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}
/* Alerts */
.alert {
	margin-top: 14px;
	padding: 10px;
	border-radius: 7px;
	font-size: 13px;
	text-align: center;
	border: 1px solid;
}
.alert.success {
	color: #22c55e;
	border-color: #22c55e;
}
.alert.error {
	color: #ef4444;
	border-color: #ef4444;
}
.hidden {
	display: none;
}
/* ===================== CHECKOUT PAGE ===================== */
.checkout-page-wrapper {
	max-width: 900px;
	margin: 0 auto;
	padding: 180px 40px 120px;
	color: #fff;
	font-family: var(--font-main);
}
/* TITLE */
.checkout-page-title {
	font-size: 3rem;
	font-weight: 900;
	margin-bottom: 60px;
	text-align: center;
}
/* SECTIONS */
.checkout-section {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 22px;
	padding: 26px 28px;
	margin-bottom: 22px;
	backdrop-filter: blur(18px);
	box-shadow:inset 0 0 20px rgba(255,255,255,0.03),0 40px 90px rgba(0,0,0,0.7);
}
.checkout-section-title {
	font-size: 1.4rem;
	font-weight: 800;
	margin-bottom: 24px;
}
/* FIELD GROUP */
.checkout-field-group {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-bottom: 14px;
}
/* LABEL */
.checkout-label {
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.4px;
	opacity: 0.85;
}
/* INPUTS */
select.checkout-input {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-color: rgba(255,255,255,0.06);
	color: #fff;
	cursor: pointer;
}
/* Dropdown arrow */
select.checkout-input {
	background-image:linear-gradient(45deg, transparent 50%, #00d1b2 50%),linear-gradient(135deg, #00d1b2 50%, transparent 50%);
	background-position:calc(100% - 18px) 52%,calc(100% - 12px) 52%;
	background-size: 6px 6px;
	background-repeat: no-repeat;
	padding-right: 42px;
}
/* Dropdown options */
select.checkout-input option {
	background-color: #0f1214;
	color: #ffffff;
}
/* Placeholder option */
select.checkout-input option[value=""] {
	color: rgba(255,255,255,0.45);
}
.checkout-input::placeholder {
	color: rgba(255,255,255,0.45);
}
/* ORDER SUMMARY */
.checkout-order-summary-wrapper {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.checkout-order-item {
	display: flex;
	justify-content: space-between;
	font-size: 0.95rem;
	opacity: 0.9;
}
.checkout-order-total {
	display: flex;
	justify-content: space-between;
	margin-top: 18px;
	padding-top: 18px;
	border-top: 1px solid rgba(255,255,255,0.15);
	font-size: 1.1rem;
	font-weight: 900;
}
/* PAY NOW */
.checkout-payment-section {
	text-align: center;
}
/* POLICIES */
.checkout-policies-footer {
	display: flex;
	justify-content: center;
	gap: 24px;
	margin-top: 60px;
	font-size: 0.85rem;
	opacity: 0.75;
}
.checkout-policy-link {
	color: #00d1b2;
	text-decoration: none;
	transition: 0.3s ease;
}
.checkout-policy-link:hover {
	color: #7dffe0;
}
/* RESPONSIVE */
@media (max-width: 800px) {
	.checkout-page-wrapper {
		padding: 140px 32px 100px;
	}
	.checkout-page-title {
		font-size: 2.2rem;
	}
}
/* PAY NOW BUTTON – BASE */
.checkout-pay-now-button {
	background: linear-gradient(135deg,#00d1b2,#7dffe0);
	color: #0a0a0a;
	border: none;
	padding: 16px 52px;
	font-size: 1.1rem;
	font-weight: 900;
	border-radius: 50px;
	cursor: pointer;
	transition: 0.35s ease;
	box-shadow:0 12px 30px rgba(0, 209, 178, 0.35);
}
/* HOVER (ENABLED ONLY) */
.checkout-pay-now-button:not(:disabled):hover {
	transform: translateY(-3px);
	box-shadow:0 20px 50px rgba(0, 209, 178, 0.55);
}
/* DISABLED – PREMIUM LOCKED STATE */
.checkout-pay-now-button:disabled {
	background: linear-gradient(135deg,rgba(255,255,255,0.12),rgba(255,255,255,0.04));
	color: rgba(255,255,255,0.45);
	cursor: not-allowed;
	box-shadow:inset 0 0 0 1px rgba(255,255,255,0.18),0 8px 20px rgba(0,0,0,0.6);
	backdrop-filter: blur(10px);
	transform: none;
}
@media (min-width: 900px) {
	.checkout-billing-section,.checkout-shipping-section {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 18px 22px;
	}
	.checkout-billing-section .checkout-section-title,.checkout-shipping-section .checkout-section-title {
		grid-column: span 2;
	}
}
.contact-panel {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 22px;
	padding: 48px;
	backdrop-filter: blur(14px);
	box-shadow:inset 0 0 22px rgba(255,255,255,0.05),0 30px 70px rgba(0,0,0,0.65);
}
/* INPUT GROUP */
.contact-input-group {
	display: flex;
	flex-direction: column;
	margin-bottom: 24px;
}
.contact-input-group label {
	font-size: 0.9rem;
	opacity: 0.85;
	margin-bottom: 6px;
}
/* INPUTS */
.contact-input-group input,.contact-input-group textarea {
	background: #0f0f0f;
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 14px;
	padding: 14px 16px;
	color: #fff;
	font-size: 1rem;
	outline: none;
	transition: 0.3s ease;
}
.contact-input-group input:focus,.contact-input-group textarea:focus {
	border-color: #00D1B2;
	box-shadow: 0 0 0 2px rgba(0,209,178,0.25);
}
/* ===================== MOBILE ===================== */
@media (max-width: 768px) {
	/* ---------- GLOBAL ---------- */
	body {
		overflow-x: hidden;
	}
	/* ---------- NAV ---------- */
	.nav-container {
		top: 10px;
	}
	.nav {
		width: 92%;
		padding: 16px 20px;
	}
	.nav-links {
		gap: 22px;
	}
	.nav-links a {
		font-size: 0.95rem;
	}
	.logo-img {
		height: 70px;
	}
	.cart-img {
		width: 30px;
		height: 30px;
	}
	/* ---------- HERO ---------- */
	.hero {
		height: auto;
		min-height: 100vh;
		padding: 120px 0 80px;
	}
	.hero-content {
		flex-direction: column;
		text-align: center;
		gap: 40px;
	}
	.left .logo {
		width: 150px;
	}
	.right {
		max-width: 100%;
	}
	.right h1 {
		font-size: 2.1rem;
	}
	.right p {
		font-size: 1rem;
	}
	/* ---------- PRODUCTS ---------- */
	.products {
		padding: 60px 20px;
	}
	.products h2 {
		font-size: 2rem;
	}
	.product-grid {
		gap: 20px;
	}
	/* ---------- FLOATING STRIP ---------- */
	.floating-strip {
		flex-wrap: wrap;
		gap: 12px;
	}
	.float-img {
		width: 110px;
		height: 90px;
	}
	/* ---------- CARDS ---------- */
	.cards-container {
		margin-top: 80px;
		gap: 30px;
	}
	.card-1,.card-3 {
		width: 90%;
		max-width: 340px;
		height: auto;
	}
	.card-2 {
		width: 95%;
		max-width: 360px;
		height: 420px;
	}
	.curved-text text {
		font-size: 32px;
	}
	/* ---------- FOOTER ---------- */
	.footer {
		padding: 60px 25px 30px;
	}
	.footer-inner {
		flex-direction: column;
		gap: 40px;
	}
	.footer-brand {
		max-width: 100%;
	}
	.footer-bottom {
		margin-top: 40px;
	}
	/* ---------- CONTACT PAGE ---------- */
	.contact-stage-inner {
		grid-template-columns: 1fr;
		gap: 50px;
		text-align: center;
	}
}
/* ===================== MOBILE EXTENSION ===================== */
@media (max-width: 768px) {
	/* ---------- GLOBAL ---------- */
	h1 {
		font-size: clamp(2rem, 7vw, 2.4rem);
	}
	h2 {
		font-size: clamp(1.8rem, 6vw, 2.2rem);
	}
	p {
		font-size: 1rem;
	}
	section,.about-story,.about-values,.community-paths,.community-values,.shop-products,.sr-results-section {
		padding-left: 20px;
		padding-right: 20px;
	}
	/* ---------- CONTACT ---------- */
	.contact-stage-inner {
		width: 100%;
		grid-template-columns: 1fr;
		gap: 40px;
		text-align: center;
	}
	.contact-copy p {
		max-width: 100%;
	}
	.contact-panel {
		padding: 32px 24px;
	}
	/* ---------- ABOUT ---------- */
	.about-hero {
		min-height: 70vh;
	}
	.about-hero-inner h1 {
		font-size: 2.2rem;
	}
	.about-story-inner {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.about-story-image {
		height: 300px;
	}
	.about-cta {
		padding: 80px 20px;
	}
	/* ---------- COMMUNITY ---------- */
	.community-hero {
		min-height: 70vh;
	}
	.community-hero-inner h1 {
		font-size: 2.3rem;
	}
	.community-paths {
		padding: 80px 20px;
	}
	.community-paths-title {
		font-size: 2.1rem;
	}
	/* ---------- SHOP ---------- */
	.shop-hero {
		min-height: 60vh;
	}
	.shop-hero-inner h1 {
		font-size: 2.3rem;
	}
	.shop-products {
		padding: 60px 20px;
	}
	.shop-card-img {
		height: 220px;
	}
	/* ---------- PRODUCT PAGE ---------- */
	.product-stage {
		padding: 140px 20px 100px;
	}
	.product-stage-inner {
		grid-template-columns: 1fr;
		gap: 50px;
		text-align: center;
	}
	.product-description {
		max-width: 100%;
	}
	.product-options {
		justify-content: center;
		flex-wrap: wrap;
	}
	.product-image-shell img {
		height: 320px;
	}
	/* ---------- SEARCH RESULTS ---------- */
	.sr-hero {
		padding: 120px 20px 60px;
	}
	.sr-title {
		font-size: 2.2rem;
	}
	.sr-results-grid {
		max-width: 100%;
	}
	/* ---------- CART ---------- */
	.cart-page {
		padding: 150px 20px 60px;
	}
	.cart-item {
		grid-template-columns: 90px 1fr;
		gap: 15px;
	}
	.cart-item img {
		width: 90px;
		height: 90px;
	}
	.cart-summary {
		flex-direction: column;
		gap: 20px;
		text-align: center;
	}
	/* ---------- POPUP / NEWSLETTER ---------- */
	.newsletter-container {
		max-width: 92%;
		padding: 18px;
	}
}
@media (max-width: 600px) {
  .sr-results-grid {
    grid-template-columns: 1fr;  /* single column on small screens */
  }
}





/* ================= SEARCH RESULTS PAGE ================= */
/* PAGE BASE */
.sr-hero,.sr-results-section {
	font-family: var(--font-main);
	color: #fff;
}
/* HERO */
.sr-hero {
	position: relative;
	padding: 160px 40px 80px;
	text-align: center;
	background: #000;
	overflow: hidden;
}
.sr-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top,rgba(0,209,178,0.22),rgba(0,0,0,0.92));
	z-index: 1;
}
.sr-hero-inner {
	position: relative;
	z-index: 2;
	max-width: 900px;
	margin: 0 auto;
}
.sr-title {
	font-size: 3rem;
	font-weight: 900;
	margin-bottom: 12px;
}
.sr-subtitle {
	font-size: 1.1rem;
	opacity: 0.85;
}
/* RESULTS SECTION */
.sr-results-section {
	background: #0a0a0a;
	padding: 80px 40px 120px;
}
.sr-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 35px;
  max-width: 800px; 
  margin: 0 auto;
}
/* RESULT CARD */
.sr-card {
	width: auto;
	background: #131313;
	border-radius: 18px;
	padding: 28px;
	border: 1px solid rgba(255,255,255,0.08);
	transition: 0.35s ease;
}
.sr-card:hover {
	transform: translateY(-8px);
	border-color: #00d1b2;
}
.sr-card-title {
	font-size: 1.4rem;
	font-weight: 800;
	margin-bottom: 10px;
}
.sr-card-text {
	font-size: 1rem;
	opacity: 0.85;
	line-height: 1.6;
	margin-bottom: 18px;
}
.sr-card-link {
	font-weight: 700;
	color: #00d1b2;
	text-decoration: none;
	letter-spacing: 0.5px;
	transition: 0.3s ease;
}
.sr-card-link:hover {
	color: #7dffe0;
}
/* EMPTY STATE */
.sr-no-results {
	grid-column: 1 / -1;
	text-align: center;
	opacity: 0.7;
	font-size: 1.1rem;
}
/* RESPONSIVE */
@media (max-width: 800px) {
	.sr-title {
		font-size: 2.3rem;
	}
}
.sr-card-img {
	height: 220px;
	border-radius: 14px;
	background-size: cover;
	background-position: center;
	margin-bottom: 18px;
}
.sr-card {
	text-decoration: none;
	color: inherit;
	display: block;
}




  .currency-container label {
    font-weight: bold;
    margin-bottom: 5px;
    color: #ffffff;
  }


  .currency-container select {
    padding: 8px 12px;
    border-radius: 6px;
    border: 1px solid #ccc;
    background-color: #fff;
    font-size: 14px;
    transition: border-color 0.3s, box-shadow 0.3s;
    cursor: pointer;
  }

  /* Hover effect */
  .currency-container select:hover {
    border-color: #888;
  }

  /* Focus effect */
  .currency-container select:focus {
    outline: none;
    border-color: #007BFF;
    box-shadow: 0 0 5px rgba(0, 123, 255, 0.5);
  }
.content-newletter-center {
	display: flex;
	justify-content: center;
	align-items: center;
}



.contact-status {
  margin-top: 14px;
  font-size: 14px;
  line-height: 1.4;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.contact-status[data-type] {
  opacity: 1;
  transform: translateY(0);
}

.contact-status[data-type="success"] {
  color: #2ecc71; /* tweak to match brand */
}

.contact-status[data-type="error"] {
  color: #e74c3c;
}

.contact-action-btn.is-loading {
  pointer-events: none;
  opacity: 0.6;
}


:root {
  --dark: #111111;
  --light: #f2f2f2;
}

.small-gallery {
	margin-top: 50px;
  padding: 24px 5vw;
  background-color: var(--dark);
}
.gallery-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  max-width: 1100px;
  margin: 0 auto;
}

.gallery-item {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.gallery-item.large {
  height: 420px;
}

.gallery-column {
  display: grid;
  grid-template-rows: 1fr 1fr;
  height: 420px;
  gap: 12px;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  max-width: none;
}


.overlay-text {
  position: absolute;
  top: 18px;
  left: 18px;
  max-width: 70%;
  color: var(--light);
  z-index: 2;
}

.overlay-text .eyebrow {
  font-size: 9px;
  letter-spacing: 0.3em;
  margin-bottom: 6px;
  opacity: 0.85;
}

.overlay-text h2 {
  font-size: 20px;
  line-height: 1.1;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.overlay-text p {
  font-size: 11px;
  opacity: 0.9;
}

.gallery-item.large::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.25);
}
@media (max-width: 768px) {
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .gallery-item.large {
    height: 300px;
  }

  .gallery-column {
    height: auto;
    grid-template-rows: auto auto;
  }

  .gallery-column .gallery-item {
    height: 200px;
  }

  .overlay-text {
    top: 16px;
    left: 16px;
    max-width: 85%;
  }

  .overlay-text h2 {
    font-size: 18px;
  }
}

/* Scroll reveal base */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s ease, transform 0.8s ease;
  will-change: opacity, transform;
}

/* When visible */
.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

/* Slight delay helpers (optional) */
.reveal.delay-1 { transition-delay: 0.1s; }
.reveal.delay-2 { transition-delay: 0.2s; }
.reveal.delay-3 { transition-delay: 0.3s; }



.checkout-input.error {
  border: 2px solid #e53935;
  background-color: #fff5f5;
}

.checkout-error-text {
  color: #e53935;
  font-size: 0.85rem;
  margin-top: 4px;
}
.original-price {
  text-decoration: line-through;
  opacity: 0.6;
  margin-left: 8px;
}

.sale-price {
  color: red;
  font-weight: bold;
}
.option.out-of-stock {
  opacity: 0.4;
  cursor: not-allowed;
}
.product-card {
  position: relative;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.product-card:hover {
  transform: translateY(-3px);
}

.product-card.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.product-card.disabled img {
  filter: grayscale(100%);
}

.product-image {
  position: relative;
}

.badge {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: bold;
  color: white;
  z-index: 2;
}

.badge.sale {
  background: red;
}

.badge.out {
  background: #333;
  top: 36px;
}

.sale-price {
  color: red;
  font-weight: bold;
  margin-right: 6px;
}

.original-price {
  text-decoration: line-through;
  color: #777;
}

.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: grid;
  place-items: center;
  z-index: 9999;
}

.modal-box {
  background: #0f172a; /* dark slate */
  color: #f8fafc;      /* light text */
  border-radius: 16px;
  padding: 24px;
  max-width: 380px;
  width: 90%;
  box-shadow: 0 25px 60px rgba(0,0,0,.5);
}

.modal-box h2 {
  margin: 0 0 8px;
  font-size: 1.25rem;
}

.modal-box p {
  color: #cbd5f5;
  line-height: 1.5;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 20px;
}

.modal-actions button {
  border: none;
  border-radius: 10px;
  padding: 10px 16px;
  font-weight: 600;
  cursor: pointer;
  transition: transform .15s ease, opacity .15s ease;
}

#modalConfirm {
  background: #6366f1; /* indigo */
  color: white;
}

#modalCancel {
  background: #1e293b;
  color: #e5e7eb;
}

.modal-actions button:hover {
  transform: translateY(-1px);
  opacity: 0.95;
}

.hidden {
  display: none;
}


.cart-notice {
  margin: 16px 0;
  padding: 14px 16px;
  border-radius: 12px;
  font-weight: 500;
  animation: slideDown .25s ease;
}

.cart-notice.info {
  background: #e0e7ff;
  color: #1e3a8a;
}

.cart-notice.error {
  background: #fee2e2;
  color: #991b1b;
}

.cart-notice.success {
  background: #dcfce7;
  color: #166534;
}

.hidden {
  display: none;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

