body,
input[type=text],
input[type=email],
input[type=url],
input[type=password],
textarea,
.portfolio_title_desc {
    font-family: "Varela Round", Helvetica, Arial, sans-serif;
}

body {
    font-size: 15px;
}

h1,
h2,
h3,
h4,
h5,
h6,
h7,
.post_quote_title,
label,
strong[itemprop="author"],
#page_content_wrapper .posts.blog li a,
.page_content_wrapper .posts.blog li a,
.post_info_cat,
.readmore,
.post_info_comment,
#post_featured_slider li .slider_image .slide_post .slide_post_date,
.post_featured_slider li .slider_image .slide_post .slide_post_date,
blockquote,
.ppb_subtitle,
.comment_date,
.post_attribute,
.post_header_title,
.post_header.grid,
.odometer,
.pricing_wrapper li.price_row em.exact_price {
    font-family: Karla, Helvetica, Arial, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
h7,
.post_info_cat,
.comment_date,
.post_attribute {
    font-weight: 400;
}

h1,
h2,
h3,
h4,
h5,
h6,
h7,
blockquote,
body.single .post_header.grid.related {
    letter-spacing: 0px;
}

h1,
h2,
h3,
h4,
h5,
h6,
h7 {
    text-transform: none;
}

h1 {
    font-size: 34px;
}

h2 {
    font-size: 30px;
}

h3 {
    font-size: 26px;
}

h4 {
    font-size: 22px;
}

h5 {
    font-size: 18px;
}

h6 {
    font-size: 16px;
}

body,
#wrapper,
#page_content_wrapper.fixed,
#gallery_lightbox h2,
.slider_wrapper .gallery_image_caption h2,
#body_loading_screen,
h3#reply-title span,
.overlay_gallery_wrapper,
.progress_bar_holder,
.pricing_wrapper_border,
.pagination a,
.pagination span,
blockquote:before {
    background-color: #ffffff;
}

body,
.pagination a,
#gallery_lightbox h2,
.slider_wrapper .gallery_image_caption h2,
.post_info a,
#page_content_wrapper.split #copyright,
.page_content_wrapper.split #copyright,
.ui-state-default a,
.ui-state-default a:link,
.ui-state-default a:visited {
    color: #7c6443;
}

::selection {
    background-color: #d2c1b5;
}

::-webkit-input-placeholder {
    color: #d2c1b5;
}

::-moz-placeholder {
    color: #d2c1b5;
}

:-ms-input-placeholder {
    color: #d2c1b5;
}

a {
    color: #918b82;
}

a:hover,
a:active,
.post_info_comment a i {
    color: #999999;
}

h1,
h2,
h3,
h4,
h5,
h6,
h7,
pre,
code,
tt,
blockquote,
.post_header h5 a,
.post_header h3 a,
.post_header.grid h6 a,
.post_header.fullwidth h4 a,
.post_header h5 a,
blockquote,
.site_loading_logo_item i,
.woocommerce .woocommerce-ordering select,
.woocommerce #page_content_wrapper a.button,
.woocommerce.columns-4 ul.products li.product a.add_to_cart_button,
.woocommerce.columns-4 ul.products li.product a.add_to_cart_button:hover,
.ui-accordion .ui-accordion-header a,
.tabs .ui-state-active a,
body.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
body.woocommerce-page div.product .woocommerce-tabs ul.tabs li.active a,
body.woocommerce #content div.product .woocommerce-tabs ul.tabs li.active a,
body.woocommerce-page #content div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a,
.post_header h5 a,
.post_header h6 a,
blockquote:before {
    color: #222222;
}

body.page.page-template-gallery-archive-split-screen-php #fp-nav li .active span,
body.tax-gallerycat #fp-nav li .active span,
body.page.page-template-portfolio-fullscreen-split-screen-php #fp-nav li .active span,
body.page.tax-portfolioset #fp-nav li .active span,
body.page.page-template-gallery-archive-split-screen-php #fp-nav ul li a span,
body.tax-gallerycat #fp-nav ul li a span,
body.page.page-template-portfolio-fullscreen-split-screen-php #fp-nav ul li a span,
body.page.tax-portfolioset #fp-nav ul li a span {
    background-color: #222222;
}

