﻿@font-face {
    font-family: 'LemonMilk';
    src: url('fonts/19572.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}
@font-face {
    font-family: 'Raleway';
    src: url('fonts/Raleway-VariableFont_wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: normal;
}
body {
    font-family: 'Raleway', Arial, sans-serif;
    background: #fff;
    color: #343434;
}
.lemon {
    font-family: 'LemonMilk', Arial, sans-serif;
}

#main-header {
    border: none;
    border-radius: 0;
    backdrop-filter: blur(40px);
    background: rgba(255, 255, 255, .4);
    -webkit-backdrop-filter: blur(40px);
    box-shadow: none;
    z-index: 1050;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s;
}
#main-header.visible {
    opacity: 1 !important;
    pointer-events: auto;
}

.main-header-visible {
    border: none;
    border-radius: 0;
    background: #fff;
    box-shadow: 0 4px 24px 0 rgba(0,0,0,0.06);
    opacity: 1;
    pointer-events: auto;
}

.btn-order-main {
    display: inline-block;
    text-decoration: none;
    border-width: 0;
    border-radius: 30px;
    background: radial-gradient(circle at 50% 45%, #cbe94a 0%, #d9f855 65%, #eaff9c 95%, #f8ffbe 100%);
    box-shadow: 0px 3px 0px #AAC33C;
    transition: background 0.2s, color 0.2s;
    text-align: center;
    padding-top: 3rem;
    padding-bottom: 3rem;
}
.btn-order-main:hover {
    border-width: 0;
    border-radius: 30px;
    background: radial-gradient(circle at 50% 45%, #bad443 0%, #c8e44e 65%, #d9ed90 95%, #e1e7ac 100%);
}

.btn-order {
    display: inline-block;
    text-decoration: none;
    color:#4A5B00;
    background:#d9f855;
    border-radius:80px;
    box-shadow: inset 0px 0px 7.82396px rgba(255, 255, 255, 0.6), inset 0px 0px 39.1198px rgba(255, 255, 255, 0.5);
    border-width: 0;
    text-align: center;
}

.btn-order:hover {
    color:#576b00;
    background:#cae64e;
}

.btn-services {
    border-width: 0;
    background: rgba(150, 168, 254, 0.2);
    border-radius: 90px;
    font-family: 'Raleway', sans-serif;
    font-weight: 500;
    font-size: 17px;
    line-height: 20px;
    color: #3D4F99;
}

.btn-services.active {
    background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%), #96A8FE;
    color: #FFFFFF;
}

.btn-main-services {
  border-width: 0;
  background: rgba(150, 168, 254, 0.2);
  border-radius: 90px;
  font-family: 'Raleway', sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 15px;
  line-height: 18px;
  color: #3D4F99;
}

.btn-main-services.active {
  background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%), #96A8FE;
  color: #FFFFFF;
}

.btn-area-ranges {
  border-width: 0;
  background: rgba(150, 168, 254, 0.2);
  border-radius: 90px;
  font-family: 'Raleway', sans-serif;
  font-style: italic;
  font-weight: 400;
  font-size: 12px;
  line-height: 14px;
  color: #3D4F99;
}

.btn-area-ranges.active {
  background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%), #96A8FE;
  color: #FFFFFF;
}

:root {
  --additional-services-block-background: rgba(199, 199, 199, 0.1);
  --additional-services-block-text-color: #777777;
  --additional-services-block-text-extra-color: rgba(119, 119, 119, 0.5);
  --additional-services-block-count: #777;
}

.additional-services-block {
    background: var(--additional-services-block-background);
    border-radius: 90px;
    gap: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.additional-services-block.active {
    --additional-services-block-background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%);
    --additional-services-block-text-color: #FFFFFF;
    --additional-services-block-text-extra-color: rgba(255, 255, 255, 0.6);
    --additional-services-block-count: #FFFFFF;
}

.additional-services-block-text {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 400;
    font-size: 15px;
    line-height: 16px;
    color: var(--additional-services-block-text-color);
}


.additional-services-block-text-extra {
  font-family: 'Raleway';
  font-style: italic;
  font-weight: 400;
  font-size: 13px;
  line-height: 15px;
  color: var(--additional-services-block-text-extra-color)
}


.additional-services-block-count {
  font-size:20px;
  color:var(--additional-services-block-count);
}

section {
    margin-bottom: 40px;
}
.card, .p-0[style*="background:#fff"] {
    background: #fff;
    border-radius: 24px;
    box-shadow: 0 4px 24px 0 rgba(0,0,0,0.06);
}
.badge {
    font-size: 12.4px;
    font-family: 'Raleway', sans-serif;
    font-weight: 500;
    letter-spacing: 0.62px;
}
/* Заглушки для фото до/после */
[style*="aspect-ratio:4/5"][style*="background:#e9e9e9"] {
    aspect-ratio: 4/5;
    min-height: 180px;
    background: #e9e9e9;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: #aaa;
}

