@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

/* Переменные и основные стили */
:root {
  --gofra-primary: #0066CC;
  --gofra-secondary: #F5F5F5;
  --gofra-text: #333333;
  --gofra-border: #DDDDDD;
  --gofra-animation-time: 0.3s;
  --gofra-font: 'Poppins', sans-serif;
  --gofra-success: #4CAF50;
  --gofra-error: #f44336;
  --gofra-warning: #f0ad4e;
  --gofra-info: #5bc0de;
  --gofra-neutral: #777;
  --gofra-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
  --gofra-radius: 12px;
  --gofra-transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Общие стили для контейнеров форм */
.gofra-login-container,
.gofra-register-container,
.gofra-forgot-password-container {
  display: none !important; /* Принудительно скрываем все формы по умолчанию */
  max-width: 1000px;
  margin: 0 auto;
  border-radius: var(--gofra-radius);
  overflow: hidden;
  box-shadow: var(--gofra-shadow);
  background-color: white;
  font-family: var(--gofra-font);
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 9999;
  opacity: 0;
  animation-duration: var(--gofra-animation-time);
  animation-fill-mode: forwards;
  max-width: 90%;
  width: 1000px;
}

/* Стили для изображений в формах */
.gofra-login-image,
.gofra-register-image {
  flex: 0 0 40%;
  background-color: #F8F3E9;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: var(--gofra-radius);
}

.gofra-login-image img,
.gofra-register-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: var(--gofra-radius);
}

/* Стили для форм */
.gofra-login-form,
.gofra-register-form {
  flex: 0 0 60%;
  padding: 30px;
  position: relative;
  background: linear-gradient(135deg, #ffffff 0%, #f5f8fd 100%);
}

.gofra-login-form::before,
.gofra-register-form::before {
  content: "";
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(45deg, var(--gofra-primary), #5BA0F3, var(--gofra-primary));
  z-index: -1;
  border-radius: calc(var(--gofra-radius) + 2px);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.gofra-login-form:hover::before,
.gofra-register-form:hover::before {
  opacity: 0.6;
}

/* Заголовки форм */
.gofra-login-header,
.gofra-register-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 30px;
}

/* Контролы в заголовке (переключатель языка + кнопка закрытия) */
.header-controls {
  display: flex;
  align-items: center;
  gap: 15px;
  position: relative;
  z-index: 10001;
  pointer-events: auto;
}

/* Стили для переключателя языка в попапе */
.language-switcher {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 10001;
}

.language-switcher .trp-language-switcher {
  margin: 0;
  position: relative;
  z-index: 10001;
}

.language-switcher .trp-language-switcher a {
  font-size: 12px;
  padding: 4px 8px;
  margin: 0 2px;
  border-radius: 4px;
  text-decoration: none;
  color: #666;
  background: rgba(0, 102, 204, 0.1);
  transition: all 0.2s;
  position: relative;
  z-index: 10001;
  cursor: pointer;
  pointer-events: auto;
  display: inline-block;
}

.language-switcher .trp-language-switcher a:hover,
.language-switcher .trp-language-switcher a.current-language {
  background: var(--gofra-primary);
  color: white;
}

/* Убеждаемся что переключатель не перекрывается */
.language-switcher * {
  pointer-events: auto;
}

/* Дополнительные стили для различных вариантов разметки TranslatePress */
.language-switcher select,
.language-switcher .trp-ls-shortcode-language,
.language-switcher .trp-ls-language-name,
.language-switcher [data-language] {
  pointer-events: auto !important;
  position: relative;
  z-index: 10001 !important;
  cursor: pointer !important;
}

/* Стили для select-based переключателя */
.language-switcher select {
  padding: 4px 8px;
  border-radius: 4px;
  border: 1px solid rgba(0, 102, 204, 0.3);
  background: rgba(0, 102, 204, 0.1);
  color: #666;
  font-size: 12px;
}

.gofra-login-header h2,
.gofra-register-header h2 {
  font-size: 28px;
  font-family: var(--gofra-font);
  color: var(--gofra-primary);
  margin: 0;
  font-weight: 600;
}

/* Социальный вход */
.gofra-social-login {
  margin-bottom: 24px;
}

.gofra-social-login-label {
  font-size: 14px;
  font-weight: 600;
  text-align: center;
  margin: 0 0 12px;
  color: var(--gofra-text);
}

.gofra-google-container {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 44px;
  position: relative;
}

.gofra-google-container::before,
.gofra-google-container::after {
  content: "";
  position: absolute;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 2;
}

.gofra-google-container::before {
  inset: -6px;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 12px;
}

.gofra-google-container::after {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 3px solid rgba(0, 0, 0, 0.15);
  border-top-color: var(--gofra-primary, #0066cc);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(0deg);
  animation: gofra-google-spinner 0.9s linear infinite;
}

.gofra-google-container.is-loading {
  pointer-events: none;
}

.gofra-google-container.is-loading::before,
.gofra-google-container.is-loading::after {
  opacity: 1;
}

.gofra-google-container.is-loading > * {
  opacity: 0.15;
}

@keyframes gofra-google-spinner {
  0% {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

.gofra-google-status {
  display: none;
  margin-top: 10px;
  text-align: center;
  font-size: 14px;
  color: #4f4f4f;
}

.gofra-google-status.is-visible {
  display: block;
}

.gofra-google-status.error {
  color: #d63c3c;
}

.gofra-social-divider {
  margin: 20px 0 0;
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #7a7a7a;
  position: relative;
}

.gofra-social-divider span {
  background: #f5f8fd;
  padding: 0 12px;
  position: relative;
  z-index: 1;
}

.gofra-social-divider::before,
.gofra-social-divider::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 35%;
  height: 1px;
  background: #d9e2f3;
}

.gofra-social-divider::before {
  left: 0;
}

.gofra-social-divider::after {
  right: 0;
}

/* Кнопки закрытия и возврата */
.close-btn,
.back-btn {
  cursor: pointer;
  font-size: 24px;
  color: #999;
  transition: color 0.2s;
}

.close-btn:hover,
.back-btn:hover {
  color: var(--gofra-text);
}

.gofra-user-menu-container .back-btn,
.gofra-user-menu-container .back-btn:link,
.gofra-user-menu-container .back-btn:visited {
  color: #495057 !important;
}

.gofra-user-menu-container .back-btn:hover,
.gofra-user-menu-container .back-btn:focus {
  color: #174982 !important;
}

/* Группы полей форм */
.form-group {
  position: relative;
  margin-bottom: 20px;
}

.form-group label {
  font-family: var(--gofra-font);
  display: block;
  margin-bottom: 8px;
  font-weight: 500;
  color: var(--gofra-text);
  transition: all 0.3s ease;
}

/* Поля ввода с иконками */
.input-icon {
  position: relative;
  z-index: 1;
}

.input-icon input {
  width: 100%;
  padding: 12px 35px !important;
  border: 1px solid var(--gofra-border);
  border-radius: 6px;
  font-size: 16px;
  transition: all 0.3s ease;
  position: relative;
  z-index: 1;
}

.input-icon i {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  color: #999;
  z-index: 2;
  cursor: pointer;
  font-size: 16px;
  transition: all 0.3s ease;
}

.input-icon i.email-icon,
.input-icon i.password-icon {
  left: 10px;
  cursor: default;
}

.input-icon i.email-icon::before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

.input-icon i.password-icon::before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

.input-icon i.password-toggle {
  right: 10px;
  left: auto;
  cursor: pointer;
  user-select: none;
  transition: all 0.2s ease;
  padding: 12px;
  border-radius: 3px;
  min-width: 20px;
  min-height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}

.input-icon i.password-toggle::before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

.input-icon i.password-toggle.hidden::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666'%3E%3Cpath d='M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24'/%3E%3Cline x1='1' y1='1' x2='23' y2='23'/%3E%3C/svg%3E");
}

.input-icon i.password-toggle:hover {
  color: var(--gofra-primary);
  background-color: rgba(0, 0, 0, 0.1);
}

.input-icon i.password-toggle:active {
  transform: scale(0.95);
}

/* Стандартные поля ввода */
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="password"],
.form-group input[type="tel"] {
  width: 100%;
  padding: 12px 15px;
  border: 1px solid var(--gofra-border);
  border-radius: 6px;
  font-size: 16px;
  transition: var(--gofra-transition);
}

.form-group input:focus {
  outline: none;
  border-color: var(--gofra-primary);
  box-shadow: 0 0 0 3px rgba(0, 115, 230, 0.1);
  transform: translateY(-2px);
}

.form-group input:hover {
  border-color: #bbb;
}

/* Чекбоксы */
.checkbox-group {
  display: flex;
  align-items: flex-start;
}

.checkbox-group input[type="checkbox"] {
  margin-right: 10px;
  margin-top: 3px;
}

.checkbox-group label {
  font-family: var(--gofra-font);
  margin-bottom: 0;
  font-weight: normal;
  font-size: 14px;
  flex: 1;
}

/* Основная кнопка */
.gofra-btn {
  font-family: var(--gofra-font);
  width: 100%;
  padding: 12px;
  background-color: var(--gofra-primary);
  color: white;
  border: none;
  border-radius: 6px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--gofra-transition);
  position: relative;
  overflow: hidden;
}

.gofra-btn:hover {
  background-color: #0055b3;
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 115, 230, 0.3);
}