#social_share_wrapper,
hr,
#social_share_wrapper,
.post.type-post,
#page_content_wrapper .sidebar .content .sidebar_widget li h2.widgettitle,
h2.widgettitle,
h5.widgettitle,
.comment .right,
.widget_tag_cloud div a,
.meta-tags a,
.tag_cloud a,
#footer,
#post_more_wrapper,
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price,
#page_content_wrapper .inner .sidebar_content,
#page_content_wrapper .inner .sidebar_content.left_sidebar,
.ajax_close,
.ajax_next,
.ajax_prev,
.portfolio_next,
.portfolio_prev,
.portfolio_next_prev_wrapper.video .portfolio_prev,
.portfolio_next_prev_wrapper.video .portfolio_next,
.separated,
.blog_next_prev_wrapper,
#post_more_wrapper h5,
#ajax_portfolio_wrapper.hidding,
#ajax_portfolio_wrapper.visible,
.tabs.vertical .ui-tabs-panel,
.woocommerce div.product .woocommerce-tabs ul.tabs li,
.woocommerce #content div.product .woocommerce-tabs ul.tabs li,
.woocommerce-page div.product .woocommerce-tabs ul.tabs li,
.woocommerce-page #content div.product .woocommerce-tabs ul.tabs li,
.woocommerce div.product .woocommerce-tabs .panel,
.woocommerce-page div.product .woocommerce-tabs .panel,
.woocommerce #content div.product .woocommerce-tabs .panel,
.woocommerce-page #content div.product .woocommerce-tabs .panel,
.woocommerce table.shop_table,
.woocommerce-page table.shop_table,
table tr td,
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals,
.woocommerce .cart-collaterals .shipping_calculator,
.woocommerce-page .cart-collaterals .shipping_calculator,
.woocommerce .cart-collaterals .cart_totals tr td,
.woocommerce .cart-collaterals .cart_totals tr th,
.woocommerce-page .cart-collaterals .cart_totals tr td,
.woocommerce-page .cart-collaterals .cart_totals tr th,
table tr th,
.woocommerce #payment,
.woocommerce-page #payment,
.woocommerce #payment ul.payment_methods li,
.woocommerce-page #payment ul.payment_methods li,
.woocommerce #payment div.form-row,
.woocommerce-page #payment div.form-row,
.ui-tabs li:first-child,
.ui-tabs .ui-tabs-nav li,
.ui-tabs.vertical .ui-tabs-nav li,
.ui-tabs.vertical.right .ui-tabs-nav li.ui-state-active,
.ui-tabs.vertical .ui-tabs-nav li:last-child,
#page_content_wrapper .inner .sidebar_wrapper ul.sidebar_widget li.widget_nav_menu ul.menu li.current-menu-item a,
.page_content_wrapper .inner .sidebar_wrapper ul.sidebar_widget li.widget_nav_menu ul.menu li.current-menu-item a,
.pricing_wrapper,
.pricing_wrapper li,
.ui-accordion .ui-accordion-header,
.ui-accordion .ui-accordion-content,
#page_content_wrapper .sidebar .content .sidebar_widget li h2.widgettitle:before,
h2.widgettitle:before,
#autocomplete,
.ppb_blog_minimal .one_third_bg,
#page_content_wrapper .sidebar .content .sidebar_widget li h2.widgettitle,
h2.widgettitle,
h5.event_title,
.tabs .ui-tabs-panel,
.ui-tabs .ui-tabs-nav li,
.ui-tabs li:first-child,
.ui-tabs.vertical .ui-tabs-nav li:last-child,
.woocommerce .woocommerce-ordering select,
.woocommerce div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce-page div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce #content div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce-page #content div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce-page table.cart th,
table.shop_table thead tr th,
hr.title_break,
.overlay_gallery_border,
#page_content_wrapper.split #copyright,
.page_content_wrapper.split #copyright,
.post.type-post,
.events.type-events,
h5.event_title,
.post_header h5.event_title,
blockquote:after,
#about_the_author,
.two_cols.gallery.wide .element,
.three_cols.gallery.wide .element,
.four_cols.gallery.wide .element {
    border-color: #e1e1e1;
}

input[type=text],
input[type=password],
input[type=email],
input[type=url],
input[type=tel],
textarea {
    background-color: #ffffff;
    color: #222222;
    border-color: #e1e1e1;
}

input[type=text]:focus,
input[type=password]:focus,
input[type=email]:focus,
input[type=url]:focus,
textarea:focus {
    border-color: #999999;
}

input[type=submit],
input[type=button],
a.button,
.button,
.woocommerce .page_slider a.button,
a.button.fullwidth,
.woocommerce-page div.product form.cart .button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
    font-family: Karla, Helvetica, Arial, sans-serif;
}

input[type=submit],
input[type=button],
a.button,
.button,
.pagination span,
.pagination a:hover,
.woocommerce .footer_bar .button,
.woocommerce .footer_bar .button:hover,
.woocommerce-page div.product form.cart .button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.post_type_icon {
    background-color: #959595;
}

.pagination span,
.pagination a:hover,
.button.ghost,
.button.ghost:hover,
.button.ghost:active {
    border-color: #959595;
}

.button.ghost,
.button.ghost:hover,
.button.ghost:active {
    color: #959595;
}

input[type=submit],
input[type=button],
a.button,
.button,
.pagination a:hover,
.woocommerce .footer_bar .button,
.woocommerce .footer_bar .button:hover,
.woocommerce-page div.product form.cart .button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.post_type_icon {
    color: #ffffff;
}

input[type=submit],
input[type=button],
a.button,
.button,
.pagination a:hover,
.woocommerce .footer_bar .button,
.woocommerce .footer_bar .button:hover,
.woocommerce-page div.product form.cart .button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
    border-color: #959595;
}

.frame_top,
.frame_bottom,
.frame_left,
.frame_right {
    background: #ffffff;
}

#menu_wrapper .nav ul li a,
#menu_wrapper div .nav li > a,
.sicky_nav li a {
    font-family: Karla, Helvetica, Arial, sans-serif;
    font-size: 14px;
    padding-top: 22px;
    padding-bottom: 22px;
    font-weight: 600;
    letter-spacing: 0px;
    text-transform: none;
}

#menu_wrapper .nav ul li a,
#menu_wrapper div .nav li > a,
.header_cart_wrapper a,
#page_share {
    color: #222222;
}

#mobile_nav_icon {
    border-color: #222222;
}