footer {
    font-family: 'Raleway', Arial, sans-serif;
    background: linear-gradient(90deg, #849af8 0%, #5c78ee 100%);
    color: #fff;
}

/* Before/After Slider */
.ba-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 24px;
  background: #f5f7fa;
  user-select: none;
}
.ba-slider img {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  object-fit: cover;
  transition: filter 0.2s;
  user-select: none;
  pointer-events: none;
}
.ba-slider .ba-after {
  clip-path: inset(0 0 0 50%);
  z-index: 2;
}
.ba-slider .ba-before {
  z-index: 1;
}
.ba-slider .ba-handle {
  position: absolute;
  top: 0; left: 50%;
  width: 48px; height: 100%;
  transform: translateX(-50%);
  cursor: ew-resize;
  z-index: 3;
  display: flex; align-items: center; justify-content: center;
}
.ba-slider .ba-divider {
  width: 4px;
  height: 100%;
  background: var(--slider-color, #849AF8);
  border-radius: 2px;
  margin: 0 0 0 0;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  z-index: 2;
}

.ba-slider .ba-circle {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 48px; height: 48px;
  background: var(--slider-color, linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%));
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  border: none;
  display: flex; align-items: center; justify-content: center;
  z-index: 4;
  cursor: ew-resize;
}
.ba-slider .ba-arrow {
  width: 18px; height: 18px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px 18px;
}
.ba-slider .ba-arrow-left {
  background-image: url('images/arrow-left.svg');
  background-position: center;
  margin-right: 2px;
}
.ba-slider .ba-arrow-right {
  background-image: url('images/arrow-right.svg');
  background-position: center;
  margin-left: 2px;
}

.before-after-section-title {
  font-size: 52px;
  line-height: 57px;
  font-style: normal;
  font-weight: 400;
  line-height: 110%;
}

.before-after-section-item-title {
  font-size: 20px;
  color: #3a3a3a;
}

.before-after-section-item-duration {
  font-size: 16px;
}

.with-blick {
  position: relative;
  display: inline-block;
  z-index: 1;
}

.with-blick::after {
  content: "";
  display: block;
  position: absolute;
  top: -15%;
  right: -10%;
  width: 100%;
  height: 100%;
  background: url('images/blick.png') no-repeat center/contain;
  pointer-events: none;
  z-index: 2;
}

.area-range-block {
  width: 100%;
  max-width: 600px;
  margin: 0 auto 32px auto;
  background: transparent;
  border-radius: 20px;
  padding: 0;
}


.area-range-slider {
  width: 100%;
  appearance: none;
  height: 12px;
  background: linear-gradient(90deg, #849af8 0%, #5c78ee 100%) 0/0% 100% no-repeat, #e0e0e0;
  border-radius: 6px;
  outline: none;
  margin-bottom: 0;
  position: relative;
  transition: background 0.3s;
  display: block;
}

.area-range-slider::-webkit-slider-thumb {
  appearance: none;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #96a8fe;
  border: 4px solid #fff;
  box-shadow: 0 2px 8px 0 rgba(90,122,255,0.10);
  cursor: pointer;
  transition: background 0.3s;
  margin-top: -10px;
  position: relative;
  z-index: 2;
}

.area-range-slider::-moz-range-thumb {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #96a8fe;
  border: 4px solid #fff;
  box-shadow: 0 2px 8px 0 rgba(90,122,255,0.10);
  cursor: pointer;
  transition: background 0.3s;
  position: relative;
  z-index: 2;
}

.area-range-slider::-ms-thumb {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #96a8fe;
  border: 4px solid #fff;
  box-shadow: 0 2px 8px 0 rgba(90,122,255,0.10);
  cursor: pointer;
  transition: background 0.3s;
  position: relative;
  z-index: 2;
}

.area-range-slider:focus {
  outline: none;
}

.area-range-slider::-webkit-slider-runnable-track {
  height: 12px;
  border-radius: 6px;
  background: transparent;
}

.area-range-slider::-ms-fill-lower {
  background: transparent;
  border-radius: 6px;
}

.area-range-slider::-ms-fill-upper {
  background: transparent;
  border-radius: 6px;
}

.area-range-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 14px;
  font-family: 'Raleway', Arial, sans-serif;
  font-size: 22px;
  color: #b0b0b0;
  font-weight: 500;
}

.area-range-labels span {
  min-width: 60px;
  text-align: center;
  opacity: 0.6;
  font-style: italic;
  font-weight: 400;
  transition: color 0.2s, opacity 0.2s, font-weight 0.2s, font-style 0.2s;
}

.area-range-labels span.active {
  color: #5A6ACF;
  opacity: 1;
  font-weight: 700;
  font-style: normal;
}

.submit-form {
  display: flex;
  max-width: 520px;
}


.form-controller {
  width: 100%;
  max-width: 500px;
  border: none;
  box-sizing: border-box;
  background: #FFFFFF;
  border-radius: 15px;

  font-family: 'Raleway';
  font-style: normal;
  font-weight: 500;
  font-size: 15px;
  line-height: 18px;
  align-items: center;
  color: #000000;

  padding: 1.5rem 1.5rem;
}

.form-controller:focus {
  border: 1px solid rgba(119, 119, 119, 0.5);
  outline: none;
  width: 100%;
  max-width: 500px;
}


.form-controller.was-validated:invalid {
  border: 1px solid rgba(244, 52, 52, 0.5) !important;
}
/* .form-controller:focus:invalid {
  border: 1px solid rgba(244, 52, 52, 0.5) !important;
} */


.success-circle {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 40px 0;
}

.success-circle svg {
  display: block;
  width: 120px;
  height: 120px;
}

@media (max-width: 600px) {
  .success-circle svg {
    width: 80px;
    height: 80px;
  }
}

.error-circle {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 40px 0;
}

.error-circle svg {
  display: block;
  width: 120px;
  height: 120px;
}

@media (max-width: 600px) {
  .error-circle svg {
    width: 80px;
    height: 80px;
  }
}


/* Flat DatePticker */

.date-picker-container {
  width: 100%;
  max-width: 500px;
  border: none;
  box-sizing: border-box;
  background: #FFFFFF;
  border-radius: 15px;
  align-items: center;
  padding: 1.5rem 1.5rem;
  min-width: 0;
}

