/** Shopify CDN: Minification failed

Line 179:0 Unexpected "}"

**/
/* ==========================================================================
   VIOLET'S CRAYON — BRAND DESIGN SYSTEM (FINAL v2.1)
   Minimalist, Stable CSS for Shopify Studio Theme.
   (Text colors are now managed exclusively by Shopify's Theme Settings.)
   ========================================================================= */

/* --------------------------------------------
   1. BRAND VARIABLES & UTILITIES
   Define your core colors here.
-------------------------------------------- */
:root {
    --vc-purple-dark: #7E57C2;  /* The main button/logo purple */
    --vc-purple-light: #E1BEE7; /* Lighter lavender for accents/stripes */
    --vc-text-dark: #3A2F4F;    /* Your charcoal text color (used for buttons/accents) */
    --vc-card-bg: #FFFFFF;
    --vc-border-radius: 12px;   /* Soft, friendly roundness */
    --vc-btn-radius: 50px;      /* pill shape for buttons */
}

/* Utility Class: Add the candy stripe background anywhere. */
.brand-stripe-bg {
    background-image: repeating-linear-gradient(
      90deg,
      var(--vc-purple-light),
      var(--vc-purple-light) 20px,
      transparent 20px,
      transparent 40px
    );
    background-color: #fafafa;
}


/* --------------------------------------------
   2. GLOBAL TYPOGRAPHY REFINEMENTS
   -- NO GLOBAL COLOR OVERRIDES HERE --
   We rely on Theme Settings for text color.
-------------------------------------------- */

/* Ensure headers use the defined dark color when not overridden by a scheme */
h1, h2, h3, h4, h5, 
.h0, .h1, .h2, .h3, .h4, .h5 {
    /* We don't use 'color' here, rely on Theme Settings for contrast */
    letter-spacing: 0.02em; 
}

/* Make main page titles pop a bit more */
.main-page-title {
    font-weight: 700;
}

/* Studio specific: Tighter rich text headings */
.rich-text__heading {
    margin-bottom: 15px !important;
}


/* --------------------------------------------
   3. SPACING & LAYOUT FIXES (The Homepage Fixer)
   Tightening up the default Studio spacing.
-------------------------------------------- */

/* Reduce vertical spacing on Rich Text Sections */
.rich-text.section {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}

/* Reduce vertical spacing on Image with text sections */
.image-with-text.section {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}

/* Ensure the content inside doesn't have huge margins */
.rich-text__wrapper, 
.image-with-text__content {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}


/* --------------------------------------------
   4. BRAND BUTTONS
   Standardizing all main action buttons.
-------------------------------------------- */
.button--primary, 
.shopify-payment-button__button--unbranded,
.newsletter-form__button {
    background-color: var(--vc-purple-dark) !important;
    color: #ffffff !important; /* Buttons MUST have white text */
    border: none !important;
    border-radius: var(--vc-btn-radius) !important;
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 0 32px !important;
    transition: all 0.3s ease;
    box-shadow: 0 4px 6px rgba(126, 87, 194, 0.2);
}

.button--primary:hover, 
.shopify-payment-button__button--unbranded:hover,
.newsletter-form__button:hover {
    background-color: #6a47a5 !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(126, 87, 194, 0.3);
}

/* Secondary/Outline buttons */
.button--secondary {
    border: 2px solid var(--vc-purple-dark) !important;
    color: var(--vc-purple-dark) !important;
    border-radius: var(--vc-btn-radius) !important;
    background: transparent !important;
}


/* --------------------------------------------
   5. PRODUCT & COLLECTION CARDS
   Making them feel soft and inviting.
-------------------------------------------- */
.card-wrapper {
    border-radius: var(--vc-border-radius) !important;
}

.card {
    background-color: var(--vc-card-bg);
    border-radius: var(--vc-border-radius) !important;
    border: 1px solid rgba(126, 87, 194, 0.1) !important; 
    box-shadow: 0 4px 12px rgba(0,0,0,0.05); 
    overflow: hidden; 
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card-wrapper:hover .card {
     transform: translateY(-4px);
     box-shadow: 0 8px 20px rgba(126, 87, 194, 0.15); 
}
/* --------------------------------------------
   6. BRAND COMPONENTS - Dotted Box
   (Used for high-impact text sections like Rich Text or Image with Text)
-------------------------------------------- */

.vc-dotted-box {
    /* 1. Background and Padding */
    background-color: #FFF8F3; /* Your desired soft background color */
    padding: 3rem 2.5rem;      /* Generous padding inside the box */
    margin: 2rem 0;            /* Vertical space to "float" off the edges */
    
    /* 2. Rounded Corners (using your variable) */
    border-radius: var(--vc-border-radius); 
    
    /* 3. The Dotted Border */
    border: 3px dotted var(--vc-purple-dark); /* 3px thickness, dotted style, dark purple color */
    
    /* 4. Subtle "Floating" Shadow */
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08); /* A light, soft shadow */
}