#menu_wrapper .nav ul li a.hover,
#menu_wrapper .nav ul li a:hover,
#menu_wrapper div .nav li a.hover,
#menu_wrapper div .nav li a:hover,
.header_cart_wrapper a:hover,
#page_share:hover {
    color: #222222;
}

#menu_wrapper .nav ul li a.hover,
#menu_wrapper .nav ul li a:hover,
#menu_wrapper div .nav li a.hover,
#menu_wrapper div .nav li a:hover {
    border-color: #222222;
}

#menu_wrapper div .nav > li.current-menu-item > a,
#menu_wrapper div .nav > li.current-menu-parent > a,
#menu_wrapper div .nav > li.current-menu-ancestor > a,
#menu_wrapper div .nav li ul li.current-menu-item a,
#menu_wrapper div .nav li.current-menu-parent ul li.current-menu-item a,
.header_cart_wrapper a:active,
#page_share:active {
    color: #222222;
}

#menu_wrapper div .nav > li.current-menu-item > a,
#menu_wrapper div .nav > li.current-menu-parent > a,
#menu_wrapper div .nav > li.current-menu-ancestor > a,
#menu_wrapper div .nav li ul li.current-menu-item a,
#menu_wrapper div .nav li.current-menu-parent ul li.current-menu-item a {
    border-color: #222222;
}

.top_bar,
#page_caption,
#nav_wrapper {
    border-color: #ffffff;
}

.top_bar {
    background-color: #ffffff;
}

#menu_wrapper .nav ul li ul li a,
#menu_wrapper div .nav li ul li a,
#menu_wrapper div .nav li.current-menu-parent ul li a {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0px;
    text-transform: none;
}

#menu_wrapper .nav ul li ul li a,
#menu_wrapper div .nav li ul li a,
#menu_wrapper div .nav li.current-menu-parent ul li a,
#menu_wrapper div .nav li.current-menu-parent ul li.current-menu-item a,
#menu_wrapper .nav ul li.megamenu ul li ul li a,
#menu_wrapper div .nav li.megamenu ul li ul li a {
    color: #d2c1b5;
}

#menu_wrapper .nav ul li ul li a:hover,
#menu_wrapper div .nav li ul li a:hover,
#menu_wrapper div .nav li.current-menu-parent ul li a:hover,
#menu_wrapper .nav ul li.megamenu ul li ul li a:hover,
#menu_wrapper div .nav li.megamenu ul li ul li a:hover,
#menu_wrapper .nav ul li.megamenu ul li ul li a:active,
#menu_wrapper div .nav li.megamenu ul li ul li a:active,
#menu_wrapper div .nav li.current-menu-parent ul li.current-menu-item a:hover {
    color: #222222;
}

#menu_wrapper .nav ul li ul li a:hover,
#menu_wrapper div .nav li ul li a:hover,
#menu_wrapper div .nav li.current-menu-parent ul li a:hover,
#menu_wrapper .nav ul li.megamenu ul li ul li a:hover,
#menu_wrapper div .nav li.megamenu ul li ul li a:hover,
#menu_wrapper .nav ul li.megamenu ul li ul li a:active,
#menu_wrapper div .nav li.megamenu ul li ul li a:active {
    background: #f9f9f9;
}

#menu_wrapper .nav ul li ul,
#menu_wrapper div .nav li ul {
    background: #f9f9f9;
    border-color: #e1e1e1;
}

#menu_wrapper div .nav li.megamenu ul li > a,
#menu_wrapper div .nav li.megamenu ul li > a:hover,
#menu_wrapper div .nav li.megamenu ul li > a:active,
#menu_wrapper div .nav li.megamenu ul li.current-menu-item > a {
    color: #222222;
}

#menu_wrapper div .nav li.megamenu ul li {
    border-color: #e1e1e1;
}

.above_top_bar {
    background: #222222;
    font-family: Karla, Helvetica, Arial, sans-serif;
}

#top_menu li a,
.top_contact_info,
.top_contact_info i,
.top_contact_info a,
.top_contact_info a:hover,
.top_contact_info a:active {
    color: #ffffff;
}

.top_contact_info,
#top_menu li a {
    font-weight: 400;
}

.mobile_menu_wrapper #searchform input[type=text] {
    background: #ffffff;
    border-color: #d2c1b5;
}

.mobile_menu_wrapper #searchform input[type=text],
.mobile_menu_wrapper #searchform button i {
    color: #d2c1b5;
}

.mobile_menu_wrapper #searchform::-webkit-input-placeholder {
    color: #d2c1b5;
}

.mobile_menu_wrapper #searchform::-moz-placeholder {
    color: #d2c1b5;
}

.mobile_menu_wrapper #searchform:-ms-input-placeholder {
    color: #d2c1b5;
}

.mobile_menu_wrapper {
    background-color: #7c6443;
}

.mobile_main_nav li a,
#sub_menu li a {
    font-family: Karla, Helvetica, Arial, sans-serif;
    font-size: 26px;
    line-height: 3em;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0px;
}

.mobile_main_nav li a,
#sub_menu li a,
.mobile_menu_wrapper .sidebar_wrapper a,
.mobile_menu_wrapper .sidebar_wrapper,
#close_mobile_menu i,
.fullmenu_wrapper a,
.fullmenu_wrapper h2.widgettitle,
.mobile_menu_wrapper #copyright {
    color: #ffffff;
}