#flatpickr-container {
  width: 100%;
  max-width: 500px;
  min-width: 0;
}

/* Контейнер календаря */
.flatpickr-calendar {
  width: 100% !important;
  max-width: 500px !important;
  min-width: 0;
  border: none !important;
  border-radius: 28px !important;
  box-shadow: none !important;
  background: #fff !important;
  margin: 0 auto;
  padding-bottom: 32px;
}


.flatpickr-calendar {
  width: 100%;
  max-width: 400px !important;
  background: transparent;
  opacity: 0;
  text-align: center;
  visibility: hidden;
  padding: 0;
  -webkit-animation: none;
          animation: none;
  direction: ltr;
  border: none;
  border-radius: 5px;
  box-shadow: none;
  position: absolute;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  background: #fff;
}
.flatpickr-calendar.open,
.flatpickr-calendar.inline {
  opacity: 1;
  max-height: 640px;
  visibility: visible;
}
.flatpickr-calendar.open {
  display: inline-block;
  z-index: 99999;
}
.flatpickr-calendar.animate.open {
  -webkit-animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
          animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.flatpickr-calendar.inline {
  display: block;
  position: relative;
  top: 2px;
}
.flatpickr-calendar.static {
  position: absolute;
  top: calc(100% + 2px);
}
.flatpickr-calendar.static.open {
  z-index: 999;
  display: block;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
  -webkit-box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
          box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
}
.flatpickr-calendar .hasWeeks .dayContainer,
.flatpickr-calendar .hasTime .dayContainer {
  border-bottom: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.flatpickr-calendar .hasWeeks .dayContainer {
  border-left: 0;
}
.flatpickr-calendar.hasTime .flatpickr-time {
  height: 40px;
  border-top: 1px solid #e6e6e6;
}
.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
  height: auto;
}
.flatpickr-calendar:before,
.flatpickr-calendar:after {
  position: absolute;
  display: block;
  pointer-events: none;
  content: '';
  height: 0;
  width: 0;
}
.flatpickr-calendar.rightMost:before,
.flatpickr-calendar.arrowRight:before,
.flatpickr-calendar.rightMost:after,
.flatpickr-calendar.arrowRight:after {
  left: auto;
  right: 22px;
}
.flatpickr-calendar.arrowCenter:before,
.flatpickr-calendar.arrowCenter:after {
  left: 50%;
  right: 50%;
}
.flatpickr-calendar:before {
  margin: 0 -5px;
}
.flatpickr-calendar:after {
  margin: 0 -4px;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after {
  bottom: 100%;
}
.flatpickr-calendar.arrowTop:before {
  border-bottom-color: #e6e6e6;
}
.flatpickr-calendar.arrowTop:after {
  border-bottom-color: #fff;
}
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after {
  top: 100%;
}
.flatpickr-calendar.arrowBottom:before {
  border-top-color: #e6e6e6;
}
.flatpickr-calendar.arrowBottom:after {
  border-top-color: #fff;
}
.flatpickr-calendar:focus {
  outline: 0;
}
.flatpickr-wrapper {
  position: relative;
  display: inline-block;
}
.flatpickr-months {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-months .flatpickr-month {
  background: transparent;
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 600;
  font-size: 16px;
  line-height: 19px;
  color: #343434;
  text-align: center;
  position: relative;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  overflow: hidden;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  text-decoration: none;
  cursor: pointer;
  position: absolute;
  top: 0;
  height: 34px;
  padding: 10px;
  z-index: 3;
  color: #343434;
  fill: rgba(0,0,0,0.9);
}
.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,
.flatpickr-months .flatpickr-next-month.flatpickr-disabled {
  display: none;
}
.flatpickr-months .flatpickr-prev-month i,
.flatpickr-months .flatpickr-next-month i {
  position: relative;
}
.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month.flatpickr-prev-month {
/*
      /*rtl:begin:ignore*/
/*
      */
  left: 0;
/*
      /*rtl:end:ignore*/
/*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,
.flatpickr-months .flatpickr-next-month.flatpickr-next-month {
/*
      /*rtl:begin:ignore*/
/*
      */
  right: 0;
/*
      /*rtl:end:ignore*/
/*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
  color: #959ea9;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: #f64747;
}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  width: 14px;
  height: 14px;
}
.flatpickr-months .flatpickr-prev-month svg path,
.flatpickr-months .flatpickr-next-month svg path {
  -webkit-transition: fill 0.1s;
  transition: fill 0.1s;
  fill: inherit;
}
.numInputWrapper {
  position: relative;
  height: auto;
}
.numInputWrapper input,
.numInputWrapper span {
  display: inline-block;
}
.numInputWrapper input {
  width: 100%;
}
.numInputWrapper input::-ms-clear {
  display: none;
}
.numInputWrapper input::-webkit-outer-spin-button,
.numInputWrapper input::-webkit-inner-spin-button {
  margin: 0;
  -webkit-appearance: none;
}
.numInputWrapper span {
  position: absolute;
  right: 0;
  width: 14px;
  padding: 0 4px 0 2px;
  height: 50%;
  line-height: 50%;
  opacity: 0;
  cursor: pointer;
  border: 1px solid rgba(57,57,57,0.15);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.numInputWrapper span:hover {
  background: rgba(0,0,0,0.1);
}
.numInputWrapper span:active {
  background: rgba(0,0,0,0.2);
}
.numInputWrapper span:after {
  display: block;
  content: "";
  position: absolute;
}
.numInputWrapper span.arrowUp {
  top: 0;
  border-bottom: 0;
}
.numInputWrapper span.arrowUp:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 4px solid rgba(57,57,57,0.6);
  top: 26%;
}
.numInputWrapper span.arrowDown {
  top: 50%;
}
.numInputWrapper span.arrowDown:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid rgba(57,57,57,0.6);
  top: 40%;
}
.numInputWrapper span svg {
  width: inherit;
  height: auto;
}
.numInputWrapper span svg path {
  fill: rgba(0,0,0,0.5);
}
.numInputWrapper:hover {
  background: rgba(0,0,0,0.05);
}
.numInputWrapper:hover span {
  opacity: 1;
}
.flatpickr-current-month {
  font-size: 135%;
  line-height: inherit;
  font-weight: 300;
  color: inherit;
  position: absolute;
  width: 75%;
  left: 12.5%;
  padding: 7.48px 0 0 0;
  line-height: 1;
  height: 34px;
  display: inline-block;
  text-align: center;
  -webkit-transform: translate3d(0px, 0px, 0px);
          transform: translate3d(0px, 0px, 0px);
}
.flatpickr-current-month span.cur-month {
  font-family: inherit;
  font-weight: 700;
  color: inherit;
  display: inline-block;
  margin-left: 0.5ch;
  padding: 0;
}
.flatpickr-current-month span.cur-month:hover {
  background: rgba(0,0,0,0.05);
}
.flatpickr-current-month .numInputWrapper {
  width: 6ch;
  width: 7ch\0;
  display: inline-block;
}
.flatpickr-current-month .numInputWrapper span.arrowUp:after {
  border-bottom-color: rgba(0,0,0,0.9);
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
  border-top-color: rgba(0,0,0,0.9);
}
.flatpickr-current-month input.cur-year {
  background: transparent;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: inherit;
  cursor: text;
  padding: 0 0 0 0.5ch;
  margin: 0;
  display: inline-block;
  font-size: inherit;
  font-family: inherit;
  font-weight: 300;
  line-height: inherit;
  height: auto;
  border: 0;
  border-radius: 0;
  vertical-align: initial;
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
}
.flatpickr-current-month input.cur-year:focus {
  outline: 0;
}
.flatpickr-current-month input.cur-year[disabled],
.flatpickr-current-month input.cur-year[disabled]:hover {
  font-size: 100%;
  color: rgba(0,0,0,0.5);
  background: transparent;
  pointer-events: none;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
  appearance: menulist;
  background: transparent;
  border: none;
  border-radius: 0;
  box-sizing: border-box;
  color: inherit;
  cursor: pointer;
  font-size: inherit;
  font-family: inherit;
  font-weight: 300;
  height: auto;
  line-height: inherit;
  margin: -1px 0 0 0;
  outline: none;
  padding: 0 0 0 0.5ch;
  position: relative;
  vertical-align: initial;
  -webkit-box-sizing: border-box;
  -webkit-appearance: menulist;
  -moz-appearance: menulist;
  width: auto;
}
.flatpickr-current-month .flatpickr-monthDropdown-months:focus,
.flatpickr-current-month .flatpickr-monthDropdown-months:active {
  outline: none;
}
.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
  background: rgba(0,0,0,0.05);
}
.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
  background-color: transparent;
  outline: none;
  padding: 0;
}
.flatpickr-weekdays {
  background: transparent;
  text-align: center;
  overflow: hidden;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 28px;
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 600 !important;
  font-size: 12px;
  line-height: 14px;
  color: #343434 !important;
}
.flatpickr-weekdays .flatpickr-weekdaycontainer {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
span.flatpickr-weekday {
  cursor: default;
  font-size: 90%;
  background: transparent;
  color: rgba(0,0,0,0.54);
  line-height: 1;
  margin: 0;
  text-align: center;
  display: block;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-weight: bolder;
}
.dayContainer,
.flatpickr-weeks {
  padding: 1px 0 0 0;
}
.flatpickr-days {
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: 307.875px;
}
.flatpickr-days:focus {
  outline: 0;
}
.dayContainer {
  padding: 0;
  outline: 0;
  text-align: left;
  width: 307.875px;
  min-width: 307.875px;
  max-width: 307.875px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: inline-block;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
          flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-around;
          justify-content: space-around;
  -webkit-transform: translate3d(0px, 0px, 0px);
          transform: translate3d(0px, 0px, 0px);
  opacity: 1;
}
.dayContainer + .dayContainer {
  -webkit-box-shadow: -1px 0 0 #e6e6e6;
          box-shadow: -1px 0 0 #e6e6e6;
}
.flatpickr-day {
  background: transparent;
  border: none;
  border-radius: 50px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: #343434;
  cursor: pointer;
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 400;
  font-size: 12px;
  width: 14.2857143%;
  -webkit-flex-basis: 14.2857143%;
      -ms-flex-preferred-size: 14.2857143%;
          flex-basis: 14.2857143%;
  max-width: 39px;
  height: 39px;
  margin: 0;
  display: inline-block;
  position: relative;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  align-items: center;
}
.flatpickr-day.inRange,
.flatpickr-day.prevMonthDay.inRange,
.flatpickr-day.nextMonthDay.inRange,
.flatpickr-day.today.inRange,
.flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover,
.flatpickr-day:focus,
.flatpickr-day.prevMonthDay:focus,
.flatpickr-day.nextMonthDay:focus {
  cursor: pointer;
  outline: 0;
  background: #e6e6e6;
  border-color: #e6e6e6;
}
.flatpickr-day.today {
  border: 1.5px solid #5a6acf91
}
.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
  border-color: #959ea9;
  background: #959ea9;
  color: #fff;
}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
  -webkit-box-shadow: none;
          box-shadow: none;
  background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%);
  color: #fff;
}
.flatpickr-day.selected.startRange,
.flatpickr-day.startRange.startRange,
.flatpickr-day.endRange.startRange {
  border-radius: 50px;
}
.flatpickr-day.selected.endRange,
.flatpickr-day.startRange.endRange,
.flatpickr-day.endRange.endRange {
  border-radius: 50px;
}
.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
  -webkit-box-shadow: -10px 0 0 #569ff7;
          box-shadow: -10px 0 0 #569ff7;
}
.flatpickr-day.selected.startRange.endRange,
.flatpickr-day.startRange.startRange.endRange,
.flatpickr-day.endRange.startRange.endRange {
  border-radius: 50px;
}
.flatpickr-day.inRange {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
          box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
  color: #ccc;
  background: #fff;
  cursor: not-allowed;
  border: none;
  cursor: default;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
  cursor: not-allowed;
  color: rgba(57,57,57,0.1);
}
.flatpickr-day.week.selected {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7;
          box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7;
}
.flatpickr-day.hidden {
  visibility: hidden;
}
.rangeMode .flatpickr-day {
  margin-top: 1px;
}
.flatpickr-weekwrapper {
  float: left;
}
.flatpickr-weekwrapper .flatpickr-weeks {
  padding: 0 12px;
  -webkit-box-shadow: 1px 0 0 #e6e6e6;
          box-shadow: 1px 0 0 #e6e6e6;
}
.flatpickr-weekwrapper .flatpickr-weekday {
  float: none;
  width: 100%;
  line-height: 28px;
}
.flatpickr-weekwrapper span.flatpickr-day,
.flatpickr-weekwrapper span.flatpickr-day:hover {
  display: block;
  width: 100%;
  max-width: none;
  color: rgba(57,57,57,0.3);
  background: transparent;
  cursor: default;
  border: none;
}
.flatpickr-innerContainer {
  display: block;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
.flatpickr-rContainer {
  display: inline-block;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.flatpickr-time {
  text-align: center;
  outline: 0;
  display: block;
  height: 0;
  line-height: 40px;
  max-height: 40px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-time:after {
  content: "";
  display: table;
  clear: both;
}
.flatpickr-time .numInputWrapper {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 40%;
  height: 40px;
  float: left;
}
.flatpickr-time .numInputWrapper span.arrowUp:after {
  border-bottom-color: #393939;
}
.flatpickr-time .numInputWrapper span.arrowDown:after {
  border-top-color: #393939;
}
.flatpickr-time.hasSeconds .numInputWrapper {
  width: 26%;
}
.flatpickr-time.time24hr .numInputWrapper {
  width: 49%;
}
.flatpickr-time input {
  background: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: 0;
  border-radius: 0;
  text-align: center;
  margin: 0;
  padding: 0;
  height: inherit;
  line-height: inherit;
  color: #393939;
  font-size: 14px;
  position: relative;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
}
.flatpickr-time input.flatpickr-hour {
  font-weight: bold;
}
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second {
  font-weight: 400;
}
.flatpickr-time input:focus {
  outline: 0;
  border: 0;
}
.flatpickr-time .flatpickr-time-separator,
.flatpickr-time .flatpickr-am-pm {
  height: inherit;
  float: left;
  line-height: inherit;
  color: #393939;
  font-weight: bold;
  width: 2%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-align-self: center;
      -ms-flex-item-align: center;
          align-self: center;
}
.flatpickr-time .flatpickr-am-pm {
  outline: 0;
  width: 18%;
  cursor: pointer;
  text-align: center;
  font-weight: 400;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
  background: #eee;
}
.flatpickr-input[readonly] {
  cursor: pointer;
}
@-webkit-keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
            transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
            transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}


/* Слоты времени */
#slots {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 16px;
  justify-content: flex-start;
}


.slot-btn {
  min-width: 120px;
  padding: 16px 0;
  border-radius: 8.61386px;
  border: 1px solid #96A8FE;
  background: #fff;
  color: #435399;
  font-weight: 600;
  font-size: 1.2rem;
  transition: background 0.2s, color 0.2s, border 0.2s;
  cursor: pointer;
  margin-bottom: 8px;
  text-align: center;
  box-sizing: border-box;
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  line-height: 15px;
}


.slot-btn.selected, .slot-btn:active {
  border: none;
  background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%), #96A8FE;;
  color: #fff;
  border-radius: 8.61386px;
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  line-height: 15px;
}

.slot-btn:disabled {
  background: #f5f5f5;
  color: #AFAFAF;
  border-color: #eee;
  border: 1px solid #D3D3D3;
  border-radius: 8.61386px;
  cursor: not-allowed;
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  line-height: 15px;
}


#main-section .upper-disclaimer {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 500;
  font-size: 12.4px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color:#798CE2;
  text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}
#main-section .upper-disclaimer-block {
  box-sizing: border-box;
  border-radius: 4.43008px;
  border: 0.886016px solid rgba(150, 168, 254, 0.2);
  max-width: 460px;
  justify-content: center;
  margin: 0 auto;
}
#main-section .main-text-name {
  font-size:144px;
  font-weight: 400;
  line-height: 100%;
  background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-style: normal;
}
#main-section .main-text-slogan{
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  font-size:32px;
  color:#343434;
}
#main-section .main-text-disclaimer{
  font-size:18px;
  color:#3a3a3a;
  max-width:460px;
  line-height: 150%;
  font-family: 'Raleway';
  font-style: normal;
  margin:0 auto;
}
#main-section .btn-order-main-text{
  font-family:'Raleway',sans-serif;
  font-style: bold;
  font-weight:700;
  font-size:16px;
  color:#576905;
  letter-spacing:0.1em;
  text-transform:uppercase;
}

