/* Hide control_toggle on mobile — it opens the desktop sidebar, non-functional on mobile */
@media (max-width: 760px) {
    .control_toggle { display: none !important; }
}

/* Mobile hero: portrait images fill from top so subject face shows */
@media (max-width: 760px) {
    .fs_slide { background-position: top center !important; }
}

/* Hero slider: autoplay only — hide all interactive controls */
.controls_wrapper,
.fs_thmb_viewport,
#scroll_hint {
    display: none !important;
}

/* ── Mobile footer (hidden on desktop where sidebar handles it) ── */
.mobile-footer {
    display: none;
}
@media (max-width: 760px) {
    .mobile-footer {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 18px 20px;
        background: #080808;
        border-top: 1px solid rgba(201,169,110,0.25);
        gap: 12px;
        position: relative;
        z-index: 10;
    }
    .mobile-footer__insta {
        display: flex;
        align-items: center;
        gap: 7px;
        color: #C9A96E;
        font-size: 11px;
        letter-spacing: 0.5px;
        text-decoration: none;
    }
    .mobile-footer__insta svg { flex-shrink: 0; }
    .mobile-footer__copy {
        font-size: 10px;
        color: rgba(255,255,255,0.35);
        letter-spacing: 0.3px;
        white-space: nowrap;
    }
}

/* ── Screen-reader only utility ── */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* ── Blog page header ── */
.blog-page-header {
    text-align: center;
    padding: 60px 20px 20px;
    max-width: 600px;
    margin: 0 auto;
}
.blog-page-header h1 {
    font-size: 28px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 8px;
}
.blog-page-header p {
    font-size: 13px;
    color: rgba(255,255,255,0.5);
    letter-spacing: 1px;
}

/* ── Global UX Baseline ── */
html { scroll-behavior: smooth; }


/* Cursor pointer on all interactive elements */
.gal-item, .pin_grid a, .shortcode_button,
a[href], nav a, .whatsapp-float,
.fs_thmb_list li, .control_toggle,
.filter_toggler, .optionset li a { cursor: pointer; }

/* Hover transitions on nav links */
nav a, .mobile_menu a {
    transition: color 0.2s ease, opacity 0.2s ease;
}
nav a:hover { opacity: 0.75; }

/* Visible focus rings for keyboard navigation */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid #C9A96E !important;
    outline-offset: 2px !important;
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    html { scroll-behavior: auto; }
    .gal-item img { transition: none !important; }
}

/* Template Options */

/*
	--//-- 1. Color Options --//--

	- Theme color - C9A96E (Luxury Gold; rgba - 201,169,110);
	- Header background color - 000000 (rgba - 0,0,0);
	- Header text color - ffffff;
	- Main menu text color - ffffff;
	- Sub-menu text color - ffffff;
	- Sub-menu border - 393b3b;
	- Body background color - ffffff;
	- Main text color - ffffff;
	- Heading color - ffffff;
	- Content block background color - 000000;
	- Footer copyright color - ffffff;
	
	--//-- 2. Fonts --//--
   
	- Content font - Roboto;
	- Main menu font - Roboto;
	- Headers - Muli;
	
*/
	
