/*
Theme Name: Mart Sander Custom
Theme URI: https://martsander.com
Author: Mart Sander
Author URI: https://martsander.com
Description: A modern, artistic WordPress theme with WooCommerce support. Features a sophisticated beige color palette and elegant typography perfect for creative professionals.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mart-sander-custom
Tags: woocommerce, e-commerce, custom-colors, custom-logo, custom-menu, featured-images, full-site-editing, block-styles, wide-blocks, portfolio

Mart Sander Custom Theme - An artistic portfolio and e-commerce theme with Tailwind CSS.
*/

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */

:root {
	--msc-cream-50: #fffefb;
	--msc-cream-100: #fdfbf7;
	--msc-stone-200: #e7e5e4;
	--msc-stone-400: #a8a29e;
	--msc-stone-500: #78716c;
	--msc-stone-600: #57534e;
	--msc-stone-700: #44403c;
	--msc-stone-800: #292524;
	--msc-stone-900: #1c1917;
	--msc-amber-500: #f59e0b;
	--msc-amber-600: #d97706;
	--msc-amber-700: #b45309;
}

/* ==========================================================================
   Base Styles
   ========================================================================== */

body {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.font-serif {
	font-family: 'Cormorant Garamond', Georgia, serif;
}

/* ==========================================================================
   Header Styles
   ========================================================================== */

#masthead {
	width: 100vw;
	left: 0;
	right: 0;
	transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

/* Ensure no horizontal scroll from 100vw */
html, body {
	overflow-x: hidden;
}

/* Transparent header (over hero) - now with semi-transparent background for readability */
#masthead.header-transparent {
	background-color: rgba(255, 254, 251, 0.95);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: #1c1917;
	box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.05);
}

#masthead.header-transparent .header-logo {
	color: #1c1917;
}

#masthead.header-transparent .main-navigation a {
	color: #1c1917;
}

#masthead.header-transparent .mini-cart,
#masthead.header-transparent .mobile-menu-toggle {
	color: #1c1917;
}

/* Solid header (scrolled) */
#masthead.header-solid {
	background-color: #fffefb;
	box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.05);
	color: #1c1917;
}

#masthead.header-solid .header-logo {
	color: #1c1917;
}

#masthead.header-solid .main-navigation a {
	color: #1c1917;
}

#masthead.header-solid .mini-cart,
#masthead.header-solid .mobile-menu-toggle {
	color: #1c1917;
}

/* Navigation links */
.main-navigation a {
	position: relative;
	font-size: 0.875rem;
	letter-spacing: 0.025em;
	transition: opacity 0.2s ease;
}

.main-navigation a:hover {
	opacity: 0.7;
}

.main-navigation a::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 1px;
	background-color: currentColor;
	transition: width 0.3s ease;
}

.main-navigation a:hover::after {
	width: 100%;
}

/* Fullscreen Mobile Menu */
#mobile-menu-overlay {
	-webkit-overflow-scrolling: touch;
}

.mobile-menu-bg {
	transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-menu-panel {
	transition: transform 0.45s cubic-bezier(0.32, 0.72, 0, 1);
	background: linear-gradient(180deg, rgba(12, 10, 9, 0.98) 0%, rgba(28, 25, 23, 0.98) 100%);
}

/* Fade items */
.menu-fade-item {
	transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Link items - slide up animation */
.menu-link-item {
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), 
	            opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1),
	            color 0.2s ease;
}

/* Card items */
.menu-card-item {
	transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), 
	            opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1),
	            background-color 0.2s ease,
	            border-color 0.2s ease;
}

/* Menu link hover effects */
#mobile-menu-overlay .menu-link-item:hover {
	transform: translateX(8px) !important;
}

/* Decorative line for section labels */
#mobile-menu-overlay span[class*="tracking-"] {
	position: relative;
}

#mobile-menu-overlay span[class*="tracking-"]::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -4px;
	width: 24px;
	height: 1px;
	background: linear-gradient(90deg, rgba(245, 158, 11, 0.5), transparent);
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.animate-fade-in-up {
	animation: fadeInUp 0.8s ease-out forwards;
}

.animation-delay-200 { animation-delay: 0.2s; }
.animation-delay-400 { animation-delay: 0.4s; }
.animation-delay-600 { animation-delay: 0.6s; }
.animation-delay-800 { animation-delay: 0.8s; }

/* Hero Section - Prevent mobile address bar resize */
.hero-section {
	min-height: 100vh;
	position: relative;
	overflow: hidden;
}