#cleaning-includes {
  width: 80%
}

.service-block {
  background: rgba(207, 207, 207, 0.1); border-radius: 40px;
}
.service-block-image {
  background:#96a8fe;
  border-radius:40px;
  width:50%;
  position:relative;
  overflow:hidden;
  justify-content: center;
  align-items: center;
  display: flex;
  flex: 0 0 50%;
}
.service-block-image img {
  width:100%;
  height:100%;
  object-fit:contain;
}
.service-block-text {
  width: 50%;
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.service-block-text-main {
  font-size:28px;
  line-height:36px;
}
.custom-list {
    list-style-image: url('images/check.svg');
}
.custom-list li {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 400;
    font-size: 15px;
    line-height: 150%;
    color: #3A3A3A;
}

.desktop-none {
  display: none;
}

.nested-services-list {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.46, 0.03, 0.52, 0.96);
  margin-top: 0;
}

.nested-services-list.open {
  max-height: 1000px; /* Должно быть больше, чем максимальная высота содержимого */
  margin-top: 10px;
}

.nested-button {
  background: rgba(193, 193, 193, 0.7);
  border-radius: 40px;
  line-height: 14px;
  font-size: 12px;
  font-weight: 500;
  font-style: normal;
  font-family: 'Raleway';
  color: #FFFFFF;
  border: none
}