.mobile_main_nav li a:hover,
.mobile_main_nav li a:active,
#sub_menu li a:hover,
#sub_menu li a:active,
.mobile_menu_wrapper .sidebar_wrapper h2.widgettitle {
    color: #ffffff;
}

#page_caption {
    background-color: #ffffff;
    padding-top: 80px;
    padding-bottom: 50px;
}

#page_caption h1,
.ppb_title {
    font-size: 40px;
}

#page_caption h1,
.ppb_title,
.post_caption h1 {
    font-weight: 400;
    line-height: 1.4em;
    text-transform: none;
    letter-spacing: 0px;
    color: #222222;
}

#page_caption.hasbg h1,
h1.hasbg {
    font-size: 22px;
}

#page_caption.hasbg {
    height: 100vh;
}

h2.ppb_title {
    font-size: 40px;
    text-transform: none;
}

#portfolio_wall_filters.alignright,
.portfolio_wall_filters.alignright {
    bottom: 40px;
}

.ppb_subtitle {
    font-size: 11px;
}

.page_tagline,
.post_header .post_detail,
.recent_post_detail,
.post_detail,
.thumb_content span,
.portfolio_desc .portfolio_excerpt,
.testimonial_customer_position,
.testimonial_customer_company {
    color: #222222;
    font-size: 13px;
    letter-spacing: 0px;
    text-transform: none;
}

.page_tagline {
    font-weight: 400;
}

#page_content_wrapper .sidebar .content .sidebar_widget li h2.widgettitle,
h2.widgettitle,
h5.widgettitle {
    font-family: Karla, Helvetica, Arial, sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #222222;
}

#page_content_wrapper .inner .sidebar_wrapper .sidebar .content,
.page_content_wrapper .inner .sidebar_wrapper .sidebar .content {
    color: #222222;
}

#page_content_wrapper .inner .sidebar_wrapper a,
.page_content_wrapper .inner .sidebar_wrapper a {
    color: #222222;
}

#page_content_wrapper .inner .sidebar_wrapper a:hover,
#page_content_wrapper .inner .sidebar_wrapper a:active,
.page_content_wrapper .inner .sidebar_wrapper a:hover,
.page_content_wrapper .inner .sidebar_wrapper a:active {
    color: #999999;
}

.footer_bar {
    background-color: #f9f9f9;
}

#footer,
#copyright,
#footer_menu li a {
    color: #d2c1b5;
}

#copyright a,
#copyright a:active,
#footer a,
#footer a:active {
    color: #222222;
}

#copyright a:hover,
#footer a:hover,
.social_wrapper ul li a:hover {
    color: #222222;
}

.footer_bar_wrapper,
.footer_bar {
    border-color: #ffffff;
}

.footer_bar_wrapper .social_wrapper ul li a {
    color: #222222;
}

#footer .sidebar_widget li h2.widgettitle {
    color: #222222;
}

#page_content_wrapper .inner .sidebar_content.full_width.blog_f {
    width: 80%;
}

.post_info_cat,
.post_info_cat a {
    color: #999999;
}

.post_header h3,
.post_header h4,
.post_header h5,
.post_header h6,
.post_header h3,
.post_header h4,
.post_header h5,
.post_header h6,
#post_featured_slider li .slider_image .slide_post h2,
.post_featured_slider li .slider_image .slide_post h2,
#post_featured_slider li .slider_image.three_cols .slide_post h2,
.post_featured_slider li .slider_image.three_cols .slide_post h2,
body.single .post_header.grid.related strong,
body.single-post .post_caption h1,
#page_content_wrapper .posts.blog li a {
    text-transform: none;
}

.post_header h5 {
    font-size: 32px;
}

.sidebar_content.full_width.blog_f .post_header h5 {
    font-size: 32px;
}

#blog_grid_wrapper.two_cols .post_header.grid h6,
.blog_grid_wrapper.two_cols .post_header.grid h6 {
    font-size: 22px;
}

.post_header.grid h6 {
    font-size: 20px;
}

.post_caption h1,
#page_caption.hasbg .background_center_title_wrapper .title_content h1 {
    font-size: 34px;
}

h6.subtitle {
    font-size: 26px;
}

body.single .post_header.grid.related {
    font-size: 15px;
}



/* =========================
   Plot & Plan - Sourcing Cards
   ========================= */

.pp-sourcing {
  padding: 60px 0 30px;
}

.pp-sourcing__head {
  max-width: 820px;
  margin: 0 auto 18px;
  text-align: left;
}

.pp-sourcing__title {
  margin: 0 0 6px;
  font-family: Karla, Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-size: 22px;
  letter-spacing: 0.2px;
}

.pp-sourcing__subtitle {
  margin: 0;
  opacity: 0.7;
  font-size: 14px;
  line-height: 1.6;
}

.pp-cardstrip {
  display: flex;
  gap: 16px;
  align-items: flex-end;
  overflow-x: auto;
  padding: 18px 4px 10px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.pp-cardstrip::-webkit-scrollbar {
  height: 10px;
}
.pp-cardstrip::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.12);
  border-radius: 999px;
}

.pp-card {
  position: relative;
  flex: 0 0 auto;
  width: 280px;
  height: 360px;
  border-radius: 18px;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  overflow: hidden;
  cursor: pointer;
  scroll-snap-align: start;

  /* calm editorial feel */
  filter: saturate(0.92) contrast(0.98);
  transform: translateY(0) scale(0.98);
  transition: transform 260ms ease, box-shadow 260ms ease, filter 260ms ease;
  box-shadow: 0 18px 40px rgba(0,0,0,0.12);
}