.gofra-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 115, 230, 0.2);
}

/* Эффект пульсации на кнопке */
.gofra-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5px;
  height: 5px;
  background: rgba(255, 255, 255, 0.5);
  opacity: 0;
  border-radius: 100%;
  transform: scale(1, 1) translate(-50%, -50%);
  transform-origin: 50% 50%;
}

.gofra-btn:focus:not(:active)::after {
  animation: ripple 1s ease-out;
}

@keyframes ripple {
  0% {
    transform: scale(0, 0) translate(-50%, -50%);
    opacity: 0.5;
  }
  100% {
    transform: scale(30, 30) translate(-50%, -50%);
    opacity: 0;
  }
}

/* Футер формы */
.form-footer {
  margin-top: 20px;
  text-align: center;
  font-size: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
}

.form-footer a {
  color: var(--gofra-primary);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s;
}

.form-footer a:hover {
  text-decoration: underline;
}

.gofra-login-form .form-footer p,
.gofra-register-form .form-footer p,
.gofra-forgot-password-container .form-footer p {
  color: var(--gofra-text) !important;
}

.gofra-login-form .form-footer a,
.gofra-login-form .form-footer a:link,
.gofra-login-form .form-footer a:visited,
.gofra-register-form .form-footer a,
.gofra-register-form .form-footer a:link,
.gofra-register-form .form-footer a:visited,
.gofra-forgot-password-container .form-footer a,
.gofra-forgot-password-container .form-footer a:link,
.gofra-forgot-password-container .form-footer a:visited {
  color: var(--gofra-primary) !important;
}

/* Переключатель типа пользователя */
.user-type-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 25px;
}

.private-toggle,
.business-toggle {
  font-weight: 500;
  margin: 0 10px;
  color: var(--gofra-neutral);
  transition: color 0.3s;
}

.private-toggle.active,
.business-toggle.active {
  color: var(--gofra-primary);
  font-weight: 600;
}

/* Стили для переключателя (switch) */
.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 24px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: .4s cubic-bezier(0.25, 0.8, 0.25, 1);
  overflow: hidden;
}

.slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: .4s cubic-bezier(0.25, 0.8, 0.25, 1);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.slider:hover {
  box-shadow: 0 0 5px rgba(0, 115, 230, 0.5);
}