/* OPTIONAL: If you apply this to a Rich Text section, this 
   tightens up the padding *outside* the box for a cleaner look.
*/
.rich-text.vc-dotted-box {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
/* ------------------------------ */
/* --------------------------------------------------------------*/
/* --------------------------------------------------------------*/
/* ============================
   Violet's Crayon – Class Snapshot Card
   ============================ */


}
/* ================================
   Violet's Crayon – Product Layout
   ================================ */

/* 1. Desktop layout – smaller media, larger info column */
@media screen and (min-width: 990px) {
  .product {
    column-gap: 3rem;
  }

  .product__media-wrapper {
    max-width: 480px;
  }

  .product__info-wrapper {
    max-width: 640px;
  }
}

/* 2. Product typography sizing on class pages */
.product__info-wrapper .price__regular,
.product__info-wrapper .price__sale {
  font-size: 1.4rem;
}

.product__info-wrapper .product__title {
  font-size: 2rem;
}

/* Quantity + add-to-cart / Appointo buttons a bit smaller */
.product-form__quantity {
  transform: scale(0.9);
  transform-origin: left center;
}

.product-form__buttons .product-form__submit,
.product-form__buttons button.appointo-single-booking-btn,
.product-form__buttons .appointo-book-btn,
.appointo-book-btn {
  font-size: 0.95rem;
  padding: 0.9rem 1.8rem;
  border-radius: 999px;
  background-color: #7A4DBA;
  color: #fff;
  border: 2px solid #7A4DBA;
}

.product-form__buttons .product-form__submit:hover,
.product-form__buttons .appointo-book-btn:hover,
.appointo-book-btn:hover {
  background-color: #5b3790;
  border-color: #5b3790;
}

/* ===============================
   Class Snapshot card (right side)
   =============================== */

.vc-class-snapshot {
  background: #FFF9F0;
  border: 1px solid #E6D5FF;
  border-radius: 18px;
  padding: 18px 20px 16px;
  margin: 1.25rem 0 1.75rem;
}

.vc-class-snapshot__eyebrow {
  font-family: 'Quicksand', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #7A4DBA;
  margin: 0 0 0.75rem;
}

/* Grid for snapshot chips */
.vc-class-snapshot__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem 1.25rem;
}

.vc-class-snapshot__item {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.5rem;
  row-gap: 0.1rem;
  align-items: center;
}

.vc-class-snapshot__item--wide {
  grid-column: 1 / -1;
}

/* Icon */
.vc-class-snapshot__icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #F1E5FF;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.1rem;
}

.vc-icon-svg {
  width: 18px;
  height: 18px;
  color: #7A4DBA;
}

/* Text inside chips */
.vc-class-snapshot__label {
  font-size: 1.45rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #7A4DBA;
;
}

.vc-class-snapshot__value {
  grid-column: 2 / 3;
  font-size: 1.25rem;
  color: #3A2F4F;
}

/* Mobile: full-width single column snapshot */
@media screen and (max-width: 749px) {
  .vc-class-snapshot {
    margin-top: 1rem;
  }

  .vc-class-snapshot__grid {
    grid-template-columns: 1fr;
  }
}

/* ------------------------------ */
/* PRODUCT PAGE – SAFE SCOPED FIX */
/* ------------------------------ */

.template-product .product__media-wrapper {
  max-width: 520px;
}

.template-product .product__media img {
  border-radius: 12px;
}

@media screen and (max-width: 768px) {
  .template-product .product__media-wrapper {
    max-width: 100%;
  }
}

/* Title sizing */
.template-product .product__title {
  font-size: 2rem !important;
  line-height: 1.2;
}

/* Price line */
.template-product .price-item {
  font-size: 1rem !important;
}

/* Quantity selector */
.template-product .quantity-input,
.template-product .quantity__button {
  font-size: 0.95rem !important;
  padding: 4px 8px !important;
}

/* Schedule button */
.template-product .product-form__submit {
  padding: 14px 18px !important;
  font-size: 1rem !important;
  border-radius: 14px !important;
  border-width: 2px !important;
}

.template-product .product-form__submit::before {
  border-radius: 14px !important;
}

/* Share link */
.template-product .share-button,
.template-product .share-button__button {
  font-size: 0.85rem !important;
  opacity: 0.8;
}

/* Class Snapshot card – layout fix */
.template-product .vc-class-card {
  max-width: 380px;
  margin-bottom: 1rem;
}