/* Скролл-бар для дополнительных услуг */

#additional-services-container {
  max-height: 450px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #849AF8 #f5f6fa; /* Firefox: thumb, track */
}

#additional-services-container::-webkit-scrollbar {
  width: 6px;
  background: #f5f6fa;
}
#additional-services-container::-webkit-scrollbar-thumb {
  background: #849AF8; /* Можно попробовать градиент, но не везде сработает */
  border-radius: 6px;
}

.order-footer {
  margin-top: 3rem !important;
}


/* Мобильный адаптив */

@media (max-width: 600px) {

  .mobile-none {
    display: none !important;
  }
  .desktop-none {
    display: block !important;
  }
  .mobile-no-flex {
    display: block !important;
  }
  .phone {
    padding: 0.5rem 0.5rem 0.5rem 0.5rem !important;
  }

  /* Главная страница */

  /* Основная секция */
  #main-section .container-md {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  #main-section .first-container {
    flex-direction: column !important;
    align-items: center !important;
  }
  #main-section .upper-disclaimer {
    font-size: 9px;
    line-height: 11px;
  }
  #main-section .upper-disclaimer-block {
    box-sizing: border-box;
    border: 0.654881px solid rgba(150, 168, 254, 0.2);
    border-radius: 3.27441px;
    max-width: 360px;
  }
  #main-section .main-text-name {
    font-weight: 400;
    font-size: 102px;
  }
  #main-section .main-text-slogan{
    font-size: 24px;
  }
  #main-section .main-text-disclaimer{
    font-size: 13px;
  }
  #main-section .btn-order-main{
    border-radius: 20px;
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  #main-section .btn-order-main-text{
    font-size: 12px;
    line-height: 14px;
  }

  #cleaning-includes .includes-small-text {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 1.5;
    color: #3A3A3A;
  }

  /* Что входит в уборку */
  #cleaning-includes {
    width: 80%
  }
  #cleaning-includes .includes-text-block {
    flex-direction: column !important;
    padding: 0 !important;
    margin-bottom: 1.5rem !important;
  }

  #cleaning-includes .includes-big-text {
    font-weight: 400 !important;
    font-size: 32px !important;
    line-height: 110% !important;
  }

  #cleaning-includes .includes-small-text {
    font-weight: 400 !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
  }

  #cleaning-includes .align-self-auto-mobile {
    align-self: auto !important;
  }

  /* Кнопки переключения видов уборки */

  #cleaning-includes .main-services-buttons {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px 12px !important;
    padding: 0 !important;
  }

  #cleaning-includes .main-services-buttons .btn-services {
    width: 100% !important;
    border-radius: 63px !important;

    font-weight: 500 !important;
    font-size: 12px !important;
    line-height: 14px !important;

    padding-top: 1.2rem !important;
    padding-bottom: 1.2rem !important;
    padding-right: .8rem !important;
    padding-left: .8rem !important;
  }

  /* Карточки типов уборки */
  #service-blocks .service-block-text-main {
    font-size: 16px;
    line-height: 130%;
    flex: 1 1 0;
    min-width: 0;
    align-self: center;
    padding-left: 1.8rem !important;
    padding-right: 0.5rem !important;
  }
  #service-blocks .custom-list li{
    font-size: 12px;
  }
  #service-blocks .service-block-image {
    border-radius: 6.95652px;
    flex: 0 0 30% !important;
  }
  #service-blocks .service-block {
    border-radius: 30px !important;
  }

  #before-after-section {
    width: 80%;
  }

  /* Секция "Результаты нашей работы" */
  .before-after-section-title {
    font-size: 32px;
    margin-bottom: 1.5rem !important;
  }

  .before-after-section-item-title {
    font-size: 17px;
  }

  .before-after-section-item-duration {
    font-size: 13px;
  }

  /* Group 130 */

