/* Beauty Shop Rio Plugin - Core Styles */

:root {
    --bsr-mint: #C4D7D0;
    --bsr-cream: #F2F2F2;
    --bsr-white: #FFFFFF;
    --bsr-gray-light: #F2F2F2;
    --bsr-gray-medium: #F2F2F2;
    --bsr-gray-dark: #666666;
    --bsr-text-dark: #12263A;
    --bsr-accent: #06BCC1;
    --bsr-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    --bsr-radius: 12px;
    --bsr-radius-sm: 8px;
}

/* Reset and Base Styles */
.bsr-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Typography */
.bsr-hero h1{
    font-family: 'Vintage';
    font-weight: 100;
    color: var(--bsr-text-dark);
    margin-bottom: 1rem;
}
.bsr-values h2,
.bsr-categories h2,
.bsr-newsletter h2 {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 300;
    color: var(--bsr-text-dark);
    margin-bottom: 1.5rem;
}

/* Common Button Styles */
.bsr-nav-btn {
    background: var(--bsr-white);
    border: none;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    font-size: 1.2rem;
    cursor: pointer;
    box-shadow: var(--bsr-shadow);
    transition: all 0.3s ease;
    color: var(--bsr-text-dark);
}

.bsr-nav-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(0, 0, 0, 0.12);
}

/* Common Form Styles */
.bsr-email-input {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid var(--bsr-gray-medium);
    border-radius: var(--bsr-radius-sm);
    font-size: 0.95rem;
    background: var(--bsr-white);
    transition: all 0.3s ease;
}

.bsr-email-input:focus {
    outline: none;
    border-color: var(--bsr-accent);
    box-shadow: 0 0 0 3px rgba(78, 205, 196, 0.1);
}

.bsr-submit-btn {
    background: var(--bsr-accent);
    color: var(--bsr-white);
    border: none;
    padding: 12px 24px;
    border-radius: var(--bsr-radius-sm);
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.bsr-submit-btn:hover {
    background: #45B8B0;
    transform: translateY(-1px);
}

/* Common Price Styles */
.bsr-old-price {
    text-decoration: line-through;
    color: var(--bsr-gray-dark);
    font-size: 0.9rem;
}

.bsr-price-current,
.bsr-current-price {
    background: var(--bsr-gray-light);
    padding: 4px 12px;
    border-radius: var(--bsr-radius-sm);
    font-weight: 600;
    color: var(--bsr-text-dark);
}

/* Common Link Styles */
.bsr-shop-btn {
    display: inline-block;
    background: var(--bsr-white);
    color: var(--bsr-text-dark);
    padding: 12px 24px;
    border-radius: 25px;
    text-decoration: none;
    font-weight: 500;
    box-shadow: var(--bsr-shadow);
    transition: all 0.3s ease;
}

.bsr-shop-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(0, 0, 0, 0.12);
    text-decoration: none;
    color: var(--bsr-text-dark);
}

/* Common Botanical Elements */
.bsr-leaf,
.bsr-lavender {
    position: absolute;
    opacity: 0.6;
}

.bsr-leaf-1,
.bsr-leaf-2,
.bsr-leaf-left,
.bsr-leaf-right,
.bsr-leaf-tl,
.bsr-leaf-tr,
.bsr-leaf-footer {
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%234A5D23"><path d="M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z"/></svg>') no-repeat center;
    background-size: contain;
}

/* Responsive Base Styles */
@media (max-width: 1024px) {
    .bsr-container {
        padding: 0 30px;
    }
}

@media (max-width: 768px) {
    .bsr-container {
        padding: 0 20px;
    }
}

@media (max-width: 480px) {
    .bsr-container {
        padding: 0 15px;
    }
    
    .bsr-nav-btn {
        width: 40px;
        height: 40px;
        font-size: 1rem;
    }
}

/*Overrides*/
.ast-theme-transparent-header #masthead .site-logo-img .transparent-custom-logo img{
    max-width: 50px !important;
}
.ast-logo-title-inline .ast-site-identity{
    padding: 0px !important;
}

@media (max-width: 544px) {
    .ast-desktop .ast-primary-header-bar.main-header-bar, .ast-header-break-point #masthead .ast-primary-header-bar.main-header-bar {
        padding-left: 0px;
        padding-right: 0px;
    }
}

.ast-theme-transparent-header.ast-header-break-point #ast-mobile-header > .ast-main-header-wrap > .main-header-bar{
    margin-top: 10px !important;
}