.pp-card.is-active,
.pp-card:hover {
  transform: translateY(-10px) scale(1.02);
  filter: saturate(0.98) contrast(1);
  z-index: 3;
}

.pp-card__shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.55),
    rgba(0,0,0,0.10) 55%,
    rgba(0,0,0,0.00)
  );
  opacity: 0.95;
  transition: opacity 260ms ease;
}

.pp-card__text {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 14px;
  color: rgba(255,255,255,0.92);
  transform: translateY(8px);
  transition: transform 260ms ease, opacity 260ms ease;
}

.pp-card.is-active .pp-card__text,
.pp-card:hover .pp-card__text {
  transform: translateY(0);
}

.pp-card__kicker {
  font-family: "Varela Round", Helvetica, Arial, sans-serif;
  font-size: 12px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  opacity: 0.85;
  margin-bottom: 6px;
}

.pp-card__headline {
  font-family: Karla, Helvetica, Arial, sans-serif;
  font-size: 18px;
  font-weight: 400;
  margin-bottom: 6px;
}

.pp-card__desc {
  font-size: 13px;
  line-height: 1.55;
  opacity: 0.88;
}

/* Make cards slightly smaller on very small screens */
@media (max-width: 640px) {
  .pp-card { width: 240px; height: 320px; }
}


/* ================================
   OPTION 2: SOURCING STORY STRIP
   Tight squares + pop-out hover
================================== */

.pp-sourcing-strip{
  padding: 80px 0;
}

.pp-sourcing-head{
  text-align: center;
  max-width: 920px;
  margin: 0 auto 38px auto;
}

.pp-sourcing-head h3{
  margin-bottom: 10px;
  letter-spacing: .02em;
}

.pp-sourcing-head p{
  margin: 0;
  opacity: .75;
}

/* Brand tint used on hover overlay */
.pp-sourcing-strip{
  --pp-brown: #6b4a2d;   /* <-- replace with Plot & Plan brand brown */
  --tile-size: 210px;    /* square size; tweak for your layout */
}

/* Row = tight squares, zero gap */
.pp-tile-row{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;                 /* NO GAP */
  margin: 0 auto;
  width: fit-content;     /* keeps strip compact */
  overflow: visible;      /* allows pop-out */
  position: relative;
}

/* Each tile is a perfect square */
.pp-tile{
  width: var(--tile-size);
  aspect-ratio: 1 / 1;
  position: relative;
  overflow: hidden;
  border-radius: 0;       /* match reference: square edges */
  background: #e9e9e9;
  transform: translateZ(0);
  transition: transform .28s cubic-bezier(.2,.8,.2,1),
              box-shadow .28s cubic-bezier(.2,.8,.2,1),
              filter .28s cubic-bezier(.2,.8,.2,1);
  box-shadow: none;
  z-index: 1;
  cursor: default;
}

/* Make them visually "touch" even if there are subpixel issues */
.pp-tile + .pp-tile{
  margin-left: 0;
}

/* Image fills tile */
.pp-tile img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .35s ease, filter .35s ease;
}

/* Overlay text (hidden until hover) */
.pp-tile-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px 18px 16px 18px;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.55),
    rgba(0,0,0,.18),
    rgba(0,0,0,0)
  );
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .25s ease, transform .25s ease, background .25s ease;
}

.pp-tile-title{
  color: #fff;
  font-size: 16px;
  line-height: 1.15;
  letter-spacing: .02em;
}

.pp-tile-sub{
  color: rgba(255,255,255,.82);
  font-size: 13px;
  margin-top: 6px;
  line-height: 1.2;
}

/* HERO tile sits popped-out by default like the reference */
.pp-tile.is-hero{
  z-index: 3;
  transform: translateY(-12px) scale(1.12);
  box-shadow:
    0 28px 60px rgba(0,0,0,.35),
    0 10px 18px rgba(0,0,0,.18);
}

/* Show overlay slightly on hero even when not hovering */
.pp-tile.is-hero .pp-tile-overlay{
  opacity: .9;
  transform: translateY(0);
  background: linear-gradient(
    to top,
    color-mix(in srgb, var(--pp-brown) 65%, rgba(0,0,0,.65)),
    rgba(0,0,0,.18),
    rgba(0,0,0,0)
  );
}

/* Hover pop-out effect (the main “3D” feel) */
.pp-tile:hover{
  z-index: 6;
  transform: translateY(-18px) scale(1.18);
  box-shadow:
    0 36px 75px rgba(0,0,0,.40),
    0 12px 22px rgba(0,0,0,.18);
}

/* Slightly calm the image + add brand tint mood */
.pp-tile:hover img{
  transform: scale(1.06);
  filter: saturate(.95) contrast(.98);
}

.pp-tile:hover .pp-tile-overlay{
  opacity: 1;
  transform: translateY(0);
  background: linear-gradient(
    to top,
    color-mix(in srgb, var(--pp-brown) 70%, rgba(0,0,0,.65)),
    rgba(0,0,0,.18),
    rgba(0,0,0,0)
  );
}

/* Optional: make non-hover tiles slightly recede when someone hovers the row */
.pp-tile-row:hover .pp-tile:not(:hover){
  filter: saturate(.95) brightness(.98);
}