.slider:hover:before {
  transform: scale(1.1);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

input:checked + .slider:before {
  transform: translateX(26px) scale(1.1);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

input:checked + .slider {
  background-color: var(--gofra-primary);
}

input:focus + .slider {
  box-shadow: 0 0 1px var(--gofra-primary);
}

.slider.round {
  border-radius: 34px;
}

.slider.round:before {
  border-radius: 50%;
}

/* Оверлей и анимации */
.gofra-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(5px);
  z-index: 9998;
  opacity: 0;
  transition: opacity var(--gofra-animation-time);
  display: none;
}

.gofra-overlay.active {
  display: block;
  opacity: 1;
}

.gofra-overlay.closing {
  opacity: 0;
}

body.gofra-popup-locked,
html.gofra-popup-locked {
  overflow: hidden;
  height: 100%;
  touch-action: none;
  overscroll-behavior: contain;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(-30px) scale(0.95);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
    box-shadow: var(--gofra-shadow);
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
  to {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(-30px) scale(0.95);
  }
}

.gofra-login-container.active,
.gofra-register-container.active,
.gofra-forgot-password-container.active {
  display: flex !important;
  animation-name: fadeIn;
  animation-duration: 0.5s;
}

/* Скрываем формы авторизации для авторизованных пользователей */
body.logged-in .gofra-login-container,
body.logged-in .gofra-register-container,
body.logged-in .gofra-forgot-password-container {
  display: none !important;
}

.gofra-login-container.closing,
.gofra-register-container.closing,
.gofra-forgot-password-container.closing {
  animation-name: fadeOut;
}

.gofra-overlay.active {
  backdrop-filter: blur(8px);
}
/* Стили для пользовательского меню */
.gofra-user-menu-container {
  display: none;
  width: 100%;
  max-width: none;
  margin: 0px;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  background-color: white;
  font-family: var(--gofra-font);
  padding: 20px;
  position: relative;
  z-index: 1;
  transition: var(--gofra-transition);
  border: none;
  min-height: 100vh;
}

/* Показываем пользовательское меню для авторизованных пользователей */
body.logged-in .gofra-user-menu-container {
  display: block !important;
}

.gofra-user-menu-container:hover {
  /* Убираем эффекты наведения для полноэкранного контейнера */
}

.gofra-user-menu-container h2 {
  font-size: 28px;
  color: var(--gofra-primary);
  margin: 0 0 5px 0;
  font-weight: 600;
  text-align: center;
  position: relative;
  display: inline-block;
  left: 50%;
  transform: translateX(-50%);
}

.gofra-user-menu-container h2::after {
  content: "";
  display: block;
  width: 50px;
  height: 3px;
  background: linear-gradient(90deg, var(--gofra-primary), #5BA0F3);
  margin: 10px auto 0;
  border-radius: 8px;
  transition: width 0.3s ease;
}

.gofra-user-menu-container:hover h2::after {
  width: 100px;
}

.menu-description {
  text-align: center;
  color: var(--gofra-text);
  margin-bottom: 30px;
  font-size: 16px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  opacity: 0.8;
}

.user-menu-items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 30px;
  perspective: 1000px;
}

.gofra-menu-item {
  display: flex;
  align-items: center;
  padding: 20px;
  background-color: var(--gofra-secondary);
  border-radius: var(--gofra-radius);
  text-decoration: none;
  color: var(--gofra-text);
  transition: var(--gofra-transition);
  cursor: pointer;
  transform-style: preserve-3d;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
  border: 2px solid rgba(0, 0, 0, 0.05);
  position: relative;
  overflow: hidden;
}

.gofra-menu-item::before {
  content: '';
  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) 100%);
  pointer-events: none;
}

.gofra-menu-item:hover {
  background-color: var(--gofra-primary);
  color: white;
  transform: translateY(-5px) rotateX(5deg);
  box-shadow: 0 10px 20px rgba(0, 115, 230, 0.2);
}

.gofra-menu-icon {
  margin-right: 15px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: white;
  border-radius: 50%;
  color: var(--gofra-primary);
  transition: var(--gofra-transition);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.gofra-menu-item:hover .gofra-menu-icon {
  color: var(--gofra-primary);
  transform: scale(1.15) rotate(5deg);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.gofra-menu-text {
  transition: all 0.3s ease;
}

.gofra-menu-item:hover .gofra-menu-text {
  transform: translateX(5px);
}

.gofra-user-menu-container .gofra-menu-item,
.gofra-user-menu-container .gofra-menu-item:link,
.gofra-user-menu-container .gofra-menu-item:visited {
  color: var(--gofra-text) !important;
}

.gofra-user-menu-container .gofra-menu-item h3,
.gofra-user-menu-container .gofra-menu-item h3:link,
.gofra-user-menu-container .gofra-menu-item h3:visited {
  color: var(--gofra-text) !important;
}

.gofra-user-menu-container .gofra-menu-item p {
  color: #6c757d !important;
}

.gofra-user-menu-container .gofra-menu-item:hover h3,
.gofra-user-menu-container .gofra-menu-item:hover p {
  color: white !important;
}

/* Стили для раздела заказов */
.gofra-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 15px;
  position: relative;
  padding: 15px;
  background-color: white;
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.centered-title {
  flex-grow: 1;
  text-align: center;
  margin: 0;
}

.gofra-section-header h3 {
  font-size: 22px;
  color: var(--gofra-primary);
  font-weight: 600;
  margin: 0;
}

/* Стили для списка заказов */
.gofra-orders-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Стили для отдельного заказа */
.gofra-order-item {
  background-color: white;
  border-radius: var(--gofra-radius);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  transition: var(--gofra-transition);
  border: 2px solid rgba(0, 0, 0, 0.05);
  transform-origin: center;
}

.gofra-order-item:hover {
  box-shadow: 0 8px 20px rgba(0, 115, 230, 0.15);
  transform: translateY(-3px);
  border-color: rgba(0, 115, 230, 0.1);
}

/* Заголовок заказа */
.gofra-order-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 20px;
  background-color: var(--gofra-secondary);
  border-bottom: 1px solid var(--gofra-border);
}

.gofra-order-info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 15px;
  min-height: 40px; /* Фиксированная минимальная высота */
}

.order-number {
  font-weight: 600;
  color: var(--gofra-primary);
  font-size: 18px;
  line-height: 1.4;
  display: flex;
  align-items: center;
}

.order-date {
  color: #777;
  font-size: 14px;
  line-height: 1.4;
  display: flex;
  align-items: center;
}

.order-status {
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 80px;
  min-height: 28px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
  border: 2px solid transparent;
  line-height: 1;
  white-space: nowrap;
}