/* ===== Beauty Shop Rio – Instagram feed polish ===== */
/* Scope to this section only */
.uagb-block-903e8ae4{
    background: #B8D4C7 !important;
}
.uagb-block-903e8ae4 #sb_instagram{
  --gap: 16px;
  --radius: var(--bsr-radius, 12px);
  --shadow: var(--bsr-shadow, 0 4px 20px rgba(0,0,0,.08));
  --mint: var(--bsr-mint, #B8D4C7);
  --cream: var(--bsr-cream, #F5F1E8);
  --text: var(--bsr-text-dark, #2D2D2D);
  --accent: var(--bsr-accent, #06BCC1);
}

/* Section spacing */
.uagb-block-903e8ae4 .uagb-container-inner-blocks-wrap{
  padding-inline: clamp(12px, 3vw, 24px);
}

/* Title line */
.uagb-block-903e8ae4 .uagb-heading-text{
  letter-spacing: .02em;
  color: var(--text);
}
.uagb-block-903e8ae4 .uagb-heading-text a{
  color: var(--accent);
  text-decoration: none;
}
.uagb-block-903e8ae4 .uagb-heading-text a:hover{
  text-decoration: underline;
}

/* Header (avatar + bio) */
.uagb-block-903e8ae4 #sb_instagram .sb_instagram_header{
  background: #F2F2F2;
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow);
  margin-bottom: 18px;
}
.uagb-block-903e8ae4 #sb_instagram .sbi_header_text{
  display: flex;
  align-items: center;
  gap: 14px;
}
.uagb-block-903e8ae4 #sb_instagram .sbi_header_img{
  width: 56px; height: 56px; border-radius: 50%; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.uagb-block-903e8ae4 #sb_instagram .sbi_feedtheme_header_text h3{
  margin: 0; font-size: 18px; color: var(--text); font-weight: 700;
}
.uagb-block-903e8ae4 #sb_instagram .sbi_bio{
  margin: 2px 0 0; font-size: 13px; line-height: 1.4; color: #666;
}

/* Grid – force neat gaps and square cards */
.uagb-block-903e8ae4 #sbi_images{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--gap) !important;
}
@media (max-width: 1024px){
  .uagb-block-903e8ae4 #sbi_images{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px){
  .uagb-block-903e8ae4 #sbi_images{ grid-template-columns: 1fr; }
}

/* Cards */
.uagb-block-903e8ae4 #sb_instagram .sbi_item .sbi_photo_wrap{
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  background: var(--bsr-white, #fff);
  position: relative;
}
.uagb-block-903e8ae4 #sb_instagram a.sbi_photo{
  display: block;
  aspect-ratio: 1 / 1;              /* keep squares clean */
  width: 100%; height: auto;
  transition: transform .35s ease, filter .35s ease;
  will-change: transform;
}
.uagb-block-903e8ae4 #sb_instagram a.sbi_photo img{
  width: 100%; height: 100%; object-fit: cover;
}

/* Hover lift */
.uagb-block-903e8ae4 #sb_instagram .sbi_item:hover .sbi_photo{
  transform: scale(1.03);
  filter: saturate(1.03);
}

/* Reel/Video play button – nicer contrast */
.uagb-block-903e8ae4 #sb_instagram .sbi_playbtn{
  width: 52px; height: 52px;
  padding: 12px;
  border-radius: 50%;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(2px);
  position: absolute; inset: auto 12px 12px auto;
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
}

/* “Load more” + “Follow” buttons */
.uagb-block-903e8ae4 #sb_instagram #sbi_load{
  display: flex; gap: 10px; align-items: center; justify-content: center;
  margin-top: 18px;
}
.uagb-block-903e8ae4 #sb_instagram .sbi_load_btn,
.uagb-block-903e8ae4 #sb_instagram .sbi_follow_btn a{
  border: none;
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 600;
  font-size: 14px;
  box-shadow: var(--shadow);
  background: #F2F2F2 !important;
  color: #12263A !important;
  transition: transform .2s ease, opacity .2s ease;
}
.uagb-block-903e8ae4 #sb_instagram .sbi_follow_btn svg{ display:none; } /* keep it compact */
.uagb-block-903e8ae4 #sb_instagram .sbi_load_btn:hover,
.uagb-block-903e8ae4 #sb_instagram .sbi_follow_btn a:hover{
  transform: translateY(-1px);
  opacity: .95;
}

.sbi_follow_btn {
    display: none !important;
}

/* Tighter inner gap than plugin’s inline style */
.uagb-block-903e8ae4 #sb_instagram[sbi_width_resp] #sbi_images{ gap: var(--gap) !important; }

/* Reduce the plugin’s inline padding-bottom */
.uagb-block-903e8ae4 #sb_instagram{ padding-bottom: 0 !important; }

/* Accessibility: focus outlines on cards */
.uagb-block-903e8ae4 #sb_instagram a.sbi_photo:focus-visible{
  outline: 3px solid color-mix(in oklab, var(--accent) 60%, white);
  outline-offset: 3px;
  border-radius: calc(var(--radius) - 2px);
}