/* Responsive: reduce tile size on smaller screens */
@media (max-width: 1100px){
  .pp-sourcing-strip{ --tile-size: 180px; }
}
@media (max-width: 900px){
  .pp-sourcing-strip{ --tile-size: 150px; }
  .pp-tile-row{ flex-wrap: wrap; } /* if needed */
}


/* ======================================
   MOBILE SLIDER BEHAVIOUR
====================================== */

@media (max-width: 900px){

  .pp-tile-slider{
    position: relative;
    width: 100%;
    overflow: hidden;
  }

  .pp-tile-row{
    display: flex;
    flex-wrap: nowrap !important;   /* prevent wrapping */
    overflow-x: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    gap: 0;
    padding: 10px 0 30px 0;
  }

  .pp-tile-row::-webkit-scrollbar{
    display: none;   /* hide scrollbar */
  }

  .pp-tile{
    flex: 0 0 75%;   /* width of each tile on mobile */
    margin-right: 12px;
  }

  /* Arrow buttons */
  .pp-slider-btn{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: none;
    background: rgba(0,0,0,0.5);
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .pp-prev{ left: 6px; }
  .pp-next{ right: 6px; }

}


/* =========================
   Plot & Plan - WhatsApp Widget
   ========================= */

:root{
  --pp-wa-green: #25D366;
  --pp-wa-shadow: 0 18px 40px rgba(0,0,0,.16);
  --pp-wa-shadow-strong: 0 28px 70px rgba(0,0,0,.22);
  --pp-wa-text: #222;
  --pp-wa-muted: rgba(0,0,0,.65);
  --pp-wa-brown: #6b4a2d; /* change to your brand brown if needed */
}

.pp-wa{
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 9999;
  display: grid;
  gap: 10px;
  justify-items: end;
  pointer-events: none; /* enables bubble layout; button re-enables */
}

.pp-wa__btn{
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  background: var(--pp-wa-green);
  color: #fff;
  text-decoration: none;
  box-shadow: var(--pp-wa-shadow-strong);
  transform: translateZ(0);
  transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

.pp-wa__btn:hover{
  transform: translateY(-2px);
  filter: saturate(1.02);
  box-shadow: 0 34px 85px rgba(0,0,0,.28);
}

.pp-wa__icon{ width: 20px; height: 20px; fill: #fff; }

.pp-wa__label{
  font-family: Karla, Helvetica, Arial, sans-serif;
  font-size: 13px;
  letter-spacing: .02em;
}

.pp-wa__bubble{
  pointer-events: auto;
  width: min(320px, calc(100vw - 44px));
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  padding: 14px 14px 12px 14px;
  box-shadow: var(--pp-wa-shadow);
  position: relative;
  overflow: hidden;
}

.pp-wa__bubble::after{
  content:"";
  position:absolute;
  right: 18px;
  bottom: -8px;
  width: 16px;
  height: 16px;
  background:#fff;
  border-right: 1px solid rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(0,0,0,.08);
  transform: rotate(45deg);
}

.pp-wa__kicker{
  font-family: "Varela Round", Helvetica, Arial, sans-serif;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--pp-wa-brown);
  margin-bottom: 6px;
}

.pp-wa__msg{
  font-family: Karla, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.45;
  color: var(--pp-wa-text);
  padding-right: 18px;
}

.pp-wa__close{
  position:absolute;
  top: 8px;
  right: 10px;
  width: 28px;
  height: 28px;
  border: 0;
  background: transparent;
  color: rgba(0,0,0,.45);
  font-size: 20px;
  cursor: pointer;
  line-height: 1;
}

.pp-wa__close:hover{ color: rgba(0,0,0,.7); }

/* Mobile tuning */
@media (max-width: 640px){
  .pp-wa{ right: 14px; bottom: 14px; }
  .pp-wa__label{ display:none; } /* icon-only on mobile */
  .pp-wa__btn{ padding: 12px; }
}


/* =========================
   About Us - OUR PROCESS
   ========================= */

.pp-process { padding-top: 0 !important; }

.pp-process__wrap{
  max-width: 920px;
  margin: 0 auto;
}

.pp-process__eyebrow{
  font-family: "Varela Round", Helvetica, Arial, sans-serif;
  font-size: 14px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: #6b4a2d; /* Plot & Plan brown (adjust if needed) */
  margin-bottom: 8px;
}

.pp-process__sub{
  margin: 0 0 18px 0;
  opacity: .75;
  font-size: 14px;
  line-height: 1.6;
}

.pp-process__steps{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.pp-process__step{
  font-family: Karla, Helvetica, Arial, sans-serif;
  font-size: 14px;
  color: #222;
  padding: 10px 14px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 999px;
  background: #fff;
}

.pp-process__arrow{
  opacity: .35;
  font-size: 16px;
}

/* Mobile: keep it clean and readable */
@media (max-width: 640px){
  .pp-process__steps{ gap: 10px; }
  .pp-process__arrow{ display:none; } /* avoids crowded arrows */
  .pp-process__step{ width: 100%; max-width: 320px; }
}






.pp-parallax-hero{
  position: relative;
  min-height: 320px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* ✅ parallax */
  background-attachment: fixed;
}

.pp-parallax-overlay{
  position:absolute; inset:0;
  background: rgba(0,0,0,0.38);
  pointer-events:none;
}

.pp-parallax-content{
  position: relative;
  color:#fff;
  max-width: 980px;
  padding: 70px 0;
}

.pp-eyebrow{
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  opacity: .85;
  margin-bottom: 10px;
}



#page_maximize i,
#page_minimize i {
  color: #6b4a2d;
  opacity: 0.7;
  transition: all 0.3s ease;
}

#page_maximize:hover i,
#page_minimize:hover i {
  opacity: 1;
  transform: scale(1.1);
}


.logo_wrapper{
    line-height:10px !important;
}



/* =========================================
   PLOT & PLAN — MATERIAL SOURCING STRIP
   Clean final version
   Desktop: 4 visible cards
   Mobile: 1 card at a time
========================================= */

/* Prevent accidental horizontal page scroll */
html,
body{
  overflow-x: hidden;
}

/* Main section */
.pp-sourcing-strip{
  padding: 50px 0 70px !important;
  overflow: hidden;
  background: #fff;
}

/* Heading */
.pp-sourcing-head{
  text-align: center;
  max-width: 920px;
  margin: 0 auto 42px auto !important;
  padding: 0 20px;
}

.pp-sourcing-head h3{
  font-size: 32px;
  line-height: 1.25;
  margin: 0 0 12px 0;
  letter-spacing: .02em;
  color: #222;
}

.pp-sourcing-head p{
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: #7c6443;
  opacity: .9;
}

/* Slider wrapper */
.pp-tile-slider{
  position: relative;
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  padding: 24px 115px !important; /* space reserved for arrows */
  overflow: hidden;
  box-sizing: border-box;
}

/* Tile row */
.pp-tile-row{
  display: flex;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
  align-items: stretch;
  width: 100%;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  scroll-behavior: smooth;
}

/* Desktop: exactly 4 visible boxes */
.pp-tile{
  position: relative;
  flex: 0 0 25% !important;
  width: 25% !important;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #eee;
  cursor: default;
  z-index: 1;
  box-shadow: none;
  transition:
    transform .28s cubic-bezier(.2,.8,.2,1),
    box-shadow .28s cubic-bezier(.2,.8,.2,1),
    filter .28s ease;
}

/* Images */
.pp-tile img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .35s ease, filter .35s ease;
}

