/*
 * Lightweight visual polish for active public pages.
 *
 * This stylesheet is deliberately scoped to pages carrying the
 * .visual-polish-prototype body class. It adds no fonts, images or scripts.
 */

.visual-polish-prototype {
  --lavie-pink: #d770ad;
  --lavie-blue: #3399ff;
  --lavie-text: #6f6f6f;
  --lavie-heading: #4f4f4f;
  --lavie-border: #ece8eb;
  --lavie-surface: #fff;
  --lavie-soft-surface: #fcfafb;
  color: var(--lavie-text);
  line-height: 1.75;
}

.visual-polish-prototype .main-content h2,
.visual-polish-prototype .main-content h3,
.visual-polish-prototype .main-content h4,
.visual-polish-prototype .main-content h5 {
  color: var(--lavie-heading);
  line-height: 1.25;
}

.visual-polish-prototype .main-content h2.mb-30- {
  margin-bottom: 24px !important;
}

.visual-polish-prototype .main-content .subtitle {
  line-height: 1.8;
}

/*
 * Content media must always follow its intrinsic aspect ratio. Revolution
 * Slider backgrounds are intentionally excluded because the slider controls
 * their responsive crop itself.
 */
.visual-polish-prototype .main-content img.img-responsive,
.visual-polish-prototype .main-content img.img-fullwidth {
  aspect-ratio: auto;
  height: auto !important;
  max-width: 100%;
  object-fit: contain;
}

.visual-polish-prototype .main-content .btn {
  align-items: center;
  border-radius: 4px;
  display: inline-flex;
  justify-content: center;
  letter-spacing: 0.35px;
  line-height: 1.25;
  min-height: 40px;
  padding: 10px 18px;
  transition: background-color 160ms ease, border-color 160ms ease,
    color 160ms ease, box-shadow 160ms ease;
}

.visual-polish-prototype .main-content .btn.btn-xs {
  min-height: 34px;
  padding: 7px 15px;
}

.visual-polish-prototype .main-content .btn:hover,
.visual-polish-prototype .main-content .btn:focus {
  box-shadow: 0 4px 12px rgba(75, 50, 64, 0.12);
}

/* Homepage: retain the existing layout while making each treatment easier to scan. */
.visual-polish-home #welcome,
.visual-polish-home #awards,
.visual-polish-home .main-content > section.bg-lighter {
  padding-bottom: 58px;
  padding-top: 58px;
}

.visual-polish-home #welcome .col-md-8 > .subtitle {
  margin-left: auto;
  margin-right: auto;
  max-width: 720px;
}

.visual-polish-home .main-content img:not(.rev-slidebg) {
  aspect-ratio: auto;
  height: auto !important;
  max-width: 100%;
  object-fit: contain;
}

.visual-polish-home #welcome .feature-items {
  background: var(--lavie-surface);
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
  box-shadow: 0 7px 20px rgba(86, 63, 76, 0.055);
  overflow: hidden;
}

.visual-polish-home #welcome .feature-items .thumb {
  background: #f5f5f5;
  overflow: hidden;
}

.visual-polish-home #welcome .feature-items .thumb img {
  display: block;
}

.visual-polish-home #welcome .feature-items h4 {
  margin: 22px 16px 10px;
}

.visual-polish-home #welcome .feature-items .details {
  min-height: 150px;
  padding: 0 20px 20px !important;
}

.visual-polish-home #welcome .feature-items .details p {
  margin-bottom: 10px;
}

.visual-polish-home #welcome .feature-items .details .font-12 {
  color: #777;
  line-height: 1.65;
}

.visual-polish-home .main-content > section.bg-lighter {
  background-color: var(--lavie-soft-surface) !important;
}

.visual-polish-home .carousel-3col article.post .entry-header {
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(86, 63, 76, 0.05);
  overflow: hidden;
}

.visual-polish-home #awards .feature-items {
  margin-top: 22px !important;
}

.visual-polish-home #awards .feature-items .thumb {
  align-items: center;
  display: flex;
  height: 145px;
  justify-content: center;
}

.visual-polish-home #awards .feature-items img {
  display: block;
  height: auto !important;
  margin: 0 auto;
  max-height: 140px;
  width: auto !important;
}

/* Treatment page: clarify the content hierarchy without changing its structure. */
.visual-polish-treatment .main-content > section > .container {
  padding-bottom: 45px !important;
  padding-top: 36px !important;
}

.visual-polish-treatment .sidebar {
  background: var(--lavie-soft-surface);
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
  padding: 20px 18px 10px;
}

.visual-polish-treatment .sidebar .widget-title {
  font-size: 19px;
  margin-bottom: 18px;
}

.visual-polish-treatment .sidebar .panel-group .panel {
  margin-bottom: 7px;
}

.visual-polish-treatment .sidebar .panel-title a {
  line-height: 1.5;
}

.visual-polish-treatment .blog-pull-right > .blog-posts > .col-md-12 {
  padding-left: 24px;
}

.visual-polish-treatment .blog-pull-right article.post > .entry-header h5 {
  font-size: 32px !important;
  margin-bottom: 24px !important;
}

.visual-polish-treatment .blog-pull-right article.post > .entry-header img {
  border-radius: 6px;
}

.visual-polish-treatment .blog-pull-right article.post > p,
.visual-polish-treatment .blog-pull-right article.post > ul {
  max-width: 820px;
}

.visual-polish-treatment .blog-pull-right article.post > ul li {
  margin-bottom: 9px;
}

.visual-polish-treatment #blog-posts-wrapper article.post {
  background: var(--lavie-surface);
  border-color: var(--lavie-border) !important;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(86, 63, 76, 0.05);
  overflow: hidden;
  padding-bottom: 0 !important;
}