.main_header {
	background:rgba(0,0,0,0.85); /* Header background color */
}
.main_header:before {
	background: -moz-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,1))!important;
	background: -ms-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,1))!important;
	background: -o-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,1))!important;
	background: -webkit-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,1))!important; /* Header background color */
}
.main_header:after {
	background: -moz-linear-gradient(rgba(0,0,0,1), rgba(0,0,0,0))!important;
	background: -ms-linear-gradient(rgba(0,0,0,1), rgba(0,0,0,0))!important;
	background: -o-linear-gradient(rgba(0,0,0,1), rgba(0,0,0,0))!important;
	background: -webkit-linear-gradient(rgba(0,0,0,1), rgba(0,0,0,0))!important; /* Header background color */
}
.main_header nav ul.menu > li > a,
ul.mobile_menu > li > a,	
.filter_toggler {
	color:#ffffff; /* Main menu text color */
}
ul.mobile_menu li a {
	color:#ffffff!important; /* Main menu text color */
}
.main_header nav .sub-menu a {
	color:#ffffff; /* Sub-menu text color */
}
ul.mobile_menu .sub-menu a {
	color:#ffffff!important; /* Sub-menu text color */
}
ul.mobile_menu .sub-menu:before,
ul.mobile_menu ul.sub-menu li:before,
.main_header nav ul.menu .sub-menu:before,
.main_header nav ul.sub-menu li:before {
	background:#393b3b; /* Sub-menu border */
}
footer .copyright {
	color:#ffffff; /* Footer copyright color */
}
.site_wrapper {
	background:rgba(0,0,0,0.85); /* Content block background color */
}
h5.shortcode_accordion_item_title,
h5.shortcode_toggles_item_title,
h5.shortcode_accordion_item_title.state-active {
	color:#ffffff!important; /* Main text color */
}
body,
.preloader {
	background:#ffffff; /* Body background color */
}
p, td, div,
input {
	color:#F8F5EF; /* Body text — ivory */
	font-family:Roboto; /* Content font */
	font-weight:400;
}
.fs_descr {
	font-family:Roboto!important; /* Content font */
}
a:hover {
	color:#E6D0A8; /* Link hover — light gold */
	font-weight:400;
}

.main_header nav ul.menu li a,
.main_header nav ul.menu li span,
ul.mobile_menu li a,
ul.mobile_menu li span,
.filter_toggler {
	font-family: Roboto; /* Main menu font */
	font-size: 11px;
	line-height: 13px;
}

::selection {background:#C9A96E; /* Theme color */
}
::-moz-selection {background:#C9A96E; /* Theme color */
}

.main_header nav ul.sub-menu > li:hover > a,
.main_header nav ul.sub-menu > li.current-menu-item > a,
.main_header nav ul.sub-menu > li.current-menu-parent > a,
.mobile_menu > li.current-menu-item > a,
.mobile_menu > li.current-menu-parent > a,
a,
blockquote.shortcode_blockquote.type5:before,
.main_header nav ul.menu li:hover > a,
.main_header nav ul.menu li.current-menu-ancestor > a,
.main_header nav ul.menu li.current-menu-item > a,
.main_header nav ul.menu li.current-menu-parent > a,
ul.mobile_menu li.current-menu-ancestor > a span,
ul.mobile_menu li.current-menu-item > a span,
ul.mobile_menu li.current-menu-parent > a span,
.dropcap.type2,
.dropcap.type5,
.widget_nav_menu ul li a:hover,
.widget_archive ul li a:hover,
.widget_pages ul li a:hover,
.widget_categories ul li a:hover,
.widget_recent_entries ul li a:hover,
.widget_meta ul li a:hover,
.widget_posts .post_title:hover,
.shortcode_iconbox a:hover .iconbox_title,
.shortcode_iconbox a:hover .iconbox_body,
.shortcode_iconbox a:hover .iconbox_body p,
.shortcode_iconbox a:hover .ico i,
.price_item.most_popular h1,
.featured_items_title h5 a:hover,
.optionset li a:hover,
.portfolio_dscr_top h3 a:hover,
.portfolio_block h5 a:hover,
.blogpost_title a:hover,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
textarea:focus,
.author_name a:hover,
.header_filter .optionset li.selected a,
.filter_toggler:hover {	
	color:#C9A96E; /* Theme color */
}

input[type="text"]:focus::-webkit-input-placeholder,
input[type="email"]:focus::-webkit-input-placeholder,
input[type="password"]:focus::-webkit-input-placeholder,
textarea:focus::-webkit-input-placeholder {
	color:#C9A96E; /* Theme color */
	-webkit-font-smoothing: antialiased;
}

input[type="text"]:focus::-moz-placeholder,
input[type="email"]:focus::-moz-placeholder,
input[type="password"]:focus::-moz-placeholder,
textarea:focus::-moz-placeholder {
	color:#C9A96E; /* Theme color */
	opacity: 1;
	-moz-osx-font-smoothing: grayscale;
}