/* Overlay */
.pp-tile-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px;
  opacity: 0;
  transform: translateY(10px);
  background: linear-gradient(
    to top,
    rgba(107,74,45,.78),
    rgba(0,0,0,.22),
    rgba(0,0,0,0)
  );
  transition: opacity .25s ease, transform .25s ease;
}

.pp-tile-title{
  color: #fff;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: .02em;
}

.pp-tile-sub{
  color: rgba(255,255,255,.84);
  font-size: 13px;
  line-height: 1.25;
  margin-top: 6px;
}

/* Hover pop-out */
.pp-tile:hover{
  z-index: 8;
  transform: translateY(-18px) scale(1.08);
  box-shadow:
    0 38px 80px rgba(0,0,0,.28),
    0 14px 24px rgba(0,0,0,.16);
}

.pp-tile:hover img{
  transform: scale(1.06);
  filter: saturate(.95) contrast(.98);
}

.pp-tile:hover .pp-tile-overlay{
  opacity: 1;
  transform: translateY(0);
}

/* Arrows */
.pp-slider-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(124,100,67,.22);
  background: rgba(255,255,255,.94);
  color: #7c6443;
  cursor: pointer;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 18px 45px rgba(0,0,0,.12);
  transition: all .25s ease;
  font-size: 0; /* hides raw arrow character */
}

.pp-slider-btn::before{
  font-family: FontAwesome;
  font-size: 20px;
  line-height: 1;
}

.pp-prev::before{
  content: "\f104";
}

.pp-next::before{
  content: "\f105";
}

.pp-prev{
  left: 34px !important;
}

.pp-next{
  right: 34px !important;
}

.pp-slider-btn:hover{
  background: #7c6443;
  color: #fff;
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 24px 55px rgba(0,0,0,.18);
}

/* Tablet: 3 visible cards */
@media (max-width: 1100px){
  .pp-tile-slider{
    padding: 22px 78px !important;
  }

  .pp-tile{
    flex: 0 0 33.3333% !important;
    width: 33.3333% !important;
  }

  .pp-prev{
    left: 18px !important;
  }

  .pp-next{
    right: 18px !important;
  }
}