.visual-polish-treatment #blog-posts-wrapper article.post img {
  display: block;
}

/* Promotion page: improve reading flow and give the lead form a clear home. */
.visual-polish-promotion .main-content > section > .container {
  padding-bottom: 45px !important;
  padding-top: 36px !important;
}

.visual-polish-promotion .main-content h3.font-36 {
  font-size: 32px !important;
  margin-bottom: 22px !important;
}

.visual-polish-promotion .main-content p.subtitle,
.visual-polish-promotion .main-content ul.subtitle {
  line-height: 1.8;
  max-width: 820px;
}

.visual-polish-promotion .main-content video {
  background: #f5f5f5;
  border-radius: 6px;
  display: block;
  height: auto;
  width: 100%;
}

.visual-polish-promotion #blog-posts-wrapper article.post {
  background: var(--lavie-surface);
  border-color: var(--lavie-border) !important;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(86, 63, 76, 0.05);
  overflow: hidden;
}

.visual-polish-promotion #blog-posts-wrapper article.post img {
  display: block;
}

/* General content pages: use the same quieter rhythm and surface treatment. */
.visual-polish-standard .main-content > section:not(.inner-header) {
  padding-bottom: 54px;
  padding-top: 54px;
}

.visual-polish-standard .main-content > section.bg-lighter {
  background-color: var(--lavie-soft-surface) !important;
}

.visual-polish-standard .section-title {
  margin-bottom: 30px;
}

.visual-polish-standard .section-title .subtitle {
  margin-left: auto;
  margin-right: auto;
  max-width: 820px;
}

.visual-polish-about .popular-items .icon-box {
  margin-bottom: 20px;
}

.visual-polish-about .popular-items .icon-box-title {
  font-size: 22px;
}

.visual-polish-about .carousel-3col article.post .entry-header {
  background: #f5f5f5;
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
  overflow: hidden;
}

.visual-polish-contact .icon-box.bg-deep {
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
}

.visual-polish-contact #contact_form,
.visual-polish-promotion #contact_form {
  background: var(--lavie-soft-surface);
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
  box-shadow: 0 7px 20px rgba(86, 63, 76, 0.05);
  margin-bottom: 24px;
  padding: 26px 26px 14px;
}

.visual-polish-contact #contact_form label,
.visual-polish-promotion #contact_form label {
  color: #5d5d5d;
  font-size: 13px;
  letter-spacing: 0.3px;
}

.visual-polish-contact #contact_form .form-group,
.visual-polish-promotion #contact_form .form-group {
  margin-bottom: 18px;
}

.visual-polish-contact #contact_form .form-control,
.visual-polish-promotion #contact_form .form-control {
  border-color: #ddd7db;
  border-radius: 4px;
  box-shadow: none;
  min-height: 44px;
  padding: 10px 12px;
}

.visual-polish-contact #contact_form textarea.form-control {
  min-height: 130px;
}

.visual-polish-contact #contact_form .form-control:focus,
.visual-polish-promotion #contact_form .form-control:focus {
  border-color: var(--lavie-pink);
  box-shadow: 0 0 0 3px rgba(215, 112, 173, 0.12);
}

/* Promotion and treatment directory pages. */
.visual-polish-listing .main-content > section > .container,
.visual-polish-treatment-directory .main-content > section > .container {
  padding-bottom: 45px !important;
  padding-top: 36px !important;
}

.visual-polish-listing .main-content .thumb {
  background: #f5f5f5;
  border: 1px solid var(--lavie-border);
  border-radius: 6px;
  overflow: hidden;
}

.visual-polish-listing .portfolio-description {
  margin-right: 0 !important;
  padding: 18px 6px 30px;
}

.visual-polish-listing .portfolio-description .title {
  font-size: 20px;
  margin-bottom: 10px;
}

.visual-polish-listing .portfolio-description p {
  line-height: 1.7;
  min-height: 48px;
}

.visual-polish-gallery #blog-posts-wrapper article.post,
.visual-polish-gallery .blog-posts article.post {
  background: var(--lavie-surface);
  border-color: var(--lavie-border) !important;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(86, 63, 76, 0.05);
  overflow: hidden;
}

@media (max-width: 991px) {
  .visual-polish-treatment .blog-pull-right > .blog-posts > .col-md-12 {
    padding-left: 15px;
  }

  .visual-polish-treatment .sidebar {
    margin-bottom: 28px;
  }

  .visual-polish-listing .portfolio-description p {
    min-height: 0;
  }
}

@media (max-width: 767px) {
  .visual-polish-home #welcome,
  .visual-polish-home #awards,
  .visual-polish-home .main-content > section.bg-lighter {
    padding-bottom: 42px;
    padding-top: 42px;
  }

  .visual-polish-prototype .main-content h2.font-48 {
    font-size: 38px !important;
  }

  .visual-polish-treatment .blog-pull-right article.post > .entry-header h5 {
    font-size: 27px !important;
  }

  .visual-polish-promotion .main-content h3.font-36 {
    font-size: 28px !important;
  }

  .visual-polish-promotion #contact_form {
    padding: 22px 18px 10px;
  }

  .visual-polish-contact #contact_form {
    padding: 22px 18px 10px;
  }

  .visual-polish-standard .main-content > section:not(.inner-header) {
    padding-bottom: 42px;
    padding-top: 42px;
  }

  .visual-polish-home #awards .feature-items .thumb {
    height: 130px;
  }

  .visual-polish-home #awards .feature-items img {
    max-height: 125px;
  }

  .visual-polish-prototype .main-content .text-center > .btn {
    max-width: 100%;
    white-space: normal;
  }
}

@media (prefers-reduced-motion: reduce) {
  .visual-polish-prototype .main-content .btn {
    transition: none;
  }
}