input[type="text"]:focus:-ms-input-placeholder,
input[type="email"]:focus:-ms-input-placeholder,
input[type="password"]:focus:-ms-input-placeholder,
textarea:focus:-ms-input-placeholder,
.widget_posts .post_title:hover {
	color:#C9A96E; /* Theme color */
}

h5.shortcode_accordion_item_title:hover,
h5.shortcode_accordion_item_title.state-active,
h5.shortcode_toggles_item_title:hover,
h5.shortcode_toggles_item_title.state-active {
	color:#C9A96E!important; /* Theme color */
}

.highlighted_colored,
.shortcode_button.btn_type5,
.shortcode_button.btn_type4:hover,
h5.shortcode_accordion_item_title:hover .ico,
h5.shortcode_toggles_item_title:hover .ico,
h5.shortcode_accordion_item_title.state-active .ico,
h5.shortcode_toggles_item_title.state-active .ico,
.box_date .box_month,
.preloader:after,
.price_item.most_popular .price_item_title,
.price_item.most_popular .price_item_btn a,
.price_item .price_item_btn a:hover,
.shortcode_button.btn_type1:hover	{
	background-color:#C9A96E; /* Theme color */
}
#mc_signup_submit:hover,
.shortcode_button.btn_type4:hover,
.load_more_works:hover,
.pp_wrapper input[type="submit"]:hover,
.search_button:hover {
	background-color:#C9A96E!important; /* Theme color */
}
blockquote.shortcode_blockquote.type5 .blockquote_wrapper,
.widget_tag_cloud a:hover,
.fs_blog_top,
.simple-post-top,
.widget_search .search_form,
.module_cont hr.type3,
blockquote.shortcode_blockquote.type2 {
	border-color:#C9A96E; /* Theme color */
}

/* Fonts Families and Sizes */
* {
	font-family:Roboto; /* Content font */
	font-weight:400;
}
p, td, div,
blockquote p,
input,	
input[type="text"],
input[type="email"],
input[type="password"],
textarea {
	font-size:12px;
	line-height:20px;
}
.main_header nav ul.menu > li > a,
ul.mobile_menu > li > a {
	font-size:11px;
	line-height: 13px;
}
.main_header nav ul.menu > li > a:before,
ul.mobile_menu > li > a:before {
	line-height: 13px;
}
h1, h2, h3, h4, h5, h6,
h1 span, h2 span, h3 span, h4 span, h5 span, h6 span,
h1 small, h2 small, h3 small, h4 small, h5 small, h6 small,
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
	font-family: Muli; /* Headers */
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased;
	padding:0;
	color:#ffffff; /* Heading color */
}
blockquote.shortcode_blockquote.type3:before,
blockquote.shortcode_blockquote.type4:before,
blockquote.shortcode_blockquote.type5:before,
.dropcap,
.shortcode_tab_item_title,
.shortcode_button,
input[type="button"], 
input[type="reset"], 
input[type="submit"],
a.shortcode_button,
.search404.search_form .search_button {
	font-family: Muli; /* Headers */
}
.sidebar_header {
	font-family: Muli; /* Headers */
}	
.load_more_works {
	font-family: Muli; /* Headers */
	color:#ffffff; /* Heading color */
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased;		
}
.box_date span,
.countdown-row .countdown-section:before,
.countdown-amount,
.countdown-period {
	font-family: Muli; /* Headers */
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased;		
}
.iconbox_header .ico i,
.title,
.comment-reply-link:before,
.ww_footer_right .blogpost_share span {
	color:#ffffff; /* Heading color */
}
a.shortcode_button,
.chart.easyPieChart,
.chart.easyPieChart span,
input[type="button"],
input[type="reset"],
input[type="submit"],
.search404 .search_button {
	font-family: Muli; /* Headers */
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased;		
}
h1, h2, h3, h4, h5, h6,
h1 span, h2 span, h3 span, h4 span, h5 span, h6 span,
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a,
h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover, h5 a:hover, h6 a:hover {
	font-weight:400;
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased;		
}

