body { font-family: 'AvenirNextCyr', 'Montserrat', Arial, sans-serif; font-weight: 400; background: #f6f9fa; color:#252525; overflow-x: hidden;}
.swoopex-yellow { color: #FFE221 !important; }
.swoopex-bg-yellow { background:#FFE221 !important; color: #252525 !important; }
.swoopex-black { color: #252525 !important;}
.swoopex-bg-black { background: #252525 !important; color:#FFE221 !important;}
.swoopex-btn { background: #FFE221; color: #252525; font-weight:700; border-radius:10px; border:none; transition:.15s;}
.swoopex-btn:hover {background:#ffe966; color: #252525;}
.uk-navbar-container { background: #fff; box-shadow: 0 2px 12px rgba(255,226,33,0.07);}
.logo { font-weight: 700; font-size: 2rem; letter-spacing: -1px;}
.hero-section { min-height: 60vh; display: flex; align-items: center; justify-content: center; background: url('./images/bg_group.webp') center/cover, linear-gradient(90deg,#FFE221 0%,#252525 100%); color:#252525; text-align:center; position:relative; overflow:hidden;}
.hero-section svg { position:absolute; left:0; bottom:-1px; width:100%; pointer-events:none; z-index:0;}
.hero-content { z-index: 2; position: relative;}
.hero-title { font-size:3rem; font-weight:700; margin-bottom: 10px; letter-spacing:-2px;}
.hero-subtitle { font-size:1.4rem; font-weight:400; margin-bottom:24px;}

.scroll-indicator {
  position: fixed;
  top: 0;
  left: 0;
  height: 4px;
  background: linear-gradient(90deg, #FFE221, #FFD700, #FFA500);
  z-index: 9999;
  transition: width 0.1s ease;
  width: 0%;
}

.floating-btn {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #FFE221;
  color: #252525;
  border: none;
  box-shadow: 0 4px 20px rgba(255, 226, 33, 0.4);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
}

.floating-btn:hover {
  transform: scale(1.1) rotate(5deg);
  box-shadow: 0 8px 30px rgba(255, 226, 33, 0.6);
}

.floating-btn:active {
  transform: scale(0.95);
}

.swoopex-btn-xl {
  padding:18px 44px; 
  font-size:1.3rem; 
  color: #FFE221;
  margin-top:10px;
  background:#000000;
}
.swoopex-btn-xl:hover {
  background:#252525;
  color: #FFE221;
}

.order-submit-btn {
  padding:18px 44px; 
  font-size:1.3rem; 
  color: #252525;
  margin-top:10px;
  background:#FFE221;
}
.order-submit-btn:hover {
  background:#ffe966;
  color: #252525;
}

.form-card { background:#fff; padding:36px; max-width:100vw; width: 100%; box-sizing: border-box;}
.order-section { background:#fff; padding: 20px 0; }
.service-grid { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; align-items:stretch;}
.service-btn { 
  display:flex; 
  flex-direction:row; 
  align-items:center; 
  justify-content:flex-start; 
  background:#ffffff; 
  border:2px solid #e5e7eb; 
  border-radius:10px; 
  width: clamp(200px, 35vw, 300px);
  height: clamp(80px, 15vw, 100px);
  font-weight:600; 
  font-size: clamp(0.9rem, 1.8vw, 1.2rem);
  cursor:pointer; 
  box-shadow:0 2px 6px rgba(255,226,33,0.06); 
  transition: all 0.3s ease;
  opacity: 1;
  color: #252525;
  position: relative;
  padding: 8px;
  gap: 8px;
}
.service-btn.selected { 
  background:#fefce8; 
  border-color:#FFE221; 
  color:#252525;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}
.service-btn img { 
  width: clamp(40px, 8vw, 60px); 
  height: clamp(40px, 8vw, 60px); 
  flex-shrink: 0;
  margin: 0;
}

.service-btn-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex-grow: 1;
  min-width: 0;
  padding-right: 50px;
}

.service-btn-title {
  font-weight: 600;
  font-size: clamp(0.85rem, 1.6vw, 1rem);
  color: #252525;
  margin: 0;
  line-height: 1.2;
  word-wrap: break-word;
  word-break: break-word;
}

.service-btn-desc { 
  font-size: clamp(0.7rem, 1.2vw, 0.8rem); 
  color: #666; 
  margin-top: 3px;
  line-height: 1.1;
  opacity: 0.8;
  word-wrap: break-word;
  word-break: break-word;
}

.service-btn-counter-controls {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.service-btn.selected .service-btn-counter-controls {
  opacity: 1;
}

.service-btn-counter-btn {
  width: 36px;
  height: 36px;
  border-radius: 6px;
  border: 2px solid #252525;
  background: #fff;
  color: #252525;
  font-weight: 700;
  font-size: 18px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  user-select: none;
}

.service-btn-counter-btn:hover {
  background: #252525;
  color: #FFE221;
}

.service-btn-counter-display {
  font-size: 16px;
  font-weight: 700;
  color: #252525;
  min-width: 24px;
  text-align: center;
}

.service-btn .service-price {
  font-size: clamp(0.8rem, 1.5vw, 1rem);
  font-weight: 700;
  color: #252525;
  margin-top: auto;
}

.service-duration {
  font-size: clamp(0.6rem, 1vw, 0.75rem);
  color: #666;
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
}

.service-duration-icon {
  width: 12px;
  height: 12px;
  opacity: 0.7;
}

.service-btn-title {
  text-align: left;
}

.service-btn-desc {
  text-align: left;
}
.order-summary { 
  background:#fffbe6; 
  padding:16px;   border-radius:14px; 
  font-size:1.1rem; 
  margin:16px 0 18px;
  transition: opacity 0.3s ease;
}
.swoopex-input { 
  border-radius:8px;
  height: 60px;
  font-size: 1.67rem;
  font-weight: 700;
  padding: 0 16px;
}
.success-modal, .sms-modal { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(37,37,37,.88); display:flex; flex-direction:column; align-items:center; justify-content:center; z-index:2000; padding:20px; box-sizing:border-box;}
.success-modal-content, .sms-modal-content { background:#fff; border-radius:18px; padding:34px 24px; max-width:400px; width:100%; text-align:center; color:#252525; position:relative; box-sizing:border-box;}
.sms-modal-close { position:absolute; top:12px; right:16px; background:none; border:none; font-size:24px; color:#999; cursor:pointer; width:30px; height:30px; display:flex; align-items:center; justify-content:center; border-radius:50%; transition:all 0.2s ease;}
.sms-modal-close:hover { background:#f5f5f5; color:#333; transform:scale(1.1);}
.sms-phone-display { font-size:0.9rem; color:#666; margin-bottom:12px; }
.sms-code-fields {display:flex; justify-content:center; gap:10px; margin:12px 0;}
.sms-code-field { width:38px; height:48px; font-size:2.1rem; text-align:center; border:2px solid #FFE221; border-radius:8px;}
.hide {display:none;}
.uk-input, .uk-select, .uk-textarea {
  border-radius:8px;
  height: 60px;
  font-size: 1.67rem;
  font-weight: 700;
  padding: 0 16px;
}
.address-suggestions {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: white;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  z-index: 1000;
  max-height: 200px;
  overflow-y: auto;
}

.address-suggestion {
  padding: 12px;
  cursor: pointer;
  border-bottom: 1px solid #eee;
  transition: background-color 0.2s ease;
}

.address-suggestion:hover {
  background-color: #f5f5f5;
}

.address-suggestion:last-child {
  border-bottom: none;
}

.phone-input-wrapper {
  display: flex;
  gap: 8px;
}

.country-code-select {
  flex: 0 0 150px;
  border-radius: 8px;
  border: 2px solid #e5e5e5 !important;
  height: 60px !important;
  min-height: 60px;
  max-height: 60px;
  font-size: 1.67rem;
  font-weight: 700;
  padding: 0 12px;
  box-sizing: border-box;
  line-height: 1.2;
  margin-right: 4px;
  background: #fff !important;
}

.phone-number-input {
  flex: 1;
  border-radius: 8px;
  border: 2px solid #e5e5e5 !important;
  height: 60px !important;
  min-height: 60px;
  max-height: 60px;
  min-width: 180px;
  box-sizing: border-box;
  padding: 0 16px !important;
  background: #fff !important;
}

.country-code-select:focus {
  border: 2px solid #FFE221;
}

.phone-number-input:focus {
  border: 2px solid #FFE221;
}

.uk-form-danger {
  border-color: #f0506e !important;
}

.uk-form-success {
  border-color: #C6DC00 !important;
}

.validation-message {
  font-size: 0.875rem;
  margin-top: 4px;
  color: #f0506e;
}

.validation-message.success {
  color: #C6DC00;
}

.uk-input::placeholder, .uk-select::placeholder, .uk-textarea::placeholder,
.swoopex-input::placeholder {
  font-size: 1.67rem;
  font-weight: 700;
  opacity: 0.6;
}

@media (max-width:768px){
  .form-card {padding:10px;}
  .order-step {padding:18px 2vw;}
  
  .service-btn { 
    width: clamp(280px, 90vw, 350px);
    height: clamp(70px, 12vw, 90px);
    font-size: clamp(0.8rem, 2vw, 1rem);
    padding: 6px;
    gap: 6px;
  }
  .service-btn img {
    width: clamp(32px, 6vw, 45px);
    height: clamp(32px, 6vw, 45px);
  }
  .service-btn-title {
    font-size: clamp(0.8rem, 1.8vw, 0.95rem);
  }
  .service-btn-desc {
    font-size: clamp(0.65rem, 1.4vw, 0.75rem);
  }
  .service-duration {
    font-size: clamp(0.55rem, 1vw, 0.65rem);
    gap: 3px;
  }
  .service-duration-icon {
    width: 10px;
    height: 10px;
  }
  .service-btn-counter-controls {
    right: 4px;
    gap: 4px;
  }
  .service-btn-counter-btn {
    width: 30px;
    height: 30px;
    font-size: 16px;
  }
  .service-btn-counter-display {
    font-size: 14px;
    min-width: 20px;
  }
  
  .service-btn-content {
    padding-right: 40px;
  }
}
.order-form-grid {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 4vw, 60px);
  max-width: 3840px;
  margin: 0 auto;
  padding: 20px 8px;
  box-sizing: border-box;
}
@media (min-width: 1201px) {
  .order-form-grid {
    display: grid;
    grid-template-columns: 1fr minmax(250px, 30%);
    gap: clamp(20px, 4vw, 60px);
    align-items: stretch;
  }
  .summary-column {
    min-width: 250px;
  }
  .summary-sticky {
    position: sticky;
    top: 20px;
    z-index: 10;
    background: #fff;
    border-radius: clamp(12px, 2vw, 20px);
    box-shadow: 0 4px 20px rgba(255,226,33,.1);
    padding: clamp(12px, 2.5vw, 24px);
    border: 2px solid #FFE221;
    box-sizing: border-box;
  }
}
@media (max-width: 1200px) {
  .order-form-grid {
    display: flex;
    flex-direction: column;
  }
  .summary-sticky {
    position: static;
    background: none;
    border: none;
    box-shadow: none;
    padding: 0;
    outline: none;
  }
}

.summary-column {
  flex: 0 0 30% !important;
  min-width: 250px;
}
.summary-sticky {
  position: -webkit-sticky;
  position: sticky;
  top: 20px;
  z-index: 10;
  background: #fff;
  border-radius: clamp(12px, 2vw, 20px);
  box-shadow: 0 4px 20px rgba(255,226,33,.1);
  padding: clamp(12px, 2.5vw, 24px);
  border: 2px solid #FFE221;
  box-sizing: border-box;
}
@media (max-width: 1200px) {
  .summary-sticky {
    position: static;
    background: none;
    border: none;
    box-shadow: none;
    padding: 0;
    outline: none;
  }
}

#step-1 { order: 1; }
#step-2 { order: 2; }
#step-3 { order: 3; }
#step-4 { order: 4; }
.summary-column { order: 5; }

@media (min-width: 1200px) {
  .order-form-grid {
    flex-direction: row;
    align-items: flex-start;
  }
  .form-steps-column {
    flex: 1 1 0;
    order: 1;
  }
  .summary-column {
    flex: 0 0 30%;
    min-width: 250px;
    order: 2;
  }
  .summary-sticky {
    position: sticky;
    top: 20px;
    z-index: 10;
  }
  .summary-sticky-inner {
    background: #fff;
    border-radius: clamp(12px, 2vw, 20px);
    box-shadow: 0 4px 20px rgba(255,226,33,.1);
    padding: clamp(12px, 2.5vw, 24px);
    border: 2px solid #FFE221;
    box-sizing: border-box;
  }
}

@media (max-width: 1200px) {
  .summary-column {
    position: static;
  }
  .summary-sticky-inner {
    background: none;
    border: none;
    box-shadow: none;
    padding: 0;
  }
}

.order-step {
  background:#fff;
  border-radius:16px;
  box-shadow: 0 2px 16px rgba(255,226,33,.07);
  padding: 24px 16px;
  min-width:0;
  min-height:200px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
}
.calendar-time-row {
  display: flex;
  gap: 32px;
  margin-bottom: 24px;
}

.calendar-section {
  flex: 1;
  min-width: 0;
}

.time-section {
  flex: 1;
  min-width: 0;
}

@media (max-width: 1600px) {
  .calendar-time-row {
    flex-direction: column;
    gap: 16px;
  }
}

.calendar-wrap { margin: 18px 0 18px 0; }
.calendar-header { display:flex; align-items:center; justify-content:center; gap:20px; margin-bottom:16px; }
.calendar-nav { 
  width: 60px;
  height: 60px;
  background: #fff;
  border: 2px solid #f0f0f0;
  border-radius: 50%;
  font-size: 1.5rem;
  color: #252525;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  font-weight: 700;
}
.calendar-nav:hover { 
  background: #fffbe6;
  border-color: #FFE221;
}
#calendar-month-name {
  font-weight: 700;
  font-size: 1.5rem;
  color: #252525;
  min-width: 200px;
  text-align: center;
}
.calendar-table { display:grid; grid-template-columns:repeat(7,76px); gap:8px; justify-content: center; }
.calendar-day { 
  width: 76px; 
  height: 66px; 
  display:flex; 
  flex-direction:column; 
  align-items:center; 
  justify-content:center; 
  border-radius:12px; 
  cursor:pointer; 
  background:#ffffff; 
  border:2px solid #e5e7eb; 
  position:relative;
  font-weight: 700;
  font-size: 1.5rem;
  color: #252525;
  transition: all 0.3s ease;
  opacity: 1;
}
.calendar-day.unavailable { 
  opacity:.4; 
  pointer-events:none; 
  background:#f8f8f8;
  color: #999;
}
.calendar-day.selected { 
  background:#fefce8; 
  border-color:#FFE221; 
  color:#252525; 
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}
.calendar-day.calendar-weekday {
  background: none !important;
  border: none !important;
  cursor: default !important;
  opacity: 0.7 !important;
  font-weight: 600;
  color: #666;
  font-size: 1.2rem;
}
.calendar-day .discount-label { 
  position: static;
  background: #C6DC00; 
  color: #252525; 
  font-size: .7rem; 
  font-weight: 700;
  padding: 1px 4px; 
  border-radius: 4px;
  margin-bottom: -2px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}
.calendar-day .today-label { 
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
  font-size: .6rem; 
  font-weight: 600;
  color: #666;
  text-transform: lowercase;
  opacity: 0.8;
  white-space: nowrap;
}
.old-price {
  text-decoration: line-through;
  color: #888;
  font-size: 0.85em;
  transition: all 0.2s ease;
}
.new-price {
  color: #00a651;
  font-weight: 600;
  transition: all 0.2s ease;
  margin-left: 4px;
}
#order-time-wrap {
  transition: all 0.3s ease;
  opacity: 1;
  transform: translateY(0);
}
.order-time-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 12px;
  justify-content: center;
}
.time {
  background: #ffffff;
  border: 2px solid #e5e7eb;
  border-radius: 12px;
  min-width: 64px;
  min-height: 44px;
  margin-bottom: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 10px;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  font-weight: 600;
  opacity: 1;
  transform: scale(1);
}

.time-slot {
  justify-content: center;
  min-width: 64px;
}

.time-slot .time-text {
  font-weight: 700;
  font-size: 1.25em;
  color: #252525;
}

.time.selected {
  background:#fefce8; 
  border-color:#FFE221; 
  color:#252525;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}
.time .hours { font-weight:700; font-size:1.25em; display:inline; color: #252525; }
.time .minutes { font-weight:600; font-size:1.1em; color:#666; display:inline;}
.available-minutes {
  display: flex; gap: 4px; margin-top: 4px;
}

.time.disabled { 
  opacity: 0.4; 
  background: #f5f5f5;
  border-color: #ddd;
  color: #999;
}
.time.disabled .hours {
  pointer-events: none;
}
.time.disabled .available-minutes {
  pointer-events: auto;
}
.time-whithout-minutes {
  padding: 8px 16px;
  min-width: 160px;
  font-size: 1.05em;
  font-weight: 600;
  color: #252525;
  background: #ffffff;
  border: 2px solid #e5e7eb;
  transition: all 0.3s ease;
  opacity: 1;
  transform: scale(1);
}
.time-whithout-minutes.selected { 
  background:#fefce8; 
  border-color:#FFE221; 
  color:#252525; 
  transform: scale(1.02);
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}
.name-phone-row {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 16px;
  align-items: start;
}

@media (max-width: 768px) {
  .name-phone-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

@media (max-width: 480px) {
  .phone-number-input {
    min-width: 80px;
  }
  
  .country-code-select {
    flex: 0 0 60px;
  }
  
  .time {
    padding: 3px 5px;
    font-size: 0.75rem;
    min-width: 28px;
    min-height: 18px;
  }
  
  .time-slot {
    min-width: 28px;
  }
  
  .time-slot .time-text {
    font-size: 0.8em;
  }
  
  .time .hours {
    font-size: 0.8em;
  }
  
  .time .minutes {
    font-size: 0.7em;
  }
  
  .time-whithout-minutes {
    padding: 3px 6px;
    min-width: 70px;
    font-size: 0.75em;
  }
  
  .order-time-row {
    gap: 4px;
  }
  
  .uk-input, .uk-select, .swoopex-input {
    height: 26px;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0 6px;
  }
  
  .uk-textarea {
    min-height: calc(0.75rem * 2 + 12px) !important;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 6px;
  }
  
  .country-code-select {
    height: 26px !important;
    min-height: 26px;
    max-height: 26px;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0 4px;
    flex: 0 0 60px;
  }
  
  .phone-number-input {
    height: 26px !important;
    min-height: 26px;
    max-height: 26px;
    min-width: 80px;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0 6px !important;
  }
  
  .uk-input::placeholder, .uk-select::placeholder, .uk-textarea::placeholder,
  .swoopex-input::placeholder {
    font-size: 0.75rem;
    font-weight: 600;
  }
}

@media (max-width: 360px) {
  .phone-number-input {
    min-width: 140px;
  }
  
  .country-code-select {
    flex: 0 0 100px;
  }
}

.address-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.address-secondary-grid {
  display: grid;
  grid-template-columns: 1.5fr 1.5fr 0.6fr 0.6fr;
  gap: 12px;
}

.address-grid > div,
.address-secondary-grid > div {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.address-secondary-grid label {
  margin-bottom: 4px;
}

@media (max-width: 768px) {
  .address-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
    .address-secondary-grid {
    grid-template-columns: 1.5fr 0.6fr;
    gap: 12px;
  }
}

@media (max-width: 480px) {
  .address-secondary-grid {
    grid-template-columns: 1fr;
  }
}

.address-secondary-grid .uk-input {
  font-size: 1.2rem;
  padding: 0 12px;
}

.service-btn.selected .service-content-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  padding: 12px 8px 8px 8px;
}

.service-btn.selected .service-name {
  font-weight: 700;
  font-size: 1.2rem;
  text-align: center;
  margin-bottom: 4px;
  color: #252525;
}

.service-counter-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 1.5vw, 12px);
  padding: 0;
  margin: 0 0 10px 0;
  flex-wrap: nowrap;
  top: 4px !important;
}

.counter-btn {
  width: clamp(36px, 6vw, 54px);
  height: clamp(36px, 6vw, 54px);
  min-width: clamp(36px, 6vw, 54px);
  min-height: clamp(36px, 6vw, 54px);
  max-width: clamp(36px, 6vw, 54px);
  max-height: clamp(36px, 6vw, 54px);
  border-radius: 10%;
  border: 2px solid #252525;
  background: #fff;
  color: #252525;
  font-weight: 900;
  font-size: clamp(1rem, 2vw, 1.4rem);
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex-shrink: 0;
  flex-grow: 0;
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  outline: none;
  text-decoration: none;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  white-space: nowrap;
  overflow: hidden;
}

.counter-btn:hover {
  background: #252525;
  color: #FFE221;
  transform: scale(1.05);
}

.counter-btn:active {
  transform: scale(0.95);
}

.counter-display {
  font-size: clamp(1.2rem, 2.2vw, 1.5rem);
  font-weight: 700;
  color: #252525;
  min-width: clamp(32px, 4vw, 40px);
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.uk-textarea {
  height: auto !important;
  min-height: calc(1.67rem * 2 + 32px) !important;
  resize: none !important;
  overflow-y: auto;
  line-height: 1.4;
}

.service-btn span {
  text-align: center;
  width: 100%;
  line-height: 1.3;
}

@media (max-width: 768px) {
  .counter-btn {
    width: clamp(32px, 5vw, 48px);
    height: clamp(32px, 5vw, 48px);
    min-width: clamp(32px, 5vw, 48px);
    min-height: clamp(32px, 5vw, 48px);
    max-width: clamp(32px, 5vw, 48px);
    max-height: clamp(32px, 5vw, 48px);
    font-size: clamp(0.9rem, 1.8vw, 1.3rem);
  }
  
  .service-counter-controls {
    gap: clamp(6px, 1.2vw, 10px);
  }
  
  .counter-display {
    font-size: clamp(1.1rem, 2vw, 1.3rem);
    min-width: clamp(28px, 3.5vw, 36px);
  }
}

@media (max-width: 480px) {
  .counter-btn {
    width: clamp(28px, 4vw, 44px);
    height: clamp(28px, 4vw, 44px);
    min-width: clamp(28px, 4vw, 44px);
    min-height: clamp(28px, 4vw, 44px);
    max-width: clamp(28px, 4vw, 44px);
    max-height: clamp(28px, 4vw, 44px);
    font-size: clamp(0.8rem, 1.5vw, 1.2rem);
  }
  
  .service-counter-controls {
    gap: clamp(4px, 1vw, 8px);
  }
  
  .counter-display {
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    min-width: clamp(24px, 3vw, 32px);
  }
}

#step-5 {
  text-align: center;
}

#step-5 .order-summary {
  margin-bottom: 24px;
}

@media (min-width: 900px) {
  #step-5 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
  }
  
  #step-5 .order-summary {
    max-width: 600px;
    margin: 0 auto 24px auto;
  }
}

.payment-section {
  margin: 24px 0;
  text-align: center;
}

.payment-buttons {
  display: flex;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 12px;
  width: 100%;
}

.pay-type-btn {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  border: 2px solid #e5e7eb;
  border-radius: 16px;
  flex: 1;
  min-width: 0;
  height: 100px;
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(255,226,33,0.06);
  transition: all 0.3s ease;
  opacity: 1;
  transform: scale(1);
  color: #252525;
  text-decoration: none;
  padding: 8px;
}

.pay-type-btn.selected {
  background: #fefce8;
  border-color: #FFE221;
  color: #252525 !important;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}

.pay-icon {
  font-size: 1.8rem;
  margin-bottom: 6px;
  display: block;
}

.pay-text {
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.2;
}

@media (max-width: 768px) {
  .payment-buttons {
    gap: 8px;
  }
  
  .pay-type-btn {
    height: 85px;
    font-size: 0.8rem;
  }
  
  .pay-icon {
    font-size: 1.5rem;
    margin-bottom: 4px;
  }
  
  .pay-text {
    font-size: 0.8rem;
  }
}

@media (max-width: 480px) {
  .payment-buttons {
    gap: 6px;
    flex-direction: row;
    justify-content: center;
  }
  
  .pay-type-btn {
    height: 75px;
    font-size: 0.75rem;
  }
  
  .pay-icon {
    font-size: 1.3rem;
    margin-bottom: 3px;
  }
  
  .pay-text {
    font-size: 0.75rem;
  }
}

#extra-services {
  transition: all 0.3s ease;
}

.extra-services-group {
  margin-bottom: 24px;
}

.extra-services-group:last-child {
  margin-bottom: 0;
}

.extra-services-group-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: #252525;
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 2px solid #FFE221;
  text-align: center;
}

.extra-services-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 10px;
  justify-content: center;
}

@media (pointer: coarse) {
  .calendar-day {
    min-height: 54px;
    min-width: 54px;
  }
  
  .time {
    min-height: 44px;
    padding: 12px 16px;
  }
  
  .service-card {
    min-height: 120px;
  }
}

.swoopex-btn:active,
.property-type-btn:active,
.kitchen-type-btn:active,
.room-counter-btn:active,
.calendar-nav:active,
.calendar-day:active,
.time-slot:active,
.pay-type-btn:active,
.time:active {
  transform: scale(0.97);
  transition: transform 0.1s ease;
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-5px); }
  75% { transform: translateX(5px); }
}

.uk-form-danger {
  animation: shake 0.3s ease-in-out;
  border-color: #f0506e !important;
  box-shadow: 0 0 0 3px rgba(240, 80, 110, 0.1);
}

.uk-form-success {
  border-color: #32d296 !important;
  box-shadow: 0 0 0 3px rgba(50, 210, 150, 0.1);
}

.uk-notification {
  animation: slideInFromTop 0.3s ease-out;
}

@keyframes slideInFromTop {
  from {
    transform: translateY(-100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.sms-modal:not(.hide),
.success-modal:not(.hide) {
  animation: fadeInModal 0.3s ease-out;
}

@keyframes fadeInModal {
  from {
    opacity: 0;
    transform: scale(0.9);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.sms-modal-content,
.success-modal-content {
  animation: slideUpModal 0.3s ease-out;
}

@keyframes slideUpModal {
  from {
    transform: translateY(50px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.loading {
  animation: pulse 1.5s ease-in-out infinite;
}

.address-suggestions {
  animation: slideDown 0.2s ease-out;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 600px) {
  .hero-section {
    min-height: 70vh;
  }
  
  .order-step {
    padding: 20px 15px;
  }
    .calendar-grid {
    gap: 8px;
  }
  
  .calendar-table {
    grid-template-columns: repeat(7, 50px);
    gap: 10px;
  }
  
  .calendar-day {
    width: 45px;
    height: 54px;
    font-size: 1.2rem;
  }
  
  .service-cards {
    gap: 15px;
  }
  
  .order-time-row {
    gap: 6px;
  }
  
  .time {
    padding: 4px 6px;
    font-size: 0.8rem;
    min-width: 32px;
    min-height: 22px;
  }
  
  .time-slot {
    min-width: 32px;
  }
  
  .time-slot .time-text {
    font-size: 0.9em;
  }
  
  .time .hours {
    font-size: 0.9em;
  }
  
  .time .minutes {
    font-size: 0.8em;
  }
  
  .time-whithout-minutes {
    padding: 4px 8px;
    min-width: 80px;
    font-size: 0.8em;
  }
  
  .uk-input, .uk-select, .swoopex-input {
    height: 30px;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0 8px;
  }
  
  .uk-textarea {
    min-height: calc(0.85rem * 2 + 16px) !important;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 8px;
  }
  
  .country-code-select {
    height: 30px !important;
    min-height: 30px;
    max-height: 30px;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0 6px;
    flex: 0 0 85px;
  }
  
  .phone-number-input {
    height: 30px !important;
    min-height: 30px;
    max-height: 30px;
    min-width: 90px;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0 8px !important;
  }
  
  .uk-input::placeholder, .uk-select::placeholder, .uk-textarea::placeholder,
  .swoopex-input::placeholder {
    font-size: 0.85rem;
    font-weight: 600;
  }
}

@media (prefers-color-scheme: dark) {
  :root {
    --text-color: #ffffff;
    --bg-color: #1a1a1a;
    --card-bg: #2d2d2d;
  }
  
  body {
    background-color: var(--bg-color);
    color: var(--text-color);
  }
  
  .service-card {
    background-color: var(--card-bg);
    color: var(--text-color);
  }
}

.service-card:focus,
/* .calendar-day:focus, */
.time:focus,
.swoopex-btn:focus {
  outline: 3px solid #FFE221;
  outline-offset: 2px;
}

@media (pointer: coarse) {
  *:focus {
    outline: none;
  }
}

.required-field::after {
  content: " *";
  color: #e74c3c;
  font-weight: bold;
  font-size: 1.1em;
}

.uk-form-label.required::after {
  content: " *";
  color: #e74c3c;
  font-weight: bold;
  font-size: 1.1em;
}

.required-dot::before {
  content: "●";
  color: #e74c3c;
  font-weight: bold;
  margin-right: 4px;
}

.uk-input.required,
.uk-select.required,
.uk-textarea.required {
  border-left: 4px solid #ddd;
}

.uk-input.required:focus,
.uk-select.required:focus, 
.uk-textarea.required:focus {
  border-left: 4px solid #FFE221;
}

.uk-input.uk-form-danger,
.uk-select.uk-form-danger,
.uk-textarea.uk-form-danger {
  border-left: 4px solid #e74c3c !important;
}

.uk-input.uk-form-success,
.uk-select.uk-form-success,
.uk-textarea.uk-form-success {
  border-left: 4px solid #27ae60 !important;
}

.uk-notification {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 1040;
  box-sizing: border-box;
  max-width: 350px;
}

.uk-notification-message {
  position: relative;
  margin-bottom: 10px;
  padding: 16px 20px;
  background: #fff;
  color: #252525;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.4;
  border-radius: 12px;
  border-left: 4px solid #FFE221;
  box-shadow: 0 4px 16px rgba(255, 226, 33, 0.15);
  font-family: 'AvenirNextCyr', 'Montserrat', Arial, sans-serif;
  animation: slideInNotification 0.3s ease-out;
}

.uk-notification-message-success {
  border-left-color: #27ae60;
  box-shadow: 0 4px 16px rgba(39, 174, 96, 0.15);
}

.uk-notification-message-danger {
  border-left-color: #e74c3c;
  box-shadow: 0 4px 16px rgba(231, 76, 60, 0.15);
}

.uk-notification-message-warning {
  border-left-color: #f39c12;
  box-shadow: 0 4px 16px rgba(243, 156, 18, 0.15);
}

.uk-notification-close {
  position: absolute;
  top: calc(50% - 12px);
  right: 12px;
  width: 24px;
  height: 24px;
  background: rgba(0, 0, 0, 0.05);
  color: #666;
  border: none;
  font-size: 16px;
  font-weight: normal;
  cursor: pointer;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease, color 0.2s ease;
  line-height: 1;
  text-align: center;
}

.uk-notification-close:hover {
  background: rgba(0, 0, 0, 0.15);
  color: #252525;
}

@keyframes slideInNotification {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.room-selectors {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 24px;
}

.room-selector {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fffbe6;
  border: 2px solid #FFE221;
  border-radius: 16px;
  padding: 16px 20px;
  transition: all 0.3s ease;
}

.room-selector:hover {
  box-shadow: 0 4px 12px rgba(255, 226, 33, 0.15);
}

.room-selector-label {
  font-size: 1.1rem;
  font-weight: 600;
  color: #252525;
  margin: 0;
}

.property-type-selector {
  margin-bottom: 24px;
}

.property-type-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.property-type-btn {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  border: 2px solid #e5e7eb;
  border-radius: 16px;
  flex: 1;
  min-width: 0;
  height: 100px;
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(255,226,33,0.06);
  transition: all 0.3s ease;
  opacity: 1;
  transform: scale(1);
  color: #252525;
  text-decoration: none;
  padding: 8px;
}

.property-type-btn:hover {
  border-color: #FFE221;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}

.property-type-btn.active {
  background: #fefce8;
  border-color: #FFE221;
  color: #252525 !important;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}

.property-icon {
  font-size: 2rem;
  margin-bottom: 8px;
  line-height: 1;
}

.property-text {
  font-size: 0.9rem;
  text-align: center;
  line-height: 1.2;
}

.kitchen-type-selector {
  margin-bottom: 24px;
  margin-top: 8px;
}

.kitchen-type-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.kitchen-type-btn {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  border: 2px solid #e5e7eb;
  border-radius: 16px;
  flex: 1;
  min-width: 0;
  height: 100px;
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(255,226,33,0.06);
  transition: all 0.3s ease;
  opacity: 1;
  transform: scale(1);
  color: #252525;
  text-decoration: none;
  padding: 8px;
}

.kitchen-type-btn:hover {
  border-color: #FFE221;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}

.kitchen-type-btn.active {
  background: #fefce8;
  border-color: #FFE221;
  color: #252525 !important;
  box-shadow: 0 4px 12px rgba(255,226,33,0.15);
}

.kitchen-icon {
  font-size: 2rem;
  margin-bottom: 8px;
  line-height: 1;
}

.kitchen-text {
  font-size: 0.9rem;
  text-align: center;
  line-height: 1.2;
}

.room-counter-group {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: flex-start;
  flex-wrap: nowrap;
}

.room-counter-label {
  font-size: 1rem;
  font-weight: 600;
  color: #252525;
  margin: 0;
  white-space: nowrap;
  min-width: fit-content;
}

.room-counter-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: fit-content;
}

.room-counter-btn {
  width: 60px;
  height: 60px;
  background: #fff;
  border: 2px solid #f0f0f0;
  border-radius: 50%;
  font-size: 1.5rem;
  color: #252525;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  font-weight: 700;
  line-height: 1;
}

.room-counter-btn:hover {
  background: #fffbe6;
  border-color: #FFE221;
}

.room-counter-display {
  font-size: 1.2rem;
  font-weight: 600;
  color: #252525;
  min-width: 30px;
  text-align: center;
}

.room-apartment-controls {
  display: flex;
  gap: 32px;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 24px;
  padding: 20px;
  border-radius: 12px;
  max-width: 100%;
  flex-wrap: wrap;
}



.uk-text-bold {
  font-size: 1.5rem;
  font-weight: 700;
  color: #252525;
}

.additional-options {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 20px;
  padding: 16px;
  border-radius: 12px;
  max-width: 100%;
}

.checkbox-option {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  justify-content: space-between;
}

.checkbox-option-label {
  font-size: 1.5rem;
  font-weight: 700;
  color: #252525;
  margin: 0;
  white-space: nowrap;
}

.checkbox-controls {
  display: flex;
  align-items: center;
  position: relative;
}

.custom-checkbox {
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  width: 28px;
  height: 28px;
  background: #fff;
  border: 2px solid #e5e7eb;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.custom-checkbox:checked {
  color: #252525;
  border-color: #FFE221;
  background-size: contain;
  background-image: url("/images/controls/check.svg");
}

.checkbox-label {
  color: #252525;
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
}

@media (max-width: 900px) {
  .room-apartment-controls {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 16px;
  }
  
  .property-type-buttons,
  .kitchen-type-buttons {
    width: 100%;
  }
  
  .room-counter-btn {
    width: 50px;
    height: 50px;
    font-size: 1.3rem;
  }
}
@media (max-width: 600px) {
  .additional-options {
    flex-direction: column;
    gap: 16px;
  }
  
  .room-counter-group {
    width: 100%;
    justify-content: space-between;
  }
  
  .room-counter-label {
    font-size: 0.95rem;
  }
  
  .room-counter-btn {
    width: 45px;
    height: 45px;
    font-size: 1.2rem;
  }
  
  .checkbox-option {
    max-width: none;
  }
}

@media (max-width: 767px) {
  .room-apartment-controls {
    flex-direction: column;
    gap: 16px;
    padding: 12px;
    margin-bottom: 16px;
  }
  
  .additional-options {
    flex-direction: column;
    gap: 16px;
    padding: 12px;
    margin-bottom: 16px;
  }
  
  .room-counter-group {
    width: 100%;
    justify-content: space-between;
  }
  
  .property-type-selector,
  .kitchen-type-selector {
    margin-bottom: 16px;
  }
  
  .property-type-buttons,
  .kitchen-type-buttons {
    flex-direction: column;
    gap: 8px;
  }
  
  .property-type-btn,
  .kitchen-type-btn {
    width: 100%;
    height: 80px;
    font-size: 0.85rem;
  }
  
  .room-counter-btn {
    width: 40px;
    height: 40px;
    font-size: 1.1rem;
  }
  
  .room-counter-group,
  .checkbox-option {
    max-width: 100%;
    justify-content: space-between;
  }
  
  .room-counter-label,
  .checkbox-option-label {
    font-size: 1.2rem;
    white-space: normal;
  }
}

@media (max-width: 900px) {
  .room-apartment-controls {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.room-counter-label,
.checkbox-option-label {
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  font-weight: 700;
  color: #252525;
  margin: 0;
}

@media (max-width: 768px) {
  .room-apartment-controls {
    flex-direction: column;
    gap: 16px;
    padding: 12px;
  }
  
  .additional-options {
    flex-direction: column;
    gap: 16px;
    padding: 12px;
  }
  
  .room-counter-group,
  .checkbox-option {
    padding: 12px;
    border-radius: 8px;
    background: rgba(255, 226, 33, 0.05);
  }
}

.summary-sticky-inner #step-5 {
  background: #fff;
  border-radius: clamp(12px, 2vw, 20px);
  box-shadow: 0 4px 20px rgba(255,226,33,.1);
  padding: clamp(12px, 2.5vw, 24px);
  border: 2px solid #FFE221;
  width: 100%;
  box-sizing: border-box;
}

.summary-sticky-inner .order-summary {
  margin-bottom: clamp(12px, 2vw, 20px);
  font-size: clamp(0.8rem, 1.4vw, 1rem);
  line-height: 1.4;
}

.summary-sticky-inner .payment-section {
  margin-bottom: clamp(12px, 2vw, 20px);
}

.summary-sticky-inner .payment-buttons {
  display: flex;
  gap: clamp(3px, 0.8vw, 6px);
  flex-wrap: nowrap;
}

.summary-sticky-inner .pay-type-btn {
  font-size: clamp(0.85rem, 1.4vw, 1.1rem);
  padding: clamp(6px, 1vw, 12px);
  text-align: center;
  flex: 1;
  min-width: 0;
  height: clamp(40px, 6vw, 60px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
  box-sizing: border-box;
}

.summary-sticky-inner .pay-icon {
  font-size: clamp(1rem, 1.6vw, 1.3rem);
  margin-bottom: clamp(2px, 0.4vw, 4px);
  display: block;
}

.summary-sticky-inner .pay-text {
  font-size: clamp(0.75rem, 1.2vw, 0.95rem);
  display: block;
  font-weight: 600;
}

.summary-sticky-inner .swoopex-btn-xl {
  width: 100%;
  font-size: clamp(0.9rem, 1.5vw, 1.1rem);
  padding: clamp(12px, 2vw, 16px);
  box-sizing: border-box;
}

.order-step {
  padding: clamp(16px, 3vw, 24px);
  border-radius: clamp(12px, 2vw, 18px);
  font-size: clamp(0.9rem, 1.6vw, 1.1rem);
}

.order-step h2,
.order-step h3 {
  font-size: clamp(1.1rem, 2.2vw, 1.4rem);
}

@media (min-width: 1600px) {
  #step-2 {
    gap: clamp(20px, 3vw, 40px);
    align-items: start;
  }
  
  #step-2 .uk-margin:first-child {
    grid-column: 1;
  }
  
  #step-2 .uk-margin:last-child {
    grid-column: 2;
  }
  
  .calendar-wrap {
    margin-bottom: 0;
  }
  
  #order-time-wrap {
    height: auto;
  }
  
  .time {
    padding: clamp(6px, 1vw, 12px);
    margin: clamp(2px, 0.5vw, 4px);
    font-size: clamp(0.85rem, 1.2vw, 1rem);
  }
  
  .order-time-row {
    gap: clamp(4px, 0.8vw, 8px);
  }
}

@media (min-width: 1000px) {
  .order-form-grid {
    align-items: stretch;
  }
}

.summary-sticky .order-submit-btn {
  width: 100%;
  display: block;
  text-align: center;
  margin-top: 24px;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.summary-remove {
  background: none;
  border: none;
  color: #e53935;
  font-size: 0.9rem;
  font-weight: bold;
  cursor: pointer;
  padding: 0 1px;
  line-height: 1;
  outline: none;
  transition: color 0.15s;
}
.summary-remove:hover {
  color: #b71c1c;
}

@media (min-width: 1024px) {
  .checkbox-option {
    justify-content: flex-start;
    gap: 8px;
  }
  
  .checkbox-option-label {
    margin-left: 4px;
    order: 2;
  }
  
  .checkbox-controls {
    order: 1;
  }
}

.uk-container.carousel-wide {
  max-width: 95vw !important;
  width: 95vw !important;
}

/* Before After Carousel Styles */
.before-after-carousel {
  position: relative;
  margin-top: 10px;
  overflow: hidden;
  padding: 10px 0;
  background: #f5f5f5;
}

.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(0, 0, 0, 0.5);
  border: none;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 2px 10px rgba(0,0,0,0.3);
  color: white;
}

.carousel-btn:hover {
  background: rgba(0, 0, 0, 0.7);
  transform: translateY(-50%) scale(1.1);
}

.carousel-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: translateY(-50%) scale(1);
}

.carousel-btn-prev {
  left: 10px;
}

.carousel-btn-next {
  right: 10px;
}

.carousel-container {
  overflow: hidden;
  margin: 0;
  padding: 40px 0;
}

.carousel-track {
  display: flex;
  transition: transform 0.3s ease;
  gap: 20px;
  padding: 5px 0;
}

.before-after-widget {
  min-width: 200px;
}

.carousel-items-6 .before-after-widget {
  flex: 0 0 calc((100% - 20px * 5) / 6);
  min-width: auto;
}

.carousel-items-5 .before-after-widget {
  flex: 0 0 calc((100% - 20px * 4) / 5);
  min-width: auto;
}

.carousel-items-4 .before-after-widget {
  flex: 0 0 calc((100% - 20px * 3) / 4);
  min-width: auto;
}

.carousel-items-3 .before-after-widget {
  flex: 0 0 calc((100% - 20px * 2) / 3);
  min-width: auto;
}

.carousel-items-2 .before-after-widget {
  flex: 0 0 calc((100% - 20px * 1) / 2);
  min-width: auto;
}

.carousel-items-1 .before-after-widget {
  flex: 0 0 calc((100%) / 1);
  min-width: auto;
}

.before-after-container {
  cursor: pointer;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 4px rgba(0,0,0,0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.before-after-container:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 10px rgba(0,0,0,0.15);
}

.before-after-wrapper {
  position: relative;
  width: 100%;
  height: 600px;
  overflow: hidden;
}

.before-image, .after-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}

.after-image {
  clip-path: inset(0 0 0 50%);
}

.lazy-load {
  opacity: 0;
}

.lazy-load:not([src]) {
  background: #f0f0f0;
}

.divider-line {
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 100%;
  background: white;
  transform: translateX(-50%);
  cursor: ew-resize;
}

.divider-handle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 40px;
  height: 40px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 2px 10px rgba(0,0,0,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
}

.divider-handle::before,
.divider-handle::after {
  content: '';
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #666;
}

.divider-handle::before {
  left: 5px;
}

.divider-handle::after {
  right: 5px;
}

.widget-title {
  padding: 15px;
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  background: white;
  color: #333;
}

/* Modal Styles */
.before-after-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  cursor: pointer;
}

.modal-content {
  position: relative;
  max-width: 90vw;
  max-height: 95vh;
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  display: flex;
  flex-direction: column;
}

.modal-close {
  position: absolute;
  top: 15px;
  right: 15px;
  z-index: 10;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}

.modal-close:hover {
  background: white;
  transform: scale(1.1);
}

.modal-before-after {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.modal-before-after-wrapper {
  position: relative;
  width: 60vw;
  max-width: 800px;
  overflow: hidden;
  flex: 1;
}

.modal-before-image, .modal-after-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.modal-after-image {
  clip-path: inset(0 0 0 50%);
}

.modal-divider-line {
  position: absolute;
  top: 0;
  left: 50%;
  width: 3px;
  height: 100%;
  background: white;
  transform: translateX(-50%);
  cursor: ew-resize;
}

.modal-divider-handle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 40px;
  height: 40px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-divider-handle::before,
.modal-divider-handle::after {
  content: '';
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #666;
}

.modal-divider-handle::before {
  left: 7px;
}

.modal-divider-handle::after {
  right: 7px;
}

.modal-title {
  padding: 20px;
  margin: 0;
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  background: white;
  color: #333;
  flex-shrink: 0;
}

/* Feedback Carousel Styles */
.feedback-carousel {
  position: relative;
  margin-top: 10px;
  overflow: hidden;
  padding: 10px 0;
  background: white;
}

.feedback-item {
  min-width: 200px;
}

.feedback-carousel .carousel-items-6 .feedback-item {
  flex: 0 0 calc((100% - 20px * 5) / 6);
  min-width: auto;
}

.feedback-carousel .carousel-items-5 .feedback-item {
  flex: 0 0 calc((100% - 20px * 4) / 5);
  min-width: auto;
}

.feedback-carousel .carousel-items-4 .feedback-item {
  flex: 0 0 calc((100% - 20px * 3) / 4);
  min-width: auto;
}

.feedback-carousel .carousel-items-3 .feedback-item {
  flex: 0 0 calc((100% - 20px * 2) / 3);
  min-width: auto;
}

.feedback-carousel .carousel-items-2 .feedback-item {
  flex: 0 0 calc((100% - 20px * 1) / 2);
  min-width: auto;
}

.feedback-carousel .carousel-items-1 .feedback-item {
  flex: 0 0 calc((100%) / 1);
  min-width: auto;
}

.feedback-image-container {
  cursor: pointer;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.feedback-image-container:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.15);
}

.feedback-image {
  width: 100%;
  height: 600px;
  object-fit: scale-down;
  display: block;
}

/* Feedback Modal Styles */
.feedback-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.feedback-modal .modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  cursor: pointer;
}

.feedback-modal .modal-content {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  z-index: 1001;
}

.feedback-modal .modal-close {
  position: absolute;
  top: -45px;
  right: 0;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  z-index: 1002;
}

.feedback-modal .modal-close:hover {
  background: white;
}

.modal-feedback-image {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
}

.modal-feedback-image img {
  width: 100%;
  height: auto;
  max-height: 80vh;
  object-fit: contain;
  display: block;
}

.pet-types-section {
  background: rgba(255, 226, 33, 0.05);
  border-radius: 8px;
  padding: 8px;
  border-left: 3px solid #FFE221;
}

.pet-types-grid {
  display: flex;
  flex-direction: row;
  gap: 8px;
  margin-top: 8px;
}

.pet-types-section .checkbox-option {
  justify-content: flex-start;
  gap: 6px;
}

.pet-types-section .checkbox-option-label {
  font-size: 0.85rem;
  font-weight: 500;
  white-space: nowrap;
}

.pet-types-section .checkbox-label {
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
}

.pet-types-section.error {
  border-left-color: #f0506e;
  background: rgba(240, 80, 110, 0.1);
  animation: shake 0.5s ease-in-out;
}

@keyframes shake {
  0%, 20%, 40%, 60%, 80% {
    transform: translateX(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-5px);
  }
}

.modal-navigation {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: white;
  gap: 20px;
  flex-shrink: 0;
  border-top: 1px solid #f0f0f0;
}

.modal-counter {
  font-size: 16px;
  font-weight: 600;
  color: #666;
  min-width: 60px;
  text-align: center;
}

.modal-navigation .carousel-btn {
  position: relative;
  top: auto;
  transform: none;
  z-index: auto;
}

@media (min-width: 1201px) {
  .modal-before-after-wrapper {
    min-height: 65vh;
  }
}

@media (max-width: 1200px) {
  .modal-before-after-wrapper {
    min-height: 60vh;
  }
}

@media (max-width: 992px) {
  .modal-before-after-wrapper {
    min-height: 55vh;
  }
}

@media (max-width: 768px) {
  .modal-content {
    max-width: 95vw;
    max-height: 95vh;
  }

  .modal-before-after-wrapper {
    width: 90vw;
    min-height: 50vh;
  }
  
  .modal-title {
    padding: 15px;
    font-size: 20px;
  }
  
  .modal-navigation {
    padding: 15px;
    gap: 15px;
  }
  
  .modal-navigation .carousel-btn {
    width: 45px;
    height: 45px;
  }
  
  .modal-counter {
    font-size: 14px;
  }
}

@media (max-width: 768px) {
  .success-modal, .sms-modal {
    align-items: center;
    justify-content: center;
    padding: 10px;
  }
  
  .success-modal-content, .sms-modal-content {
    max-width: 90vw;
    padding: 20px 16px;
    margin: 0;
    max-height: 80vh;
    overflow-y: auto;
    position: static;
  }
  
  .sms-code-fields {
    gap: 8px;
  }
  
  .sms-code-field {
    width: 34px;
    height: 42px;
    font-size: 1.8rem;
  }
}

@media (max-width: 480px) {
  .success-modal, .sms-modal {
    height: 100%;
    padding: 5px;
    align-items: center;
    justify-content: center;
  }
  
  .success-modal-content, .sms-modal-content {
    max-width: 95vw;
    padding: 16px 12px;
    margin: 0;
    max-height: 80vh;
    border-radius: 12px;
    position: static;
  }
  
  .sms-code-fields {
    gap: 6px;
    margin: 8px 0;
  }
  
  .sms-code-field {
    width: 30px;
    height: 38px;
    font-size: 1.5rem;
  }
  
  .sms-phone-display {
    font-size: 0.8rem;
    margin-bottom: 8px;
  }
  
  .modal-content {
    max-width: 95vw;
    max-height: 95vh;
  }
  
  .modal-before-after-wrapper {
    width: 95vw;
    min-height: 40vh;
  }
  
  .modal-title {
    padding: 10px;
    font-size: 18px;
  }
  
  .modal-navigation {
    padding: 10px;
    gap: 10px;
  }
  
  .modal-navigation .carousel-btn {
    width: 40px;
    height: 40px;
  }
  
  .modal-counter {
    font-size: 12px;
    min-width: 40px;
  }
}

.home-link-container.uk-navbar-item {
  align-items: center !important;
}

.home-link-container.uk-navbar-item[style*="display: flex"] {
  display: flex !important;
}

.home-link-container .uk-button {
  display: flex;
  align-items: center;
  gap: 6px;
}

.swoopex-header-right {
  flex-wrap: wrap;
}

.swoopex-header-contact {
  display: flex;
  align-items: center;
  white-space: nowrap;
}

.swoopex-header-contact .swoopex-contact-text {
  display: none;
}

@media (max-width: 640px) {
  .swoopex-header-nav {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    align-items: center;
    row-gap: 16px;
    column-gap: 10px;
  }

  .swoopex-header-nav .uk-navbar-left {
    grid-column: 1;
    grid-row: 1;
  }

  .swoopex-header-nav .swoopex-header-right {
    display: contents;
  }

  .swoopex-header-nav .swoopex-header-right .uk-inline {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
  }

  .swoopex-header-nav .swoopex-header-right .swoopex-header-contact {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: stretch;
    width: 100%;
    min-height: 0;
    line-height: 1;
  }

  .swoopex-header-contact .swoopex-contact-text {
    display: inline;
  }

  .feedback-image {
    height: 300px;
  }

  .before-image, .after-image, .before-after-wrapper {
    height: 400px;
  }
}

/* Swoopex Cookie Consent Banner */
.swoopex-cookie-container {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 9998;
pointer-events: none;
visibility: hidden;
}

.swoopex-cookie-container.show {
visibility: visible;
pointer-events: all;
}

.swoopex-cookie-backdrop {
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(37,37,37,0.4);
backdrop-filter:blur(2px);
z-index:9998;
opacity:0;
visibility:hidden;
transition:all .3s ease;
pointer-events:none
}

.swoopex-cookie-backdrop.show {
opacity:1;
visibility:visible;
pointer-events:all
}

.swoopex-cookie-banner {
position:fixed;
bottom:20px;
left:50%;
transform:translateX(-50%) translateY(100px);
max-width:600px;
width:calc(100% - 40px);
background:#fff;
border-radius:16px;
box-shadow:0 8px 30px rgba(0,0,0,0.15);
z-index:9999;
opacity:0;
visibility:hidden;
transition:all .4s cubic-bezier(0.68,-0.55,0.265,1.55)
}

.swoopex-cookie-banner.show {
opacity:1;
visibility:visible;
transform:translateX(-50%) translateY(0)
}

.swoopex-cookie-content {
padding:24px;
display:flex;
flex-direction:column;
gap:16px
}

.swoopex-cookie-icon {
font-size:32px;
text-align:center;
animation:cookieBounce 2s ease-in-out infinite
}

@keyframes cookieBounce {
0%,100% {
transform:translateY(0)
}
50% {
transform:translateY(-5px)
}
}

.swoopex-cookie-text {
text-align:center
}

.swoopex-cookie-title {
font-size:20px;
font-weight:700;
color:#252525;
margin:0 0 8px 0
}

.swoopex-cookie-message {
font-size:14px;
color:#666;
line-height:1.6;
margin:0 0 8px 0
}

.swoopex-cookie-link {
color:#FFE221;
text-decoration:underline;
font-weight:600;
transition:color .15s
}

.swoopex-cookie-link:hover {
color:#ffe966;
text-decoration:underline
}

.swoopex-cookie-buttons {
display:flex;
gap:12px;
justify-content:center;
flex-wrap:wrap
}

.swoopex-cookie-btn {
padding:12px 28px;
border:none;
border-radius:10px;
font-weight:700;
font-size:14px;
cursor:pointer;
transition:all .15s;
flex:1;
min-width:120px
}

.swoopex-cookie-btn-accept {
background:#FFE221;
color:#252525
}

.swoopex-cookie-btn-accept:hover {
background:#ffe966;
transform:translateY(-2px);
box-shadow:0 4px 12px rgba(255,226,33,0.3)
}

.swoopex-cookie-btn-decline {
background:#f6f9fa;
color:#252525;
border:2px solid #e0e0e0
}

.swoopex-cookie-btn-decline:hover {
background:#e0e0e0;
transform:translateY(-2px)
}

.swoopex-cookie-btn-settings {
background:#ffffff;
color:#252525;
border:2px solid #FFE221
}

.swoopex-cookie-btn-settings:hover {
background:#FFE221;
transform:translateY(-2px)
}

.swoopex-cookie-btn-necessary {
background:#6c757d;
color:#ffffff;
border:2px solid #6c757d
}

.swoopex-cookie-btn-necessary:hover {
background:#5a6268;
transform:translateY(-2px)
}

.swoopex-cookie-btn-save {
background:#ffffff;
color:#252525;
border:2px solid #FFE221
}

.swoopex-cookie-btn-save:hover {
background:#FFE221;
transform:translateY(-2px)
}

.swoopex-cookie-settings {
margin:5px 0;
padding:5px 0;
border-top:1px solid #e0e0e0;
}

.swoopex-cookie-option {
margin:2px 0;
}

.swoopex-cookie-label {
display:flex;
align-items:flex-start;
cursor:pointer;
padding:10px;
border-radius:8px;
transition:background-color 0.3s ease;
}

.swoopex-cookie-label:hover {
background:#f6f9fa;
}

.swoopex-cookie-checkbox {
margin:4px 12px 0 0;
width:18px;
height:18px;
cursor:pointer;
accent-color:#FFE221;
}

.swoopex-cookie-checkbox:disabled {
cursor:not-allowed;
opacity:0.6;
}

.swoopex-cookie-option-text {
flex:1;
display:flex;
flex-direction:column;
}

.swoopex-cookie-option-text strong {
font-size:14px;
font-weight:600;
color:#252525;
margin-bottom:4px;
}

.swoopex-cookie-option-text small {
font-size:12px;
color:#666;
line-height:1.4;
}

@media (max-width:640px) {
.swoopex-cookie-banner {
bottom:10px;
width:calc(100% - 20px);
border-radius:12px
}

.swoopex-cookie-content {
padding:20px
}

.swoopex-cookie-title {
font-size:18px
}

.swoopex-cookie-message {
font-size:13px
}

.swoopex-cookie-buttons {
flex-direction:column
}

.swoopex-cookie-btn {
width:100%
}

.swoopex-cookie-option-text strong {
font-size:13px;
}

.swoopex-cookie-option-text small {
font-size:11px;
}
}

.swoopex-cookie-gdpr-notice {
margin-top:15px;
padding-top:15px;
border-top:1px solid #e0e0e0;
font-size:11px;
color:#666;
line-height:1.5;
}

.swoopex-cookie-gdpr-notice a {
color:#FFE221;
text-decoration:underline;
}

.swoopex-details-link {
color:#FFE221;
text-decoration:underline;
font-size:11px;
cursor:pointer;
}

.swoopex-details-link:hover {
color:#ffd700;
}

.swoopex-cookie-details-modal {
position:fixed;
top:0;
left:0;
right:0;
bottom:0;
background:rgba(0,0,0,0.7);
display:flex;
align-items:center;
justify-content:center;
z-index:999999;
padding:20px;
}

.swoopex-cookie-details-content {
background:white;
border-radius:12px;
max-width:700px;
width:100%;
max-height:80vh;
overflow-y:auto;
position:relative;
padding:30px;
box-shadow:0 10px 40px rgba(0,0,0,0.3);
}

.swoopex-cookie-details-close {
position:absolute;
top:15px;
right:15px;
background:transparent;
border:none;
font-size:32px;
cursor:pointer;
color:#999;
line-height:1;
padding:0;
width:32px;
height:32px;
}

.swoopex-cookie-details-close:hover {
color:#252525;
}

.swoopex-cookie-details-body h3 {
font-size:22px;
margin-bottom:15px;
color:#252525;
}

.swoopex-cookie-details-body h4 {
font-size:16px;
margin:20px 0 10px;
color:#252525;
}

.swoopex-cookie-details-body p {
font-size:14px;
line-height:1.6;
color:#666;
margin-bottom:15px;
}

.swoopex-cookie-table {
width:100%;
border-collapse:collapse;
margin:15px 0;
font-size:13px;
}

.swoopex-cookie-table th {
background:#f6f9fa;
padding:10px;
text-align:left;
font-weight:600;
border-bottom:2px solid #e0e0e0;
}

.swoopex-cookie-table td {
padding:10px;
border-bottom:1px solid #f0f0f0;
}

.swoopex-cookie-table code {
background:#f6f9fa;
padding:2px 6px;
border-radius:4px;
font-family:monospace;
}

@media (max-width:640px) {
.swoopex-cookie-details-content {
padding:20px;
}

.swoopex-cookie-table {
font-size:11px;
}

.swoopex-cookie-table th,
.swoopex-cookie-table td {
padding:6px;
}
}

/* CTA Box */
.cta-box {
  background: linear-gradient(135deg, var(--primary-color) 0%, #FFD700 100%);
  padding: 40px;
  border-radius: 12px;
  margin: 50px 0;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  position: relative;
  overflow: hidden;
}

.hero-marketing {
  color: var(--secondary-color);
  padding: 60px 0 40px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
  height: 100vh;
  max-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-bg-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255, 255, 255, 0.5) 100%);
  z-index: 1;
}

.hero-marketing .uk-container {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 20px;
  position: relative;
  z-index: 2;
}

.hero-marketing h1,
.hero-marketing p {
  display: block;
  text-align: center;
}

.hero-marketing h1 {
  font-size: 48px;
  margin-bottom: 20px;
  line-height: 1.2;
}

.hero-marketing p {
  font-size: 20px;
  max-width: 800px;
  margin: 0 auto 40px;
}

.hero-title-with-bg {
  background-color: rgba(255, 226, 33, 0.7);
  padding: 15px 25px;
  display: inline-block;
  margin-bottom: 20px;
  color: var(--secondary-color);
  text-align: center;
  max-width: 100%;
  word-wrap: break-word;
}

.hero-subtitle-with-bg {
  background-color: rgba(255, 226, 33, 0.7);
  padding: 15px 25px;
  display: inline-block;
  margin-bottom: 40px;
  color: var(--secondary-color);
  text-align: center;
  max-width: 100%;
  word-wrap: break-word;
}

.services-modern-section {
  padding: 80px 0;
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
  position: relative;
  overflow: hidden;
}

.services-modern-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 20"><defs><linearGradient id="gradient" x1="0%" y1="0%" x2="100%" y2="0%"><stop offset="0%" style="stop-color:rgba(255,226,33,0.05);stop-opacity:1" /><stop offset="100%" style="stop-color:rgba(63,128,234,0.05);stop-opacity:1" /></linearGradient></defs><path d="M0,10 Q25,0 50,10 T100,10 L100,20 L0,20 Z" fill="url(%23gradient)"/></svg>') repeat-x;
  opacity: 0.3;
  z-index: 0;
}

.services-modern-section > .uk-container {
  position: relative;
  z-index: 1;
}

.company-intro {
  text-align: center;
  margin-bottom: 80px;
  padding: 40px 0;
}

.company-title {
  font-size: 42px;
  font-weight: 700;
  color: var(--secondary-color);
  margin-bottom: 20px;
  line-height: 1.2;
}

.company-subtitle {
  font-size: 22px;
  color: var(--accent-color);
  margin-bottom: 25px;
  font-weight: 500;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

.company-description {
  font-size: 18px;
  color: var(--dark-gray);
  max-width: 1000px;
  margin: 0 auto 40px;
  line-height: 1.6;
}

.company-stats {
  display: flex;
  justify-content: center;
  gap: 60px;
  margin-top: 50px;
  flex-wrap: wrap;
}

.stat-item {
  text-align: center;
}

.stat-number {
  font-size: 36px;
  font-weight: 700;
  color: var(--accent-color);
  margin-bottom: 8px;
}

.stat-label {
  font-size: 16px;
  color: var(--dark-gray);
  font-weight: 500;
}

.services-categories {
  margin-bottom: 80px;
}

.services-categories .section-title {
  text-align: center;
  margin-bottom: 50px;
}

.services-categories .section-title h3 {
  font-size: 36px;
  color: var(--secondary-color);
  margin-bottom: 15px;
}

.services-categories .section-title p {
  font-size: 18px;
  color: var(--dark-gray);
  max-width: 600px;
  margin: 0 auto;
}

.categories-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
  margin-top: 50px;
}

.category-card {
  background: white;
  border-radius: 16px;
  padding: 40px 30px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  display: block;
  text-decoration: none !important;
  color: inherit;
}

.category-card:hover {
  text-decoration: none !important;
}

.category-card h4,
.category-card p,
.category-card * {
  text-decoration: none !important;
}



.category-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.12);
}

.category-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 25px;
  background: var(--primary-color);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease;
}

.category-icon img {
  width: 50px;
  height: 50px;
}

.category-card:hover .category-icon {
  transform: scale(1.05);
}

.category-card h4 {
  font-size: 22px;
  font-weight: 600;
  color: var(--secondary-color);
  margin-bottom: 15px;
}

.category-card p {
  color: var(--dark-gray);
  line-height: 1.6;
  margin-bottom: 20px;
}

.section-title {
  text-align: center;
  margin-bottom: 50px;
}

.section-title h2 {
  font-size: 36px;
  margin-bottom: 15px;
}

.section-title p {
  color: var(--dark-gray);
  max-width: 700px;
  margin: 0 auto;
}

.before-after-section-title {
  text-align: center;
  margin-bottom: 10px;
}

.before-after-section-title h2 {
  font-size: 36px;
  margin-bottom: 15px;
}

.before-after-section-title p {
  color: var(--dark-gray);
  max-width: 700px;
  margin: 0 auto;
}

.feedback-section-title {
  text-align: center;
  margin-bottom: 10px;
}

.feedback-section-title h2 {
  font-size: 36px;
  margin-bottom: 15px;
}

.feedback-section-title p {
  color: var(--dark-gray);
  max-width: 700px;
  margin: 0 auto;
}

.benefits-section {
  background-color: var(--light-gray);
  padding: 80px 0;
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 30px;
  margin-top: 50px;
}

.benefit-item {
  text-align: center;
  padding: 30px;
}

.benefit-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--primary-color);
  border-radius: 50%;
}
  .benefit-item h3 {
  margin-bottom: 15px;
  font-size: 20px;
}

.before-after-section {
  background-color: var(--light-gray);
  padding: 20px 0;
}

.feedback-section {
  padding: 20px 0;
  background-color: white;
}

.cta-section {
  background: linear-gradient(135deg, var(--primary-color) 0%, #FFD700 100%);
  padding: 80px 0;
  text-align: center;
}

.cta-section h2 {
  font-size: 36px;
  margin-bottom: 20px;
  color: var(--secondary-color);
}

.cta-section p {
  font-size: 18px;
  max-width: 700px;
  margin: 0 auto 40px;
  color: var(--secondary-color);
}

.nav-links {
  display: flex;
  gap: 20px;
}

.nav-links a {
  text-decoration: none;
  color: #333;
  font-weight: 500;
  transition: color 0.3s ease;
}

.nav-links a:hover {
  color: var(--accent-color);
}

@media (max-width: 768px) {
  .hero-marketing {
    height: 100vh;
    max-height: 100vh;
    padding: 40px 0 20px 0;
  }
  
  .hero-marketing .uk-container {
    padding: 15px;
  }
  
  .hero-marketing h1 {
    font-size: 36px;
  }
  
  .hero-marketing p {
    font-size: 18px;
  }
  
  .hero-title-with-bg {
    padding: 12px 20px;
    font-size: 32px;
    max-width: calc(100vw - 40px);
  }
  
  .hero-subtitle-with-bg {
    padding: 12px 20px;
    font-size: 16px;
    line-height: 1.4;
    max-width: calc(100vw - 40px);
  }
  
  .section-title h2 {
    font-size: 28px;
  }
  
  .services-grid, .benefits-grid {
    grid-template-columns: 1fr;
  }
  
  .floating-btn {
    width: 50px;
    height: 50px;
    font-size: 20px;
  }

  .company-title {
    font-size: 32px;
  }

  .company-subtitle {
    font-size: 18px;
  }

  .company-description {
    font-size: 16px;
  }

  .company-stats {
    gap: 30px;
  }

  .stat-number {
    font-size: 28px;
  }

  .categories-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .category-card {
    padding: 25px 20px;
  }


}