.hero-bg-image {
	position: absolute;
	top: -100px;
	left: 0;
	right: 0;
	bottom: -100px;
	background-size: cover;
	background-position: center;
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes float {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-20px); }
}

.animate-float {
	animation: float 6s ease-in-out infinite;
}

.animate-float-delayed {
	animation: float 6s ease-in-out 3s infinite;
}

/* ==========================================================================
   Work Items Animation
   ========================================================================== */

.work-item {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.work-item.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* ==========================================================================
   Links & Buttons
   ========================================================================== */

a {
	color: var(--msc-amber-700);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:hover {
	color: var(--msc-amber-600);
}

button {
	font-family: inherit;
	cursor: pointer;
}

/* ==========================================================================
   Screen Reader Text
   ========================================================================== */

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

/* ==========================================================================
   Prose Typography
   ========================================================================== */

.prose p { margin-bottom: 1.5em; }
.prose h2 { margin-top: 2em; margin-bottom: 1em; font-size: 1.5em; }
.prose h3 { margin-top: 1.5em; margin-bottom: 0.75em; font-size: 1.25em; }
.prose ul, .prose ol { margin: 1.5em 0; padding-left: 1.5em; }
.prose li { margin: 0.5em 0; }

.prose blockquote {
	border-left: 3px solid var(--msc-amber-600);
	padding-left: 1.5em;
	margin: 2em 0;
	font-style: italic;
	color: var(--msc-stone-600);
}

/* ==========================================================================
   Forms
   ========================================================================== */

input:focus,
textarea:focus,
select:focus {
	outline: none;
	border-color: var(--msc-amber-600);
}

/* ==========================================================================
   WordPress Alignments
   ========================================================================== */

.alignleft { float: left; margin-right: 1.5em; margin-bottom: 1em; }
.alignright { float: right; margin-left: 1.5em; margin-bottom: 1em; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }

/* ==========================================================================
   WooCommerce
   ========================================================================== */

.woocommerce .price { color: var(--msc-stone-900); font-weight: 500; }
.woocommerce .price del { color: var(--msc-stone-400); }
.woocommerce .price ins { text-decoration: none; color: var(--msc-amber-700); }
.woocommerce .onsale { background-color: var(--msc-amber-600); color: white; }

/* ==========================================================================
   Utilities
   ========================================================================== */

::selection {
	background: #fde68a;
	color: var(--msc-stone-900);
}

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--msc-cream-100); }
::-webkit-scrollbar-thumb { background: var(--msc-stone-400); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--msc-stone-500); }

/* ==========================================================================
   Contact Form 7 Styling
   ========================================================================== */

.wpcf7 {
	margin: 0;
}

.wpcf7 form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.wpcf7 form p {
	margin: 0;
}

.wpcf7 form label {
	display: block;
	font-size: 0.875rem;
	color: var(--msc-stone-600);
	margin-bottom: 0.5rem;
}

.wpcf7 form input[type="text"],
.wpcf7 form input[type="email"],
.wpcf7 form input[type="tel"],
.wpcf7 form input[type="url"],
.wpcf7 form textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	background-color: #fafaf9;
	border: 1px solid var(--msc-stone-200);
	color: var(--msc-stone-900);
	font-family: inherit;
	font-size: 1rem;
	transition: border-color 0.2s ease;
}

.wpcf7 form input[type="text"]:focus,
.wpcf7 form input[type="email"]:focus,
.wpcf7 form input[type="tel"]:focus,
.wpcf7 form input[type="url"]:focus,
.wpcf7 form textarea:focus {
	outline: none;
	border-color: var(--msc-amber-500);
}

.wpcf7 form textarea {
	min-height: 100px;
	max-height: 120px;
	height: 100px;
	resize: vertical;
}

.wpcf7 form input[type="submit"] {
	width: 100%;
	padding: 1rem 2rem;
	background-color: var(--msc-stone-900);
	color: var(--msc-cream-50);
	border: none;
	font-weight: 500;
	font-size: 1rem;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.wpcf7 form input[type="submit"]:hover {
	background-color: var(--msc-amber-700);
}

.wpcf7 .wpcf7-response-output {
	margin: 1rem 0 0 0;
	padding: 1rem;
	border: none;
	font-size: 0.875rem;
}

.wpcf7 .wpcf7-mail-sent-ok {
	background-color: #d1fae5;
	color: #065f46;
}

.wpcf7 .wpcf7-validation-errors,
.wpcf7 .wpcf7-spam-blocked {
	background-color: #fee2e2;
	color: #991b1b;
}

.wpcf7 .wpcf7-not-valid-tip {
	color: #dc2626;
	font-size: 0.75rem;
	margin-top: 0.25rem;
}

.wpcf7 .wpcf7-spinner {
	margin-left: 1rem;
}

/* ==========================================================================
   Legal Pages Typography (prose-legal)
   ========================================================================== */

.prose-legal {
	color: var(--msc-stone-700);
	line-height: 1.8;
}

/* Hide duplicate H1 from block content - the template already has H1 */
.prose-legal h1,
.prose-legal .wp-block-heading h1 {
	display: none;
}

/* Headings */
.prose-legal h2,
.prose-legal .wp-block-heading h2 {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-size: 1.75rem;
	font-weight: 600;
	color: var(--msc-stone-900);
	margin-top: 2.5rem;
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--msc-stone-200);
	position: relative;
}