input[type="button"],
input[type="reset"],
input[type="submit"] {
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased; 		
}
h1, h1 span, h1 a {
	font-size:26px;
	line-height:28px;
}
h2, h2 span, h2 a {
	font-size:22px;
	line-height:24px;
}
h3, h3 span, h3 a {
	font-size:19px;
	line-height:21px;
}
h4, h4 span, h4 a, 
h3.comment-reply-title,
h3.comment-reply-title a {
	font-size:16px;
	line-height:18px;
}
h5, h5 span, h5 a {
	font-size:14px;
	line-height:16px;
}
h6, h6 span, h6 a,
.comment_info h6:after {
	font-size:13px;
	line-height:15px;
}
@media only screen and (max-width: 760px) {
	.fw_content_wrapper {
		background:#ffffff!important; /* Body background color */
	}
}

/* Logo Size */
.logo_def,
.logo_retina {
	width:190px;
	height:90px;
}

/* ── WhatsApp Floating Button ── */
.whatsapp-float {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background-color: #25d366;
    border-radius: 50%;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.4);
    z-index: 1000;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.whatsapp-float:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 20px rgba(0,0,0,0.5);
}
@media (max-width: 480px) {
    .whatsapp-float {
        width: 46px;
        height: 46px;
        bottom: 14px;
        right: 12px;
    }
}

/* ── About Page — Stat Counters ── */
.stat_counters_row {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 2%;
    padding: 40px 0 20px;
    text-align: center;
}
.stat_box {
    flex: 0 0 22%;
    min-width: 140px;
}
@media (max-width: 600px) {
    .stat_box {
        flex: 0 0 46%;
    }
}
.stat_box .stat-num {
    display: block;
    font-size: 42px;
    font-weight: 700;
    margin-bottom: 6px;
    color: #fff;
}
.stat_box p {
    font-size: 13px;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #CFC7BB;
    margin: 0;
}

/* ── About Page — Services List ── */
.services_block {
    padding: 30px 0 10px;
}
.services_block h3 {
    font-size: 16px;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 20px;
    color: #fff;
}
.services_list {
    list-style: none;
    padding: 0;
    margin: 0;
    columns: 2;
}
.services_list li {
    padding: 6px 0;
    font-size: 14px;
    color: #bbb;
    border-bottom: 1px solid #222;
}
.services_list li:before {
    content: "— ";
    color: #CFC7BB;
    font-family: inherit;
}

/* ── Contact Form Select ── */
.contact_form select {
    width: 100%;
    padding: 12px 15px;
    margin-bottom: 15px;
    background: #111114;
    border: 1px solid #333;
    color: #CFC7BB;
    font-size: 13px;
}

/* ── Contact Info Instagram Icon ── */
.contact_info_icon .ico_social_instagram {
    font-size: 18px;
}