/* Mobile: 1 card at a time */
@media (max-width: 768px){
  .pp-sourcing-strip{
    padding: 38px 0 52px !important;
  }

  .pp-sourcing-head{
    margin-bottom: 26px !important;
  }

  .pp-sourcing-head h3{
    font-size: 25px;
  }

  .pp-sourcing-head p{
    font-size: 14px;
  }

  .pp-tile-slider{
    padding: 12px 52px 24px !important;
    overflow: hidden;
  }

  .pp-tile-row{
    overflow-x: auto !important;
    overflow-y: visible !important;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .pp-tile-row::-webkit-scrollbar{
    display: none;
  }

  .pp-tile{
    flex: 0 0 100% !important;
    width: 100% !important;
    scroll-snap-align: center;
  }

  .pp-tile:hover{
    transform: none;
    box-shadow: none;
  }

  .pp-slider-btn{
    width: 40px;
    height: 40px;
  }

  .pp-prev{
    left: 8px !important;
  }

  .pp-next{
    right: 8px !important;
  }
}

/* Small mobile */
@media (max-width: 480px){
  .pp-tile-slider{
    padding-left: 46px !important;
    padding-right: 46px !important;
  }

  .pp-slider-btn{
    width: 38px;
    height: 38px;
  }
}


/* ===================================
PLOT & PLAN - PROCESS SECTION 2026
=================================== */

.pp-process-modern{

display:flex;
justify-content:center;
align-items:stretch;
gap:30px;

position:relative;

max-width:1400px;
margin:auto;

padding-top:60px;

flex-wrap:nowrap;

}

.pp-process-line{

position:absolute;

top:110px;
left:10%;

width:80%;
height:1px;

background:

linear-gradient(
to right,
transparent,
rgba(124,100,67,.2),
transparent
);

z-index:0;

}

.pp-process-card{

position:relative;

background:

rgba(255,255,255,.75);

backdrop-filter:blur(16px);

padding:40px 30px;

width:280px;

border-radius:24px;

border:

1px solid rgba(
124,
100,
67,
0.08
);

box-shadow:

0 15px 50px rgba(0,0,0,.06);

transition:.45s;

z-index:2;

text-align:left;

overflow:hidden;

}

.pp-process-card:hover{

transform:

translateY(-12px);

box-shadow:

0 30px 70px rgba(0,0,0,.12);

}

.pp-step-number{

position:absolute;

right:25px;
top:20px;

font-size:58px;

font-weight:700;

opacity:.06;

color:#7c6443;

}

.pp-process-card h4{

font-size:22px;

margin-bottom:14px;

color:#222;

}

.pp-process-card p{

font-size:14px;

line-height:1.7;

opacity:.7;

margin:0;

}

.pp-process-card::before{

content:"";

position:absolute;

top:0;
left:0;

height:4px;

width:100%;

background:#7c6443;

transform:scaleX(0);

transform-origin:left;

transition:.45s;

}

.pp-process-card:hover::before{

transform:scaleX(1);

}



/* ========= MOBILE ========= */

@media(max-width:991px){

.pp-process-modern{

flex-direction:column;

padding-top:20px;

gap:25px;

}

.pp-process-line{

display:none;

}

.pp-process-card{

width:100%;

max-width:450px;

margin:auto;

}

.pp-process-card::after{

content:"↓";

position:absolute;

bottom:-20px;

left:50%;

transform:translateX(-50%);

font-size:24px;

color:#d2c1b5;

}

.pp-process-card:last-child::after{

display:none;

}

}


/* Aura Regent gallery responsive fix */
.portfolio_filter_wrapper.gallery.four_cols.contain{
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  height: auto !important;
  overflow: visible !important;
}

.portfolio_filter_wrapper.gallery.four_cols.contain .element.grid,
.portfolio_filter_wrapper.gallery.four_cols.contain .one_fourth{
  position: relative !important;
  left: auto !important;
  top: auto !important;
  width: 100% !important;
  height: auto !important;
  float: none !important;
  transform: none !important;
  margin: 0 !important;
}

.portfolio_filter_wrapper.gallery.four_cols.contain img{
  width: 100% !important;
  height: auto !important;
  display: block;
}

/* Tablet */
@media (max-width: 1024px){
  .portfolio_filter_wrapper.gallery.four_cols.contain{
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Mobile */
@media (max-width: 767px){
  .portfolio_filter_wrapper.gallery.four_cols.contain{
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}

/* Small mobile */
@media (max-width: 480px){
  .portfolio_filter_wrapper.gallery.four_cols.contain{
    grid-template-columns: 1fr;
  }
}


/* ==========================
FOUNDERS HOVER EFFECT
========================== */

.founder-card{

overflow:hidden;
position:relative;

}

.founder-card .image_wrapper{

position:relative;
overflow:hidden;

}

.founder-card img{

display:block;
width:100%;
transition:all .6s ease;

}

/* overlay */

.founder-overlay{

position:absolute;

top:0;
left:0;

width:100%;
height:100%;

display:flex;

justify-content:center;
align-items:center;

background:rgba(124,100,67,.65);

opacity:0;

transition:.5s ease;

backdrop-filter:blur(3px);

}

/* hover effect */

.founder-card:hover .founder-overlay{

opacity:1;

}

.founder-card:hover img{

transform:scale(1.05);

}

/* linkedin */

.founder-link{

display:flex;

flex-direction:column;

align-items:center;

text-decoration:none !important;

color:#fff !important;

transform:translateY(20px);

transition:.4s;

}

.founder-card:hover .founder-link{

transform:translateY(0);

}

.founder-link i{

font-size:24px;   /* smaller icon */
margin-bottom:18px; /* more breathing space */

}

.founder-link span{

font-size:15px;
letter-spacing:.5px;
text-transform:none; /* sentence case */
font-weight:400;

}

/* mobile */

@media(max-width:768px){

/* Mobile */
@media(max-width:768px){

/* Keep hidden initially */
.founder-overlay{

opacity:0;
background:rgba(124,100,67,.60);

}

/* Trigger on tap */
.founder-card:active .founder-overlay{

opacity:1;

}

.founder-card:active .founder-link{

transform:translateY(0);

}

.founder-link i{

font-size:22px;

}

.founder-link span{

font-size:13px;

}

}

.success-message{
    background:#f5f1ea;
    border:1px solid #d7c7b2;
    color:#7c6443;
    padding:15px 20px;
    margin-bottom:30px;
    border-radius:4px;
    font-size:14px;
    line-height:1.6;
}