/* Стили для разных статусов заказа */
.order-status.completed {
  background-color: #28a745;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.processing {
  background-color: #fd7e14;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.on-hold {
  background-color: #17a2b8;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.cancelled,
.order-status.failed {
  background-color: #dc3545;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.pending {
  background-color: #6c757d;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.refunded {
  background-color: #6f42c1;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Эффекты наведения для статусов */
.order-status:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.order-status.completed:hover {
  border-color: #1e7e34;
  box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
}

.order-status.processing:hover {
  border-color: #e55100;
  box-shadow: 0 4px 8px rgba(253, 126, 20, 0.3);
}

.order-status.on-hold:hover {
  border-color: #117a8b;
  box-shadow: 0 4px 8px rgba(23, 162, 184, 0.3);
}

.order-status.cancelled:hover,
.order-status.failed:hover {
  border-color: #bd2130;
  box-shadow: 0 4px 8px rgba(220, 53, 69, 0.3);
}

.order-status.pending:hover {
  border-color: #545b62;
  box-shadow: 0 4px 8px rgba(108, 117, 125, 0.3);
}

.order-status.refunded:hover {
  border-color: #59359a;
  box-shadow: 0 4px 8px rgba(111, 66, 193, 0.3);
}

/* Стили для кастомных статусов заказов */
.order-status.apstrade {
  background-color: #fd7e14;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.komplektesana {
  background-color: #28a745;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.gatavs-sanemsanai {
  background-color: #17a2b8;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.nodots-piegadei {
  background-color: #6f42c1;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.izpildits {
  background-color: #28a745;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status.atcelts {
  background-color: #dc3545;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Эффекты наведения для кастомных статусов */
.order-status.apstrade:hover {
  border-color: #e55100;
  box-shadow: 0 4px 8px rgba(253, 126, 20, 0.3);
}

.order-status.komplektesana:hover {
  border-color: #1e7e34;
  box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
}

.order-status.gatavs-sanemsanai:hover {
  border-color: #117a8b;
  box-shadow: 0 4px 8px rgba(23, 162, 184, 0.3);
}

.order-status.nodots-piegadei:hover {
  border-color: #59359a;
  box-shadow: 0 4px 8px rgba(111, 66, 193, 0.3);
}

.order-status.izpildits:hover {
  border-color: #1e7e34;
  box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
}

.order-status.atcelts:hover {
  border-color: #bd2130;
  box-shadow: 0 4px 8px rgba(220, 53, 69, 0.3);
}

/* Стиль по умолчанию для неопознанных статусов */
.order-status:not(.completed):not(.processing):not(.on-hold):not(.cancelled):not(.failed):not(.pending):not(.refunded):not(.apstrade):not(.komplektesana):not(.gatavs-sanemsanai):not(.nodots-piegadei):not(.izpildits):not(.atcelts) {
  background-color: #868e96;
  color: white;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.order-status:not(.completed):not(.processing):not(.on-hold):not(.cancelled):not(.failed):not(.pending):not(.refunded):not(.apstrade):not(.komplektesana):not(.gatavs-sanemsanai):not(.nodots-piegadei):not(.izpildits):not(.atcelts):hover {
  border-color: #6c757d;
  box-shadow: 0 4px 8px rgba(134, 142, 150, 0.3);
}

/* Кнопка раскрытия деталей */
.gofra-order-details-toggle {
  background: none;
  border: none;
  display: flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  font-family: var(--gofra-font);
  font-size: 14px;
  color: var(--gofra-primary);
  font-weight: 500;
  transition: all 0.2s;
}

.gofra-user-menu-container .gofra-order-details-toggle,
.gofra-user-menu-container .gofra-order-details-toggle:link,
.gofra-user-menu-container .gofra-order-details-toggle:visited {
  background-color: transparent !important;
  color: var(--gofra-primary) !important;
}

.gofra-user-menu-container .gofra-order-details-toggle:hover,
.gofra-user-menu-container .gofra-order-details-toggle:focus,
.gofra-user-menu-container .gofra-order-details-toggle:active {
  background-color: transparent !important;
  color: #13396a !important;
}

.gofra-order-details-toggle .hide-details {
  display: none;
}

.toggle-arrow {
  transition: transform 0.3s ease;
}

/* Детали заказа */
.gofra-order-details {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease;
  background-color: #fafbfc;
  border-top: 1px solid #e9ecef;
}

/* Активное состояние для раскрытия деталей */
.gofra-order-item.details-open .gofra-order-details {
  max-height: 2000px;
}

.gofra-order-item.details-open .toggle-arrow {
  transform: rotate(180deg);
}

.gofra-order-item.details-open .show-details {
  display: none;
}

.gofra-order-item.details-open .hide-details {
  display: inline;
}

/* Таблица товаров */
.gofra-order-products {
  padding: 20px;
  background-color: white;
}

.gofra-order-table {
  width: 100%;
  border-collapse: collapse;
  background-color: white;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.gofra-order-table th,
.gofra-order-table td {
  padding: 15px;
  text-align: center;
  border-bottom: 1px solid #e9ecef;
  vertical-align: middle;
}

/* Обеспечиваем правильное выравнивание чисел */
.gofra-order-table .woocommerce-Price-amount bdi {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

.gofra-order-table th {
  background-color: var(--gofra-primary);
  color: white;
  font-weight: 600;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Столбец с продуктом */
.product-name {
  width: 40%;
  font-weight: 500;
}

.product-name a {
  color: var(--gofra-primary);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s ease;
}

.product-name a:hover {
  text-decoration: underline;
  color: #0055b3;
}

/* Столбец с количеством */
.product-quantity {
  width: 15%;
  text-align: center;
  font-weight: 600;
  color: var(--gofra-text);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* Столбец с ценой */
.product-price {
  width: 20%;
  text-align: right;
  font-weight: 500;
}

.product-price .woocommerce-Price-amount {
  font-weight: 600;
  color: var(--gofra-text);
  display: inline-block;
  min-width: 60px;
  text-align: right;
}

/* Столбец с суммой */
.product-subtotal {
  width: 25%;
  text-align: right;
  font-weight: 600;
}

.product-subtotal .woocommerce-Price-amount {
  font-weight: 700;
  color: var(--gofra-primary);
  display: inline-block;
  min-width: 70px;
  text-align: center;
}

/* Итоговые строки */
.gofra-order-table tfoot {
  background-color: #f8f9fa;
}

.gofra-order-table tfoot tr th {
  text-align: right;
  background-color: transparent;
  font-weight: 600;
  color: var(--gofra-text);
  padding: 12px 15px;
  border-bottom: 1px solid #e9ecef;
}

.gofra-order-table tfoot tr td {
  text-align: center;
  font-weight: 600;
  color: var(--gofra-text);
  padding: 12px 15px;
  border-bottom: 1px solid #e9ecef;
  white-space: nowrap;
}

.gofra-order-table tfoot tr td .woocommerce-Price-amount {
  display: inline-block;
  min-width: 70px;
  text-align: right;
  font-weight: inherit;
}

/* Строка доставки */
.order-shipping th,
.order-shipping td {
  border-top: 2px solid #e9ecef;
}

.shipping-method-info {
  text-align: right;
}

.shipping-method-title {
  display: block;
  font-size: 12px;
  color: #666;
  margin-bottom: 3px;
  font-style: italic;
}

/* Строка налога */
.order-tax th,
.order-tax td {
  color: #6c757d;
  font-style: italic;
}

/* Общая сумма */
.order-total {
  background-color: var(--gofra-primary) !important;
}

.order-total th,
.order-total td {
  color: white !important;
  font-size: 18px;
  font-weight: 700 !important;
  border-bottom: none !important;
  background-color: var(--gofra-primary) !important;
  padding: 15px !important;
  white-space: nowrap;
}

.order-total td .woocommerce-Price-amount {
  display: inline-block;
  min-width: 80px;
  text-align: right;
  font-weight: inherit;
  color: inherit;
}

/* Пометка о налоге */
.tax-label {
  display: inline-block;
  margin-left: 8px;
  font-size: 11px;
  color: #6c757d;
  font-weight: normal;
  background-color: #f8f9fa;
  padding: 2px 6px;
  border-radius: 10px;
  border: 1px solid #e9ecef;
}

/* Скрываем пустые tax-label элементы */
.tax-label:empty {
  display: none;
  margin: 0;
  padding: 0;
  border: none;
}

/* Адреса в заказах */
.gofra-order-address {
  display: flex;
  gap: 30px;
  padding: 20px;
  flex-wrap: wrap;
  background-color: #f8f9fa;
  border-radius: 8px;
  margin: 0 20px 20px 20px;
  border: 1px solid #e9ecef;
}

.gofra-order-address .gofra-billing-address,
.gofra-order-address .gofra-shipping-address {
  flex: 1;
  min-width: 250px;
  background-color: white;
  padding: 20px;
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  border: 1px solid #e9ecef;
}

.gofra-order-address h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 15px 0;
  color: var(--gofra-primary);
  padding-bottom: 8px;
  border-bottom: 2px solid var(--gofra-primary);
  display: inline-block;
}

.gofra-order-address address {
  font-style: normal;
  line-height: 1.6;
  color: var(--gofra-text);
  margin: 0;
  font-size: 14px;
}

/* Стили для адреса самовывоза */
.pickup-address {
  padding: 15px;
  background-color: #e8f4fd;
  border-radius: 6px;
  border-left: 4px solid var(--gofra-primary);
  margin-top: 5px;
}

.pickup-address strong {
  color: var(--gofra-primary);
  font-weight: 600;
  display: block;
  margin-bottom: 10px;
}

.pickup-hours {
  margin-top: 15px;
  padding: 10px;
  background-color: white;
  border-radius: 4px;
  border: 1px solid rgba(0, 102, 204, 0.2);
}

.pickup-hours strong {
  color: var(--gofra-text);
  font-size: 14px;
  margin-bottom: 8px;
}

.gofra-order-address .gofra-shipping-address address strong {
  color: var(--gofra-primary);
  font-weight: 600;
}

/* Кнопки действий */
.gofra-order-actions {
  display: flex;
  gap: 15px;
  padding: 20px;
  justify-content: flex-end;
  background-color: #f8f9fa;
  border-top: 1px solid #e9ecef;
  margin: 0;
}

.gofra-order-actions .gofra-btn {
  width: auto;
  position: relative;
  overflow: hidden;
  transition: var(--gofra-transition);
}

.gofra-order-actions .gofra-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.2) 50%, rgba(255,255,255,0) 100%);
  transition: all 0.6s;
}

.gofra-order-actions .gofra-btn:hover::before {
  left: 100%;
}

.view-btn {
  background-color: #555;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.view-btn:hover {
  background-color: #444;
  transform: translateY(-3px);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.pay-btn {
  background-color: var(--gofra-success);
  box-shadow: 0 2px 5px rgba(92, 184, 92, 0.2);
}

.pay-btn:hover {
  background-color: #4cae4c;
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 5px 15px rgba(92, 184, 92, 0.3);
}

/* Стили для форм адресов */
.gofra-addresses-columns {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px;
}

.gofra-address-column {
  flex: 1;
  min-width: 300px;
  padding: 0 15px;
  box-sizing: border-box;
}

.gofra-billing-address-container,
.gofra-shipping-address-container {
  background-color: #f8f9fa;
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 20px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
  height: 100%;
}

.gofra-addresses-container h4 {
  margin-top: 0;
  border-bottom: 1px solid #eee;
  padding-bottom: 10px;
  margin-bottom: 20px;
  color: #333;
}

.shipping-checkbox-top {
  margin-bottom: 20px;
  background-color: #f8f9fa;
  padding: 15px;
  border-radius: 8px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
  font-weight: 500;
}

.shipping-checkbox-top label {
  margin-bottom: 0;
  color: #333;
}

@media screen and (max-width: 768px) {
  .gofra-addresses-columns {
    display: block;
  }
  
  .gofra-address-column {
    width: 100%;
    margin-bottom: 20px;
  }
  
  .gofra-billing-address-container,
  .gofra-shipping-address-container {
    height: auto;
  }
}

/* Стили для профиля пользователя */
.gofra-profile-container {
  background: linear-gradient(135deg, #ffffff 0%, #f8fbff 100%);
  border-radius: var(--gofra-radius);
  padding: 30px;
  box-shadow: var(--gofra-shadow);
  margin-bottom: 20px;
  transition: var(--gofra-transition);
  border: 1px solid rgba(0, 115, 230, 0.05);
  position: relative;
  overflow: hidden;
}

.gofra-profile-container::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, var(--gofra-primary), #5BA0F3);
}

.gofra-profile-container:hover {
  box-shadow: 0 8px 25px rgba(0, 115, 230, 0.15);
}

.gofra-profile-container form {
  max-width: 600px;
  margin: 0 auto;
}

.password-change-section {
  margin: 20px 0;
  padding: 15px;
  background-color: var(--gofra-secondary);
  border-radius: 8px;
}

.password-change-btn {
  background-color: #555;
  width: auto !important;
}

.password-change-btn:hover {
  background-color: #444;
}

.password-change-fields {
  margin-top: 15px;
}

.form-actions {
  display: flex;
  gap: 15px;
  margin-top: 30px;
  flex-wrap: wrap;
}

.form-actions .save-btn {
  background-color: var(--gofra-primary);
  flex: 2;
  position: relative;
  overflow: hidden;
  transition: var(--gofra-transition);
}

.form-actions .save-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 15px rgba(0, 115, 230, 0.3);
}

.form-actions .save-btn::after {
  content: "✓";
  position: absolute;
  color: white;
  font-size: 0;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s ease;
}

.form-actions .save-btn:hover::after {
  font-size: 18px;
}

.form-actions .delete-account-btn {
  background-color: var(--gofra-error);
  flex: 1;
  position: relative;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.form-actions .delete-account-btn:hover {
  background-color: #c9302c;
  transform: translateY(-3px);
  box-shadow: 0 6px 15px rgba(217, 83, 79, 0.3);
}

.form-actions .delete-account-btn::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, rgba(255,255,255,0) 70%);
  transform: scale(0);
  opacity: 0;
  transition: all 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.form-actions .delete-account-btn:hover::before {
  transform: scale(2);
  opacity: 1;
}

/* Стили для формы подтверждения email */
.gofra-email-confirmation {
  flex: 0 0 60%;
  padding: 30px;
  position: relative;
  width: 100%;
  min-height: 100%;
  background: linear-gradient(135deg, #ffffff 0%, #f5f8fd 100%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

.gofra-email-confirmation::before {
  content: "";
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(45deg, var(--gofra-primary), #5BA0F3, var(--gofra-primary));
  z-index: -1;
  border-radius: calc(var(--gofra-radius) + 2px);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.gofra-email-confirmation:hover::before {
  opacity: 0.6;
}

.gofra-email-confirmation .gofra-login-header {
  width: 100%;
  margin-bottom: 30px;
}

.gofra-email-confirmation .gofra-login-header h2 {
  flex: 1;
  text-align: left;
}

.gofra-email-confirmation .header-controls {
  margin-left: auto;
}

.gofra-email-confirmation .confirmation-message {
  margin: 30px auto 40px;
  max-width: 420px;
}

.gofra-email-confirmation .confirmation-message h3 {
  color: var(--gofra-text);
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 15px;
}

.gofra-email-confirmation .confirmation-message p {
  color: #4a4a4a;
  line-height: 1.6;
}

.gofra-email-confirmation .confirmation-icon {
  width: 96px;
  height: 96px;
  margin: 0 auto 25px;
  border-radius: 50%;
  background: rgba(0, 102, 204, 0.08);
  color: var(--gofra-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  box-shadow: 0 10px 30px rgba(0, 102, 204, 0.15);
}

.gofra-email-confirmation .confirmation-icon::before {
  content: "";
  display: block;
  width: 56px;
  height: 56px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230066CC' stroke-width='1.5'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.gofra-email-confirmation .gofra-btn {
  align-self: center;
  width: 100%;
  max-width: 260px;
}


.small-text {
  font-size: 14px;
  color: #777;
  margin-top: 15px;
}

#resend-confirmation {
  color: var(--gofra-primary);
  text-decoration: none;
  font-weight: 600;
}

/* Стили для валидации полей */
.invalid-input {
  border-color: var(--gofra-error) !important;
  background-color: rgba(217, 83, 79, 0.05) !important;
}

.error-message {
  color: var(--gofra-error);
  font-size: 12px;
  margin-top: 5px;
  font-style: italic;
}

/* Стили для кнопки "назад" */
.gofra-back-button,
.gofra-back-button:link,
.gofra-back-button:visited {
  background: none;
  border: none;
  font-size: 24px;
  color: #ffffff !important;
  cursor: pointer;
  padding: 5px 10px;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.gofra-back-button:hover,
.gofra-back-button:focus,
.gofra-back-button:active {
  color: white !important;
  background-color: var(--gofra-primary) !important;
  transform: scale(1.1);
  box-shadow: 0 3px 10px rgba(0, 115, 230, 0.3);
}

.gofra-back-button::after {
  content: "";
  position: absolute;
  background: rgba(255, 255, 255, 0.3);
  width: 100px;
  height: 100px;
  left: -50px;
  top: -50px;
  opacity: 0;
  border-radius: 50%;
  transform: scale(0);
  transition: transform 0.3s, opacity 0.3s;
}

.gofra-back-button:active::after {
  transform: scale(1);
  opacity: 1;
  transition: 0s;
}

/* Стили для уведомлений */
.gofra-notification {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10001;
  display: none;
  opacity: 0;
  transition: all 0.3s ease;
  font-family: var(--gofra-font);
}

.gofra-notification.active {
  display: block;
  opacity: 1;
}

.gofra-notification-content {
  background: white;
  border-radius: 8px;
  padding: 16px 20px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  max-width: calc(100vw - 40px);
  transform: scale(0.95);
  transition: transform 0.3s ease;
}

.gofra-notification.active .gofra-notification-content {
  transform: scale(1);
}

.gofra-notification-icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}

.gofra-notification-icon.success {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%234CAF50'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
}

.gofra-notification-icon.error {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23F44336'%3E%3Cpath d='M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z'/%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
}

.gofra-notification-message {
  flex-grow: 1;
  font-size: 16px;
  line-height: 1.5;
  color: var(--gofra-text);
  font-family: var(--gofra-font);
  font-weight: 500;
}

.gofra-notification-close {
  background: none;
  border: none;
  padding: 0;
  width: 24px;
  height: 24px;
  cursor: pointer;
  color: #999;
  font-size: 24px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.2s;
  margin-left: 10px;
}

.gofra-notification-close:hover {
  color: var(--gofra-text);
}

.gofra-notification-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  z-index: 10000;
  opacity: 0;
  transition: opacity 0.3s ease;
  display: none;
}

.gofra-notification-overlay.active {
  display: block;
  opacity: 1;
}

/* Стили для анимации загрузки */
.gofra-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  text-align: center;
  color: var(--gofra-text);
  font-family: var(--gofra-font);
  background-color: #f8f9fa;
  border-radius: var(--gofra-radius);
  margin: 20px 0;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.gofra-loading p {
  margin-top: 15px;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 500;
  color: var(--gofra-primary);
}

.gofra-spinner {
  width: 50px;
  height: 50px;
  animation: spin 2s linear infinite;
}

.gofra-spinner .path {
  stroke: var(--gofra-primary);
  stroke-linecap: round;
  animation: dash 1.5s ease-in-out infinite;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes dash {
  0% {
    stroke-dasharray: 1, 150;
    stroke-dashoffset: 0;
  }
  50% {
    stroke-dasharray: 90, 150;
    stroke-dashoffset: -35;
  }
  100% {
    stroke-dasharray: 90, 150;
    stroke-dashoffset: -124;
  }
}

/* Стили для пагинации */
.gofra-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  margin: 30px 0;
  padding: 25px 20px;
  border-top: 2px solid #e9ecef;
  font-family: var(--gofra-font);
  background-color: #f8f9fa;
  border-radius: 0 0 var(--gofra-radius) var(--gofra-radius);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.gofra-pagination-info {
  font-size: 15px;
  color: var(--gofra-text);
  margin-right: 25px;
  font-weight: 600;
  background-color: white;
  padding: 8px 15px;
  border-radius: 20px;
  border: 1px solid #e9ecef;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.gofra-pagination-buttons {
  display: flex;
  gap: 5px;
  align-items: center;
  flex-wrap: wrap;
}

#orders-page-numbers {
  display: flex;
  gap: 3px;
  align-items: center;
}

.gofra-pagination-buttons .gofra-pagination-btn,
.gofra-pagination-buttons .gofra-pagination-btn:link,
.gofra-pagination-buttons .gofra-pagination-btn:visited {
  background-color: #ffffff !important;
  color: var(--gofra-text) !important;
  border-color: #ddd !important;
}

.gofra-pagination-btn {
  padding: 10px 14px;
  border: 2px solid #ddd;
  background-color: white;
  color: var(--gofra-text);
  text-decoration: none;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  cursor: pointer;
  font-family: var(--gofra-font);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  line-height: 1;
}

.gofra-pagination-btn,
.gofra-pagination-btn:visited {
  background-color: #ffffff;
  color: var(--gofra-text);
}

.gofra-pagination-btn:hover:not(.disabled) {
  background-color: var(--gofra-primary);
  color: white;
  border-color: var(--gofra-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 115, 230, 0.2);
}

.gofra-pagination-btn.active {
  background-color: var(--gofra-primary);
  color: white;
  border-color: var(--gofra-primary);
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(0, 115, 230, 0.3);
}

.gofra-pagination-btn.disabled {
  background-color: #f8f9fa;
  color: #aaa;
  border-color: #e9ecef;
  cursor: not-allowed;
  transform: none;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  opacity: 0.6;
}

.gofra-pagination-btn.disabled:hover {
  background-color: #f8f9fa;
  color: #aaa;
  border-color: #e9ecef;
  transform: none;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.gofra-pagination-ellipsis {
  padding: 10px 14px;
  color: #777;
  font-size: 16px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  line-height: 1;
  letter-spacing: 2px;
}

/* Стили для "нет заказов" */
.gofra-no-orders {
  text-align: center;
  padding: 60px 20px;
  background-color: #f8f9fa;
  border-radius: var(--gofra-radius);
  margin: 20px 0;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  border: 2px dashed #ddd;
}

.gofra-no-orders p {
  font-size: 18px;
  color: var(--gofra-text);
  margin-bottom: 20px;
  font-weight: 500;
}

.gofra-no-orders .shop-btn {
  display: inline-block;
  text-decoration: none;
  width: auto;
  max-width: 250px;
  margin: 0 auto;
}

/* Адаптивные стили для пагинации */
@media (max-width: 768px) {
  .gofra-pagination {
    flex-direction: column;
    gap: 20px;
    padding: 20px 15px;
  }
  
  .gofra-pagination-info {
    margin-right: 0;
    margin-bottom: 0;
    order: 2;
    font-size: 14px;
    padding: 6px 12px;
  }
  
  .gofra-pagination-buttons {
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    order: 1;
  }
  
  #orders-page-numbers {
    gap: 4px;
  }
  
  .gofra-pagination-btn {
    padding: 8px 10px;
    font-size: 14px;
    min-width: 40px;
    min-height: 40px;
  }
  
  .gofra-pagination-ellipsis {
    padding: 8px 10px;
    font-size: 14px;
    min-width: 40px;
    min-height: 40px;
  }
}

@media (max-width: 480px) {
  .gofra-pagination {
    padding: 15px 10px;
    gap: 15px;
  }
  
  .gofra-pagination-buttons {
    gap: 5px;
  }
  
  #orders-page-numbers {
    gap: 3px;
  }
  
  .gofra-pagination-btn {
    padding: 6px 8px;
    font-size: 13px;
    min-width: 36px;
    min-height: 36px;
    border-width: 1px;
  }
  
  .gofra-pagination-ellipsis {
    padding: 6px 8px;
    font-size: 13px;
    min-width: 36px;
    min-height: 36px;
  }
  
  .gofra-pagination-info {
    font-size: 13px;
    padding: 5px 10px;
  }
  
  .gofra-loading {
    padding: 30px 15px;
  }
  
  .gofra-loading p {
    font-size: 14px;
  }
  
  .gofra-spinner {
    width: 40px;
    height: 40px;
  }
}

/* Стили для формы сброса пароля */
.gofra-reset-password-form-container {
  max-width: 600px;
  margin: 50px auto;
  padding: 30px;
  background-color: #f8f8f8;
  border-radius: var(--gofra-radius);
  box-shadow: var(--gofra-shadow);
  font-family: var(--gofra-font);
}

.success-message {
  text-align: center;
  padding: 20px;
}

.success-icon {
  display: inline-block;
  width: 60px;
  height: 60px;
  line-height: 60px;
  font-size: 30px;
  color: white;
  background-color: var(--gofra-success);
  border-radius: 50%;
  margin-bottom: 20px;
}

/* Анимация появления заказов */
@keyframes orderAppear {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#gofra-user-orders {
  animation: slideIn 0.5s ease-out forwards;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateX(-30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.gofra-orders-list .gofra-order-item {
  animation: orderAppear 0.4s ease-out forwards;
  opacity: 0;
}

/* Анимация для первых 10 элементов (для пагинации по 10) */
.gofra-orders-list .gofra-order-item:nth-child(1) { animation-delay: 0.05s; }
.gofra-orders-list .gofra-order-item:nth-child(2) { animation-delay: 0.1s; }
.gofra-orders-list .gofra-order-item:nth-child(3) { animation-delay: 0.15s; }
.gofra-orders-list .gofra-order-item:nth-child(4) { animation-delay: 0.2s; }
.gofra-orders-list .gofra-order-item:nth-child(5) { animation-delay: 0.25s; }
.gofra-orders-list .gofra-order-item:nth-child(6) { animation-delay: 0.3s; }
.gofra-orders-list .gofra-order-item:nth-child(7) { animation-delay: 0.35s; }
.gofra-orders-list .gofra-order-item:nth-child(8) { animation-delay: 0.4s; }
.gofra-orders-list .gofra-order-item:nth-child(9) { animation-delay: 0.45s; }
.gofra-orders-list .gofra-order-item:nth-child(10) { animation-delay: 0.5s; }

/* Адаптивные стили */
@media (max-width: 768px) and (min-width: 531px) {
  /* Стили для планшетов - таблица с горизонтальной прокруткой */
  .gofra-order-table {
    min-width: 700px;
    font-size: 14px;
  }
  
  .gofra-order-products {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 15px;
    position: relative;
  }
  

  
  .gofra-order-products::-webkit-scrollbar {
    height: 8px;
  }
  
  .gofra-order-products::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
  }
  
  .gofra-order-products::-webkit-scrollbar-thumb {
    background: var(--gofra-primary);
    border-radius: 10px;
  }
  
  .gofra-order-table th,
  .gofra-order-table td {
    padding: 8px 12px;
    white-space: nowrap;
  }
  
  .product-name {
    min-width: 250px;
  }
  
  .product-name a {
    display: block;
    word-wrap: break-word;
    white-space: normal;
    line-height: 1.3;
    max-width: 230px;
  }
}

@media (max-width: 768px) {
  .gofra-login-container,
  .gofra-register-container,
  .gofra-forgot-password-container {
    flex-direction: column;
    width: 95%;
    max-height: 90vh;
    overflow-y: auto;
  }
  
  .gofra-login-image,
  .gofra-register-image {
    display: none;
  }
  
  .gofra-login-form,
  .gofra-register-form,
  .gofra-email-confirmation {
    flex: auto;
    padding: 20px 15px;
  }
  
  .gofra-login-header h2,
  .gofra-register-header h2 {
    font-size: 22px;
  }
  
  .form-group input[type="text"],
  .form-group input[type="email"],
  .form-group input[type="password"],
  .form-group input[type="tel"] {
    padding: 10px;
    font-size: 14px;
  }
  
  .gofra-btn {
    padding: 10px;
    font-size: 14px;
  }
  
  .checkbox-group label {
    font-size: 12px;
  }
  
  .form-group {
    margin-bottom: 15px;
  }

  .form-group.checkbox-group {
    display: flex;
    align-items: flex-start;
  }
  
  .form-group.checkbox-group input[type="checkbox"] {
    margin-top: 3px;
  }
  
  .form-group.checkbox-group label {
    margin-left: 8px;
    text-align: left;
    flex: 1;
  }
  
  .gofra-user-menu-container {
    width: 100%;
    max-width: none;
    padding: 10px;
    min-height: 100vh;
  }
  
  .user-menu-items {
    grid-template-columns: 1fr;
  }
  
  .gofra-menu-item {
    padding: 15px;
  }
  
  .gofra-section-header {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .gofra-order-header {
    flex-direction: row;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 10px 15px;
  }
  
  .gofra-order-toggle {
    flex-shrink: 0;
  }
  
  .gofra-order-info {
    flex-direction: row;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    flex: 1;
  }
  
  .gofra-order-address {
    flex-direction: column;
    margin: 0 10px 20px 10px;
    padding: 15px;
  }
  
  .gofra-order-address .gofra-billing-address,
  .gofra-order-address .gofra-shipping-address {
    min-width: auto;
    margin-bottom: 15px;
    padding: 15px;
  }
  
  .gofra-order-address .gofra-billing-address:last-child,
  .gofra-order-address .gofra-shipping-address:last-child {
    margin-bottom: 0;
  }
  
  .gofra-order-actions {
    flex-direction: column;
    width: 100%;
  }
  
  .gofra-order-actions .gofra-btn {
    width: 100%;
    text-align: center;
  }
  
  .gofra-back-button {
    font-size: 20px;
    padding: 3px 8px;
    color: #ffffff !important;
  }
  
  .form-actions {
    flex-direction: column;
  }
  
  .form-actions .save-btn,
  .form-actions .delete-account-btn {
    width: 100%;
  }
  
  .gofra-notification {
    width: 90%;
  }
  
  .gofra-notification-content {
    padding: 15px 20px;
    min-width: auto;
  }
  
  .gofra-notification-message {
    font-size: 14px;
  }
  
  .gofra-notification-icon {
    width: 24px;
    height: 24px;
  }
}

@media (max-width: 530px) {
  .gofra-register-form,
  .gofra-email-confirmation {
    padding: 15px 10px;
  }
  
  .form-group label {
    font-size: 14px;
  }
  
  .user-type-toggle {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .private-toggle, 
  .business-toggle {
    font-size: 14px;
  }
  
  /* Дополнительные стили для заголовка заказа на мобильных */
  .gofra-order-header {
    padding: 8px 12px;
  }
  
  .order-number {
    font-size: 15px;
  }
  
  .order-date {
    font-size: 12px;
  }
  
  .order-status {
    font-size: 10px;
    padding: 4px 8px;
    min-width: 70px;
    min-height: 24px;
  }
  
  .gofra-order-details-toggle {
    font-size: 12px;
  }
  
  /* Мобильная версия таблицы - горизонтальная прокрутка */
  .gofra-order-table {
    min-width: 650px;
    font-size: 13px;
  }
  
  .gofra-order-products {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 10px;
    position: relative;
  }
  

  
  .gofra-order-products::-webkit-scrollbar {
    height: 6px;
  }
  
  .gofra-order-products::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
  }
  
  .gofra-order-products::-webkit-scrollbar-thumb {
    background: var(--gofra-primary);
    border-radius: 10px;
  }
  
  .gofra-order-table th,
  .gofra-order-table td {
    padding: 6px 8px;
    white-space: nowrap;
    font-size: 12px;
  }
  
  .gofra-order-table th {
    font-size: 11px;
    padding: 8px 6px;
  }
  
  .product-name {
    min-width: 250px;
  }
  
  .product-name a {
    display: block;
    word-wrap: break-word;
    white-space: normal;
    line-height: 1.3;
    font-size: 12px;
    max-width: 230px;
  }
  
  .product-quantity {
    min-width: 60px;
    text-align: center;
  }
  
  .product-price,
  .product-subtotal {
    min-width: 70px;
    text-align: right;
  }
  
  /* Итоговая секция с прокруткой */
  .gofra-order-table tfoot th {
    font-size: 11px;
    padding: 6px 8px;
  }
  
  .gofra-order-table tfoot td {
    font-size: 12px;
    padding: 6px 8px;
  }
  
  .gofra-order-table tfoot tr.order-total th,
  .gofra-order-table tfoot tr.order-total td {
    font-size: 14px;
    font-weight: 700;
  }
}

@media (max-width: 360px) {
  .gofra-login-form,
  .gofra-register-form,
  .gofra-email-confirmation {
    padding: 15px 10px;
  }
  
  .form-group input[type="text"],
  .form-group input[type="email"],
  .form-group input[type="password"],
  .form-group input[type="tel"] {
    font-size: 13px;
  }
  
  .form-group label {
    font-size: 13px;
    margin-bottom: 5px;
  }
  
  .gofra-register-header h2 {
    font-size: 18px;
  }
}

@media (max-height: 800px) and (max-width: 768px) {
  .gofra-register-form,
  .gofra-email-confirmation {
    max-height: 70vh;
    overflow-y: auto;
    padding-right: 10px;
  }
  
  .gofra-register-form::-webkit-scrollbar,
  .gofra-email-confirmation::-webkit-scrollbar {
    width: 4px;
  }
  
  .gofra-register-form::-webkit-scrollbar-track,
  .gofra-email-confirmation::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 2px;
  }
  
  .gofra-register-form::-webkit-scrollbar-thumb,
  .gofra-email-confirmation::-webkit-scrollbar-thumb {
    background: var(--gofra-primary);
    border-radius: 2px;
  }
  
}

.gofra-confirmation-container {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10000;
  background: white;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
  max-width: 90vw;
  width: 400px;
  opacity: 0;
  transition: opacity 0.3s ease;
  font-family: var(--gofra-font);
}

.gofra-confirmation-container.active {
  opacity: 1;
}

.gofra-confirmation {
  padding: 25px;
}

.gofra-confirmation-message {
  font-size: 16px !important;
  line-height: 1.5 !important;
  color: var(--gofra-text) !important;
  margin-bottom: 20px !important;
  text-align: center !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 400 !important;
}

.gofra-confirmation-buttons {
  display: flex;
  justify-content: center;
  gap: 15px;
}

.gofra-confirmation-buttons .gofra-btn {
  width: auto;
  min-width: 100px;
  padding: 10px 20px;
  font-family: var(--gofra-font);
  font-weight: 500;
}

.gofra-confirmation-buttons .confirm-yes {
  background-color: var(--gofra-primary);
}

.gofra-confirmation-buttons .confirm-no {
  background-color: var(--gofra-error);
}

.gofra-confirmation-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.gofra-confirmation-overlay.active {
  opacity: 1;
}