/* ── Contact Page — Luxury Redesign ── */
.contact_bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    background: url('../img/hero/hero-2.jpg') center 20% / cover no-repeat;
}
.contact_bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(5,3,8,0.90) 0%, rgba(18,8,4,0.82) 100%);
}
body.contact-page .site_wrapper {
    background: rgba(8,5,12,0.70) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    border: 1px solid rgba(201,169,110,0.18) !important;
    box-shadow: 0 8px 60px rgba(0,0,0,0.55), inset 0 1px 0 rgba(200,169,110,0.12) !important;
}
body.contact-page h1 {
    font-size: 18px;
    letter-spacing: 6px;
    text-transform: uppercase;
    font-family: Muli, sans-serif;
    font-weight: 300;
    color: #fff;
    border-bottom: 1px solid rgba(201,169,110,0.35);
    padding-bottom: 22px;
    margin-bottom: 4px;
}
/* Inputs — bottom-border only, luxury minimal */
body.contact-page .contact_form input[type="text"],
body.contact-page .contact_form input[type="email"],
body.contact-page .contact_form input[type="tel"],
body.contact-page .contact_form select,
body.contact-page .contact_form textarea {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid rgba(201,169,110,0.35) !important;
    border-radius: 0 !important;
    color: #fff !important;
    padding: 13px 2px !important;
    font-size: 12px !important;
    letter-spacing: 1.5px !important;
    transition: border-color 0.3s !important;
    width: 100% !important;
    box-shadow: none !important;
}
body.contact-page .contact_form input[type="text"]:focus,
body.contact-page .contact_form input[type="email"]:focus,
body.contact-page .contact_form input[type="tel"]:focus,
body.contact-page .contact_form select:focus,
body.contact-page .contact_form textarea:focus {
    outline: none !important;
    border-bottom-color: #C9A96E !important;
}
body.contact-page .contact_form input::placeholder,
body.contact-page .contact_form textarea::placeholder {
    color: rgba(255,255,255,0.38) !important;
    letter-spacing: 3px !important;
    font-size: 10px !important;
    text-transform: uppercase !important;
}
body.contact-page .contact_form select {
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(201,169,110,0.6)'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 4px center !important;
}
body.contact-page .contact_form select option {
    background: #0d0a12;
    color: #fff;
}
body.contact-page .contact_form button[type="submit"] {
    background: linear-gradient(135deg, #C9A96E 0%, #a8893e 100%);
    border: none;
    color: #0d0a12;
    letter-spacing: 5px;
    font-size: 10px;
    text-transform: uppercase;
    padding: 16px 5px 16px 0;
    width: 100%;
    cursor: pointer;
    transition: opacity 0.3s, box-shadow 0.3s;
    border-radius: 0;
    margin-top: 22px;
    font-family: Muli, sans-serif;
    font-weight: 700;
    display: block;
    text-align: center;
    box-shadow: 0 4px 20px rgba(201,169,110,0.25);
    -webkit-appearance: none;
    outline: none;
}
body.contact-page .contact_form button[type="submit"]:hover {
    opacity: 0.88;
    box-shadow: 0 6px 28px rgba(201,169,110,0.4);
}
/* Contact info luxury */
body.contact-page .contact_info_list {
    padding-top: 10px;
}
body.contact-page .contact_info_item {
    border-bottom: 1px solid rgba(201,169,110,0.12);
    padding-bottom: 18px;
    margin-bottom: 18px;
}
body.contact-page .contact_info_icon i {
    color: #C9A96E !important;
}
body.contact-page .contact_info_text,
body.contact-page .contact_info_text a {
    color: rgba(255,255,255,0.75) !important;
    font-size: 12px !important;
    letter-spacing: 0.5px !important;
    transition: color 0.2s;
}
body.contact-page .contact_info_text a:hover {
    color: #C9A96E !important;
}
/* Success/error note */
body.contact-page #note p { font-size: 12px; letter-spacing: 1px; }

/* ── About Page — Video Background & Luxury Styling ── */
body.about-page,
body.about-page html {
    background: #07050a !important;
}
.about_video_bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}
.about_video_bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(5,3,8,0.48);
    pointer-events: none;
}
.about_video_bg video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.9;
    filter: brightness(0.52) saturate(0.72);
}
/* Glass card */
body.about-page .site_wrapper {
    background: rgba(6,3,9,0.55) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    border: 1px solid rgba(201,169,110,0.20) !important;
    box-shadow: 0 12px 70px rgba(0,0,0,0.45), inset 0 1px 0 rgba(200,169,110,0.12) !important;
    position: relative !important;
    z-index: 10 !important;
}
body.about-page .main_header {
    z-index: 20 !important;
}
/* Heading */
body.about-page .headInModule {
    font-size: 17px !important;
    letter-spacing: 5px !important;
    text-transform: uppercase !important;
    font-family: Muli, sans-serif !important;
    font-weight: 300 !important;
    color: #fff !important;
    border-bottom: 1px solid rgba(201,169,110,0.35) !important;
    padding-bottom: 16px !important;
}
/* Bio text */
body.about-page .module_content p {
    color: rgba(255,255,255,0.78) !important;
    font-size: 13px !important;
    line-height: 1.9 !important;
    letter-spacing: 0.3px !important;
}
/* Portrait image */
body.about-page .module_content img[alt] {
    border: 1px solid rgba(201,169,110,0.25);
    display: block;
}
/* CTA button */
body.about-page .shortcode_button.btn_type1 {
    background: transparent !important;
    border: 1px solid rgba(201,169,110,0.65) !important;
    color: #C9A96E !important;
    letter-spacing: 3px !important;
    font-size: 10px !important;
    padding: 13px 36px !important;
    border-radius: 0 !important;
    transition: background 0.3s, border-color 0.3s !important;
}
body.about-page .shortcode_button.btn_type1:hover {
    background: rgba(201,169,110,0.12) !important;
    border-color: #C9A96E !important;
}
/* Stats — gold numbers */
body.about-page .stat_box .stat-num {
    color: #C9A96E !important;
    font-size: 38px !important;
    font-weight: 300 !important;
    letter-spacing: 2px !important;
    margin-bottom: 6px !important;
}
body.about-page .stat_box p {
    color: rgba(255,255,255,0.55) !important;
    font-size: 9px !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
}
body.about-page .stat_counters_row {
    border-top: 1px solid rgba(201,169,110,0.2);
    border-bottom: 1px solid rgba(201,169,110,0.2);
    padding: 28px 0;
}
/* Services */
body.about-page .services_block h3 {
    color: #C9A96E !important;
    font-size: 10px !important;
    letter-spacing: 5px !important;
    text-transform: uppercase !important;
    font-weight: 400 !important;
    margin-bottom: 18px !important;
    font-family: Muli, sans-serif !important;
}
body.about-page .services_list li {
    color: rgba(255,255,255,0.72) !important;
    font-size: 12px !important;
    letter-spacing: 1.5px !important;
    padding: 8px 0 !important;
    border-bottom: 1px solid rgba(201,169,110,0.1) !important;
    list-style: none !important;
}
body.about-page .services_list li::before {
    content: '— ';
    color: rgba(201,169,110,0.5);
    margin-right: 6px;
}