.template-product .vc-class-card .snapshot-row {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.template-product .vc-class-card .snapshot-item {
  width: 48%;
  margin-bottom: 10px;
}

.template-product .vc-class-card .snapshot-item span.label {
  font-weight: 600;
  font-size: 0.78rem;
}

.template-product .vc-class-card .snapshot-item span.value {
  font-size: 0.9rem;
}

/* Fix for icons */
.template-product .vc-icon {
  width: 18px;
  height: 18px;
  margin-right: 6px;
}
/* ---------------------------------------- */
/* WIDEN DETAIL COLUMN ON PRODUCT PAGES     */
/* ---------------------------------------- */

.template-product .product__grid {
  grid-template-columns: 1fr 1.1fr !important;
  column-gap: 50px !important;
}

@media screen and (min-width: 1200px) {
  .template-product .product__grid {
    grid-template-columns: 0.9fr 1.2fr !important;
  }
}

@media screen and (max-width: 900px) {
  .template-product .product__grid {
    grid-template-columns: 1fr !important;
  }
}
.template-product .page-width {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.vc-calendar-wrapper {
  max-width: 1200px;
  margin: 0 auto;
  background: #fffdf8;
  padding: 2rem;
  border-radius: 24px;
  border: 3px solid #e4d4ff;
  box-shadow: 0 6px 18px rgba(106, 63, 160, 0.15);
}
.vc-calendar-subtitle {
  text-align: center;
  font-size: 1.4rem;
  margin-bottom: 1.5rem;
  font-weight: 500;
  color: #5a3a76;
}
/*
.vc-calendar-footerlink {
  text-align: center;
  margin-top: 1.5rem;
}
.vc-calendar-footerlink a {
  font-size: 1.5rem;
  color: #5a3a76;
  font-weight: 600;
  font-decoration: none;
}
  */

/* 5. FOOTER BUTTON STYLING */
.vc-navlink-center {
    text-align: center;
    margin-top: 40px;
    padding-bottom: 60px;
}

.vc-navlink {
    display: inline-block;
    background-color: #7d50a1; /* Brand purple from your logo */
    color: #ffffff !important;
    padding: 15px 35px;
    text-decoration: none;
    font-size: 1.3rem;
    font-weight: bold;
    border-radius: 50px; /* Rounded pill shape to match your logo's soft edges */
    transition: transform 0.2s ease, background-color 0.2s ease;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

.vc-navlink:hover {
    background-color: #6a428a; /* Slightly darker on hover */
    transform: translateY(-2px); /* Subtle lift effect */
    color: #ffffff !important;
}
/* --- Universal Centered Titles (Final Version) --- */

/* 1. Targets Standard Pages, Collections, and your "Explore Our Offerings" page */
.main-page-title, 
.collection-hero__title,
.title-wrapper-with-link h1,
.collection-list-title,
h1.title--primary {
    text-align: center !important;
    width: 100% !important;
    margin: 0 auto !important;
    display: block !important;
}

/* 2. Specific fix for the "Studio Schedule" page title to ensure it stays centered */
h1.main-page-title.page-title.h0 {
    text-align: center !important;
    justify-content: center !important;
    display: flex !important;
}

/* 3. Product Page Fix: Center the visible title and hide the ghost duplicate */
.product__title h1 {
    text-align: center !important;
    width: 100% !important;
}

.product__title + .product__title,
.product__title h1.visually-hidden {
    display: none !important;
}

/* 4. Center instructions/subtitles globally */
.vc-calendar-subtitle, .rte .center-text {
    text-align: center !important;
}
/* --- Collections List Spacing --- */
#shopify-section-template--25688950210856__main .section-stack {
    margin-top: 60px !important;
    padding-top: 20px !important;
}

#shopify-section-template--25688950210856__main .title-wrapper-with-link {
    margin-bottom: 50px !important;
}

/* --- 1. UNIVERSAL CENTERED TITLES & SPACING --- */
/* This centers titles and adds 60px of space at the top/bottom */
.main-page-title, 
.collection-hero__title, 
.title-wrapper-with-link h1,
.collection-list-title, 
h1.title--primary {
    text-align: center !important;
    width: 100% !important;
    margin: 30px auto 20px auto !important; 
    display: block !important;
}

/* --- 2. PRODUCT PAGE REFINEMENT --- */
/* Keeps product titles tighter to the top so they don't have a huge gap */
.product__title h1 {
    margin-top: 10px !important;
    margin-bottom: 20px !important;
}

/* Hides the duplicate accessibility title on product pages */
.product__title + .product__title,
.product__title h1.visually-hidden {
    display: none !important;
}

/* --- 3. STUDIO SCHEDULE (CALENDAR) SPECIFICS --- */
/* Ensures the "Calendar" page title stays centered */
h1.main-page-title.page-title.h0 {
    text-align: center !important;
}

/* Centers the subtitle text on the calendar page */
.vc-calendar-subtitle {
    text-align: center !important;
    margin-bottom: 30px !important;
}
/* --- CART PAGE BRANDING --- */

/* 1. Center Cart Title and Subtitle */
.cart__header, .cart__title {
    text-align: center !important;
    margin-top: 40px !important;
}

/* 2. Style the Product Images like Polaroid Photos */
.cart-item__image-container {
    border: 8px solid #fff;
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
    transform: rotate(-2deg); /* Gives it a "scrapbook" feel */
    transition: transform 0.3s ease;
}

.cart-item__image-container:hover {
    transform: rotate(0deg);
}

/* 3. Style the Checkout Button */
.cart__checkout-button {
    background-color: #7d50a1 !important; /* Your brand purple */
    border-radius: 50px !important;
    padding: 18px 30px !important;
    font-weight: bold !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    box-shadow: 0 5px 15px rgba(125, 80, 161, 0.2);
}

/* 4. Soften the Cart Item Rows */
.cart-item {
    border-bottom: 1px solid #f0e6f5 !important; /* Light lavender divider */
    padding: 20px 0 !important;
}