/* Ellipse 5 */

  .ba-cases-arrow {
    display: flex;
    width: 48px; height: 48px;
    background: #D9F855;
    border-radius: 61.2px;
    box-shadow: inset 0px 0px 5.98533px rgba(255, 255, 255, 0.6), inset 0px 0px 29.9267px rgba(255, 255, 255, 0.5);
    border: none;
    display: flex; align-items: center; justify-content: center;
  }

  .ba-cases-arrow-left {
    transform: matrix(-1, 0, 0, 1, 0, 0);
  }

  .ba-cases-arrow:hover {
    background: linear-gradient(94.82deg, #849AF8 7.12%, #5C78EE 93.68%);
  }

  .ba-cases-arrow:active svg path,
  .ba-cases-arrow:hover svg path{
    stroke: white;
  }

  .ba-case {
    display: none;
  }

  .ba-case.active {
    display: block !important;
    opacity: 1 !important;
  }


  /* Hedaer */
  #main-header {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }

  #main-header .logo img{
    width: 80%;
  }

  
  /* Страничка формы */
  
  #header-logo img {
    width: 90%;
  }

  .main-header-visible {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
    margin-bottom: 0 !important;
  }
  .main-header-visible .phone img{
    width: 10% !important;
  }

  .main-header-visible-container {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }

  #order-main-container {
    border-radius: 0 !important;
    max-width: max-content !important;
  }

  #order-main-services-block {
    flex-wrap: wrap !important;
  }

  .additional-services-block-text {
    font-size: 10px;
    line-height: 11px;
    width: 40% !important;
    padding-left: 0 !important
  }

  .additional-services-block-text-extra {
    font-size: 10px;
    line-height: 11px;
    width: 35% !important;
    flex: none !important;
    padding-left: 0 !important
  }

  .plus-minus-btn {
    padding-left: 0 !important
  }

  .additional-services-block-count {
    font-size: 14px;
    line-height: 17px;
  }

  .nested-button {
    font-size: 8px;
    line-height: 9px;
  }

  #additional-services-container {
    max-height: 320px;
  }

  #price-contant-form {
    margin-left: 0 !important;
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }

  .order-footer {
    margin-top: 0 !important;
  }

}