/* ── Slider Thumbnails — perfect filled circles ── */
.fs_thmb_viewport {
    height: 72px !important;
    border-radius: 72px !important;
}
.fs_thmb_wrapper {
    height: 72px !important;
}
.fs_thmb_viewport .fs_thmb_list li {
    width: 72px !important;
    height: 72px !important;
    border: 2px solid rgba(255,255,255,0.3) !important;
    box-sizing: border-box !important;
    margin-right: 12px !important;
    opacity: 0.7 !important;
    transition: border-color 0.25s, opacity 0.25s !important;
}
.fs_thmb_viewport .fs_thmb_list li:hover,
.fs_thmb_viewport .fs_thmb_list li.current-slide {
    border-color: rgba(255,255,255,0.9) !important;
    opacity: 1 !important;
}
.fs_thmb_viewport .fs_thmb_list li img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center 20% !important;
}

/* ── Slide Video Overlay ── */
#slide-video-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 10;
    background: #000;
}
#slide-video-overlay video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ── Homepage — allow scroll below slider ── */
body.homepage {
    overflow-y: auto;
}


/* ── Pin Grid Section ── */
#pin_section {
    position: relative;
    z-index: 10;
    margin-top: 100vh;
    margin-left: 240px;
    background: #111114;
    padding: 64px 0 56px;
}
.pin_inner {
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 36px;
}
.pin_heading {
    text-align: center;
    margin-bottom: 40px;
}
.pin_heading h2 {
    font-size: 26px;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 12px;
    font-family: Muli, sans-serif;
}
.pin_heading p {
    font-size: 13px;
    color: #777;
    letter-spacing: 1px;
    margin: 0;
}
.pin_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}
.pin_grid a {
    display: block;
    overflow: hidden;
    position: relative;
}
.pin_grid a img {
    width: 100%;
    height: 340px;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
    filter: brightness(0.92);
}
.pin_grid a:hover img {
    transform: scale(1.05);
    filter: brightness(1);
}
.pin_cta {
    text-align: center;
    margin-top: 44px;
}
.pin_cta .shortcode_button {
    letter-spacing: 3px;
    font-size: 11px;
    padding: 14px 36px;
    text-transform: uppercase;
}
@media (max-width: 960px) {
    #pin_section { margin-left: 0; }
    #scroll_hint { left: 50%; }
}
@media (max-width: 720px) {
    .pin_grid { grid-template-columns: repeat(2, 1fr); }
    .pin_grid a img { height: 240px; }
}
@media (max-width: 480px) {
    .pin_grid { grid-template-columns: 1fr; }
    .pin_grid a img { height: 280px; }
}