.prose-legal h2::before,
.prose-legal .wp-block-heading h2::before {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 3rem;
	height: 2px;
	background: var(--msc-amber-600);
}

.prose-legal h3,
.prose-legal .wp-block-heading h3 {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-size: 1.35rem;
	font-weight: 600;
	color: var(--msc-stone-800);
	margin-top: 2rem;
	margin-bottom: 0.75rem;
}

/* Paragraphs */
.prose-legal p {
	margin-bottom: 1.25rem;
	text-align: left;
}

.prose-legal p:last-child {
	margin-bottom: 0;
}

/* Strong and emphasis */
.prose-legal strong {
	color: var(--msc-stone-900);
	font-weight: 600;
}

.prose-legal em {
	font-style: italic;
	color: var(--msc-stone-600);
}

/* Links */
.prose-legal a {
	color: var(--msc-amber-700);
	text-decoration: underline;
	text-decoration-color: var(--msc-amber-600);
	text-underline-offset: 2px;
	transition: all 0.2s ease;
}

.prose-legal a:hover {
	color: var(--msc-amber-600);
	text-decoration-color: var(--msc-amber-500);
}

/* Horizontal rules / Separators */
.prose-legal hr,
.prose-legal .wp-block-separator {
	border: none;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent 0%,
		var(--msc-stone-300) 15%,
		var(--msc-stone-300) 85%,
		transparent 100%
	);
	margin: 2.5rem 0;
	position: relative;
}

.prose-legal hr::before,
.prose-legal .wp-block-separator::before {
	content: '◆';
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background: var(--msc-cream-50);
	padding: 0 1rem;
	color: var(--msc-amber-600);
	font-size: 0.625rem;
}

/* Lists */
.prose-legal ul,
.prose-legal ol {
	margin: 1.5rem 0;
	padding-left: 1.5rem;
}

.prose-legal ul {
	list-style-type: none;
}

.prose-legal ul li {
	position: relative;
	padding-left: 1.25rem;
	margin-bottom: 0.5rem;
}

.prose-legal ul li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.7em;
	width: 6px;
	height: 6px;
	background: var(--msc-amber-600);
	border-radius: 50%;
}

.prose-legal ol {
	list-style-type: decimal;
}

.prose-legal ol li {
	margin-bottom: 0.5rem;
	padding-left: 0.25rem;
}

.prose-legal ol li::marker {
	color: var(--msc-amber-700);
	font-weight: 600;
}

/* Blockquotes */
.prose-legal blockquote {
	border-left: 3px solid var(--msc-amber-600);
	padding: 1rem 1.5rem;
	margin: 2rem 0;
	background: linear-gradient(135deg, var(--msc-cream-100) 0%, transparent 100%);
	font-style: italic;
	color: var(--msc-stone-600);
}

.prose-legal blockquote p:last-child {
	margin-bottom: 0;
}

/* Tables */
.prose-legal table {
	width: 100%;
	border-collapse: collapse;
	margin: 2rem 0;
	font-size: 0.9375rem;
}

.prose-legal table th,
.prose-legal table td {
	padding: 0.75rem 1rem;
	text-align: left;
	border-bottom: 1px solid var(--msc-stone-200);
}

.prose-legal table th {
	background: var(--msc-stone-100);
	font-weight: 600;
	color: var(--msc-stone-900);
}

.prose-legal table tr:hover td {
	background: var(--msc-cream-100);
}

/* Contact information styling */
.prose-legal strong:has(+ strong),
.prose-legal p > strong:first-child {
	display: inline;
}

/* Make email and phone links more visible */
.prose-legal a[href^="mailto:"],
.prose-legal a[href^="tel:"] {
	background: linear-gradient(135deg, rgba(217, 119, 6, 0.1) 0%, transparent 100%);
	padding: 0.125rem 0.375rem;
	border-radius: 0.25rem;
}