/*admin order create*/

/* Макет страницы */
.page-layout {
  display: flex;
  gap: 20px;
  margin-bottom: 20px;
  }
  
  .order-form-section {
  flex: 2;
  background: #f8f9fa;
  padding: 20px;
  border-radius: 8px;
  max-width: 50%;
  }
  
  .memo-section {
  flex: 1;
  min-width: 300px;
  }
  
  /* Стили для памятки */
  .memo-content {
  font-size: 14px;
  line-height: 1.5;
  }
  
  .memo-content h5 {
  color: #333;
  margin: 15px 0 8px 0;
  font-size: 16px;
  font-weight: 600;
  }
  
  .memo-content h5:first-child {
  margin-top: 0;
  }
  
  .memo-content ul {
  margin: 8px 0 15px 0;
  padding-left: 20px;
  }
  
  .memo-content li {
  margin-bottom: 5px;
  color: #555;
  }
  
  .memo-content p {
  margin: 5px 0;
  color: #555;
  }
  
  .memo-content strong {
  color: #333;
  }
  
  /* Адаптивность для мобильных устройств */
  @media (max-width: 768px) {
  .page-layout {
      flex-direction: column;
  }
  
  .memo-section {
      min-width: auto;
      max-width: none;
  }
  }
  
  /* Общие стили для всех виджетов */
  .form-widget {
  margin: 20px 0;
  padding: 15px;
  border: 1px solid #ddd;
  border-radius: 8px;
  background: #f8f9fa;
  }
  
  .widget-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  }
  
  .widget-header h4 {
  margin: 0;
  color: #333;
  font-size: 16px;
  font-weight: 600;
  }
  
  .widget-content {
  background: white;
  border-radius: 6px;
  padding: 10px;
  border: 1px solid #e0e0e0;
  }
  
  .form-row {
  display: flex;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid #f0f0f0;
  }
  
  .form-row:last-child {
  border-bottom: none;
  }
  
  .form-label {
  flex: 1;
  font-weight: 500;
  color: #333;
  }
  
  .form-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  }
  
  .form-control {
  padding: 6px 10px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  width: 100%;
  box-sizing: border-box;
  }
  
  .form-control:focus {
  outline: none;
  border-color: #007bff;
  box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);
  }
  
  textarea.form-control {
  resize: vertical;
  min-height: 60px;
  }
  
  .btn {
  padding: 6px 12px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
  text-decoration: none;
  display: inline-block;
  transition: all 0.2s;
  }
  
  .btn-primary {
  background-color: #007bff;
  color: white;
  }
  
  .btn-primary:hover {
  background-color: #0056b3;
  }
  
  .btn-outline-primary {
  background-color: transparent;
  color: #007bff;
  border: 1px solid #007bff;
  }
  
  .btn-outline-primary:hover {
  background-color: #007bff;
  color: white;
  }
  
  .btn-danger {
  background-color: #dc3545;
  color: white;
  }
  
  .btn-danger:hover {
  background-color: #c82333;
}

.btn-warning {
  background-color: #ffc107;
  color: #212529;
}

.btn-warning:hover {
  background-color: #e0a800;
  color: #212529;
}

.btn-success {
  background-color: #28a745;
  color: white;
}

.btn-success:hover {
  background-color: #1e7e34;
  color: white;
}