/* Mobile Homepage — hide slider text/UI that scrolls awkwardly */
@media (max-width: 760px) {
    html.fullscreen .fs_title_wrapper,
    html.fullscreen .fs_title,
    html.fullscreen .fs_description_wrapper,
    html.fullscreen .fs_description,
    html.fullscreen .fs_bottom_controls,
    html.fullscreen .fs_thmb_viewport,
    html.fullscreen #fs_play-pause,
    html.fullscreen #scroll_hint {
        display: none !important;
    }
    body.homepage #pin_section {
        z-index: 200;
        position: relative;
    }
}

/* About — round portrait */
.portrait-circle {
    width: 260px !important;
    height: 260px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    object-position: center 8% !important;
    border: 3px solid rgba(200,169,110,0.55) !important;
    box-shadow: 0 0 0 8px rgba(200,169,110,0.08), 0 24px 64px rgba(0,0,0,0.5) !important;
    display: block !important;
    margin: 16px auto 28px !important;
}
@media (max-width: 760px) {
    .portrait-circle {
        width: 180px !important;
        height: 180px !important;
        margin: 10px auto 20px !important;
    }
}

/* About — services pill grid */
.services_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 18px;
}
.service-tag {
    padding: 13px 12px;
    border: 1px solid rgba(201,169,110,0.28);
    text-align: center;
    font-size: 10px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.72);
    font-family: Muli, sans-serif;
    font-weight: 400;
    transition: background 0.25s, border-color 0.25s, color 0.25s;
    cursor: default;
}
.service-tag:hover {
    background: rgba(201,169,110,0.08);
    border-color: rgba(201,169,110,0.7);
    color: #C9A96E;
}