/* WordPress block specific styles */
.prose-legal .wp-block-group {
	margin: 1.5rem 0;
}

.prose-legal .wp-block-columns {
	margin: 2rem 0;
}

.prose-legal .has-text-align-center {
	text-align: center;
}

/* First paragraph after heading - slightly larger */
.prose-legal h2 + p,
.prose-legal h3 + p {
	font-size: 1.0625rem;
}

/* Responsive adjustments */
@media (max-width: 640px) {
	.prose-legal h2,
	.prose-legal .wp-block-heading h2 {
		font-size: 1.5rem;
	}

	.prose-legal h3,
	.prose-legal .wp-block-heading h3 {
		font-size: 1.25rem;
	}

	.prose-legal hr::before,
	.prose-legal .wp-block-separator::before {
		font-size: 0.5rem;
	}
}

/* ==========================================================================
   WPML Language Switcher
   ========================================================================== */

.msc-lang-switcher {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
}

/* Reset WPML default styles */
.msc-lang-switcher .wpml-ls,
.msc-lang-switcher .wpml-ls-statics-shortcode_actions {
	border: none !important;
	background: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.msc-lang-switcher .wpml-ls-item {
	display: inline-flex;
	align-items: center;
}

.msc-lang-switcher .wpml-ls-link {
	text-decoration: none !important;
	transition: all 0.2s ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.msc-lang-switcher .wpml-ls-native,
.msc-lang-switcher .wpml-ls-display {
	font-size: inherit;
	font-weight: inherit;
	letter-spacing: inherit;
}

/* Show flag icons */
.msc-lang-switcher .wpml-ls-flag {
	display: inline-block !important;
	width: 20px !important;
	height: 15px !important;
	margin: 0 !important;
	border-radius: 2px;
	overflow: hidden;
}

/* Header Style - Just flag clickable */
.msc-lang-switcher--header .wpml-ls-item {
	display: none;
}

.msc-lang-switcher--header .wpml-ls-item:not(.wpml-ls-current-language) {
	display: inline-flex;
}

.msc-lang-switcher--header .wpml-ls-link {
	display: inline-block;
	line-height: 0;
	transition: opacity 0.2s ease;
}

.msc-lang-switcher--header .wpml-ls-link:hover {
	opacity: 0.7;
}

.msc-lang-switcher--header .wpml-ls-flag {
	display: block !important;
	border: none !important;
	border-radius: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	vertical-align: top !important;
}

/* Footer Style with flags */
.msc-lang-switcher--footer .wpml-ls-item:not(:last-child)::after {
	content: '|';
	margin: 0 0.5rem;
	color: rgba(120, 113, 108, 0.5);
}

.msc-lang-switcher--footer .wpml-ls-link {
	font-size: 0.875rem;
	color: #a8a29e;
}

.msc-lang-switcher--footer .wpml-ls-link:hover {
	color: #f59e0b;
}

.msc-lang-switcher--footer .wpml-ls-current-language .wpml-ls-link {
	color: #fbbf24;
	font-weight: 500;
}

/* Mobile Menu Style */
.msc-lang-switcher--mobile .wpml-ls-item {
	width: 100%;
}

.msc-lang-switcher--mobile .wpml-ls-link {
	padding: 0.75rem 1rem;
	width: 100%;
	background: rgba(41, 37, 36, 0.5);
	border: 1px solid rgba(68, 64, 60, 0.5);
	font-size: 0.875rem;
	color: rgba(255, 254, 251, 0.9);
	transition: all 0.2s ease;
}

.msc-lang-switcher--mobile .wpml-ls-link:hover {
	background: rgba(68, 64, 60, 0.5);
	border-color: rgba(245, 158, 11, 0.5);
	color: #fbbf24;
}

.msc-lang-switcher--mobile .wpml-ls-current-language {
	display: none;
}

/* Dropdown style reset (if WPML outputs dropdown) */
.msc-lang-switcher .wpml-ls-sub-menu,
.msc-lang-switcher .wpml-ls-slot-shortcode_actions {
	position: static !important;
	display: flex !important;
	visibility: visible !important;
	opacity: 1 !important;
	background: none !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
	list-style: none !important;
}

.msc-lang-switcher ul {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	gap: 0.5rem !important;
}

.msc-lang-switcher--mobile ul {
	flex-direction: column !important;
	width: 100%;
}

/* ==========================================================================
   Print
   ========================================================================== */

@media print {
	.site-header, .site-footer, #back-to-top, #side-cart, #cart-overlay { display: none !important; }
	body { background: white; color: black; }
}