.btn-sm {
  padding: 4px 8px;
  font-size: 12px;
}
  
  /* Специфичные стили для виджета дополнительных услуг */
  .service-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px;
  margin: 5px 0;
  background: white;
  border-radius: 4px;
  border: 1px solid #e0e0e0;
  }
  
  .service-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  }
  
  .service-count {
  width: 80px;
  }
  
  /* Модальное окно */
  .modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  }
  
  .modal-content {
  background: white;
  border-radius: 8px;
  width: 90%;
  max-width: 500px;
  max-height: 80vh;
  overflow: hidden;
  }
  
  .modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px;
  border-bottom: 1px solid #e0e0e0;
  }
  
  .modal-header h5 {
  margin: 0;
  }
  
  .modal-header .close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: #666;
  }
  
  .modal-body {
  padding: 15px;
  }
  
  .service-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px;
  border-bottom: 1px solid #f0f0f0;
  }
  
  .service-item:last-child {
  border-bottom: none;
  }
  
  .service-info {
  flex: 1;
  }
  
  .service-info small {
  display: block;
  color: #666;
  margin-top: 2px;
  }
  
  /* Стили для календаря */
  .fc-event {
  font-size: 13px !important;
  padding: 4px 8px !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  border: 2px solid !important;
}
  
  /* Статусы заказов */
  .fc-event.status-new {
  background-color: #ffc107 !important;
  border-color: #e0a800 !important;
  color: #212529 !important;
}

.fc-event.status-cancelled {
  background-color: #dc3545 !important;
  border-color: #c82333 !important;
  color: white !important;
}

.fc-event.status-confirmed {
  background-color: #17a2b8 !important;
  border-color: #138496 !important;
  color: white !important;
}

.fc-event.status-confirmed-no-employees {
  background-color: rgba(23, 162, 184, 0.7) !important;
  border-color: #138496 !important;
  color: #333 !important;
}

.fc-event.status-completed {
  background-color: #28a745 !important;
  border-color: #1e7e34 !important;
  color: white !important;
}

.fc-event.status-overdue {
  background-color: #dc3545 !important;
  border-color: #c82333 !important;
  color: white !important;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0% { opacity: 1; }
  50% { opacity: 0.7; }
  100% { opacity: 1; }
}

.fc-event.status-default {
  background-color: #6c757d !important;
  border-color: #545b62 !important;
  color: white !important;
}
  
  .fc-event:hover {
  opacity: 0.8 !important;
  transform: scale(1.02) !important;
  transition: all 0.2s ease !important;
  }
  
  /* Стили для дополнительной информации в карточках событий */
  .fc-event-address,
  .fc-event-service,
  .fc-event-employees {
  font-size: 10px !important;
  opacity: 0.8 !important;
  margin-top: 2px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1.2 !important;
  }
  
  .fc-event-service {
  color: #007bff !important;
  font-weight: 500 !important;
  }
  
  .fc-event-employees {
  color: #007bff !important;
  font-weight: 500 !important;
  }
  
  .fc-toolbar {
  background-color: #f8f9fa !important;
  padding: 10px !important;
  border-radius: 6px !important;
  }
  
  .fc-daygrid-day {
  min-height: 100px !important;
  }
  
  /* Улучшенные стили для временной сетки */
  .fc-timegrid-slot {
  height: 30px !important;
  }
  
  .fc-timegrid-slot-label {
  font-size: 11px !important;
  color: #666 !important;
  }
  
  /* Стили для модального окна */
  .order-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  }
  
  .order-modal-content {
  background: white;
  border-radius: 8px;
  width: 90%;
  max-width: 600px;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  }
  
  .order-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
  border-bottom: 1px solid #e0e0e0;
  background: #f8f9fa;
  border-radius: 8px 8px 0 0;
  }
  
  .order-modal-header h3 {
  margin: 0;
  color: #333;
  font-size: 18px;
  }
  
  .order-modal-close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: #666;
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background-color 0.2s;
  }
  
  .order-modal-close:hover {
  background-color: #e0e0e0;
  }
  
  .order-modal-body {
  padding: 20px;
  }
  
  .order-detail-row {
  display: flex;
  margin-bottom: 12px;
  align-items: flex-start;
  }
  
  .order-detail-label {
  font-weight: 600;
  color: #333;
  min-width: 120px;
  margin-right: 15px;
  }
  
  .order-detail-value {
  flex: 1;
  color: #555;
  }
  
  .order-detail-value.status-confirmed {
  color: #28a745;
  font-weight: 600;
  }
  
  .order-detail-value.status-cancelled {
  color: #dc3545;
  font-weight: 600;
  }
  
  .order-detail-value.status-pending {
  color: #ffc107;
  font-weight: 600;
  }
  
  /* Стили для расписания сотрудников */
  .schedule-loading {
  text-align: center;
  color: #666;
  padding: 20px;
  }
  
  .schedule-day {
  margin-bottom: 15px;
  border-bottom: 1px solid #f0f0f0;
  padding-bottom: 10px;
  }
  
  .schedule-day:last-child {
  border-bottom: none;
  margin-bottom: 0;
  }
  
  .schedule-day-title {
  font-weight: 600;
  color: #333;
  margin-bottom: 8px;
  font-size: 14px;
  }
  
  .schedule-employee {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0;
  font-size: 12px;
  }
  
  .schedule-employee-name {
  color: #555;
  flex: 1;
  }
  
  .schedule-employee-time {
  color: #007bff;
  font-weight: 500;
  font-size: 11px;
  }
  
  .schedule-no-employees {
  color: #999;
  font-style: italic;
  font-size: 12px;
  text-align: center;
  padding: 10px;
  }
  
  /* Стили для календаря внутри виджета */
  .widget-content #calendar {
  border: none;
  background: transparent;
  }
  
  .widget-content .fc {
  border: none;
  }
  
  .widget-content .fc-toolbar {
  background: transparent !important;
  padding: 0 0 10px 0 !important;
  }
  
  /* Стили для расчетных полей */
  .calculation-field {
  background: #e8f5e8 !important;
  border-color: #28a745 !important;
  color: #155724 !important;
  font-weight: 600;
  }
  
  .calculation-field:focus {
  border-color: #28a745 !important;
  box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.25) !important;
  }