/* ── About Page — Testimonials ── */
.testimonials_block {
    padding: 44px 0 10px;
}
.testimonials_block h3 {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 22px;
    letter-spacing: 0.02em;
    margin-bottom: 6px;
    color: #C9A96E;
    text-align: center;
}
.testimonials_sub {
    text-align: center;
    font-size: 12px;
    letter-spacing: 1px;
    color: #CFC7BB;
    margin: 0 0 26px;
}
.tm-stars {
    display: block;
    color: #C9A96E;
    font-size: 13px;
    letter-spacing: 3px;
    margin-bottom: 12px;
}
.testimonials_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}
@media (max-width: 600px) {
    .testimonials_grid { grid-template-columns: 1fr; }
}
.tm-card {
    position: relative;
    margin: 0;
    padding: 30px 26px 24px;
    border: 1px solid rgba(201,169,110,0.28);
    background: rgba(255,255,255,0.02);
}
.tm-card:before {
    content: "\201C";
    position: absolute;
    top: 8px;
    left: 18px;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 54px;
    line-height: 1;
    color: rgba(201,169,110,0.35);
    pointer-events: none;
}
.tm-quote {
    position: relative;
    font-size: 15px;
    line-height: 1.7;
    color: rgba(255,255,255,0.82);
    font-style: italic;
    margin: 0 0 18px;
}
.tm-attr {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.tm-name {
    font-size: 13px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #C9A96E;
    font-weight: 600;
}
.tm-place {
    font-size: 12px;
    letter-spacing: 1px;
    color: #CFC7BB;
}

/* Gallery — Editorial Bento Grid */
.gallery-editorial {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    width: 100%;
    background: #0B0B0D;
    box-sizing: border-box;
}
.gal-item {
    position: relative;
    overflow: hidden;
    display: block;
    text-decoration: none;
    background: #0B0B0D;
}
.gal-item img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94), filter 0.4s ease;
    filter: brightness(0.88) saturate(1.05);
}
.gal-item:hover img {
    transform: scale(1.04);
    filter: brightness(1.02) saturate(1.12);
}
.gal-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.08) 50%, transparent 80%);
    opacity: 0;
    transition: opacity 0.35s ease;
    display: flex;
    align-items: flex-end;
    padding: 22px;
}
.gal-item:hover .gal-overlay { opacity: 1; }
.gal-label {
    font-size: 9px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #C9A96E;
    font-family: Muli, sans-serif;
    border-bottom: 1px solid rgba(200,169,110,0.45);
    padding-bottom: 5px;
}
/* Grid positions no longer needed — all items flow naturally */
.gal-1, .gal-2, .gal-3, .gal-4, .gal-5, .gal-6 {
    grid-column: auto;
    grid-row: auto;
}
/* Tablet */
@media (max-width: 960px) {
    .gallery-editorial {
        grid-template-columns: repeat(2, 1fr);
        gap: 3px;
    }
}
/* Mobile */
@media (max-width: 600px) {
    .gallery-editorial {
        grid-template-columns: repeat(2, 1fr);
        gap: 2px;
    }
}

/* Hide fullscreen slider controls when pin section is in view */
html.slider-hidden .fs_title_wrapper,
html.slider-hidden .controls_wrapper,
html.slider-hidden .fs_thmb_viewport,
html.slider-hidden #slide-video-overlay,
html.slider-hidden #scroll_hint {
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity 0.3s ease !important;
}

/* Playfair Display — must be last to win cascade over theme Muli rules */
body h1, body h3,
body .headInModule,
body .bg_title h1,
body .blogpost_title a,
body .pin_heading h2,
body.contact-page h1,
body.about-page .headInModule {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em !important;
}
}

/* ════════════════════════════════════════════════════════════
   Brand Palette — Luxury Gold & Ivory
   ════════════════════════════════════════════════════════════ */
:root {
    --base: #0B0B0D;
    --gold: #C9A96E;
    --gold-light: #E6D0A8;
    --gold-accent: #D8B56A;
    --ivory: #F8F5EF;
    --text-secondary: #CFC7BB;
    --border: rgba(201,169,110,0.25);
    --section-bg: #111114;
    --footer-bg: #080808;
}

/* Active menu item → light gold */
.main_header nav ul.menu li.current-menu-item > a,
.main_header nav ul.menu li.current-menu-item > a span,
ul.mobile_menu li.current-menu-item > a span {
    color: #E6D0A8 !important;
}

/* Main headings → gold */
body .headInModule,
body .bg_title h1,
body .blogpost_title,
body .blogpost_title a,
body .pin_heading h2,
body .blog-page-header h1,
body.contact-page h1 {
    color: #C9A96E !important;
}

/* Primary solid buttons → gold background, dark text, accent-gold hover.
   (The About-page CTA keeps its refined gold-outline style.) */
body:not(.about-page) .shortcode_button {
    background-color: #C9A96E !important;
    color: #0B0B0D !important;
    border-color: #C9A96E !important;
}
body:not(.about-page) .shortcode_button:hover {
    background-color: #D8B56A !important;
    color: #0B0B0D !important;
    border-color: #D8B56A !important;
}
.contact_form button,
.contact_form input[type="submit"] {
    background-color: #C9A96E !important;
    color: #0B0B0D !important;
    border: none !important;
}
.contact_form button:hover,
.contact_form input[type="submit"]:hover {
    background-color: #D8B56A !important;
    color: #0B0B0D !important;
}