/* =========================================
   0. TIPOGRAFÍAS LOCALES
   ========================================= */
@font-face {
  font-family: 'Lexend';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/lexend-v26-latin-200.woff2') format('woff2');
  font-display: swap;
}
@font-face {
  font-family: 'Lexend';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/lexend-v26-latin-300.woff2') format('woff2');
  font-display: swap;
}
@font-face {
  font-family: 'Lexend';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/lexend-v26-latin-regular.woff2') format('woff2');
  font-display: swap;
}
@font-face {
  font-family: 'Lexend';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/lexend-v26-latin-500.woff2') format('woff2');
  font-display: swap;
}
@font-face {
  font-family: 'Lexend';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/lexend-v26-latin-600.woff2') format('woff2');
  font-display: swap;
}
@font-face {
  font-family: 'Lexend';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/lexend-v26-latin-700.woff2') format('woff2');
  font-display: swap;
}

/* =========================================
   1. VARIABLES & RESET
   ========================================= */
:root {
  --font-sans: 'Lexend', system-ui, -apple-system, sans-serif;
  --bg-page: #F8FAFC; /* Gris muy leve */
  --bg-surface: #FFFFFF;
  --text-main: #0F172A; /* Slate 900 - Azul profundo */
  --text-muted: #475569; /* Slate 600 */
  --accent: #37B8C7; /* Teal 600 */
  --accent-hover: #7ff2ff;
  --border-color: #e5eaf57e;
  --border-radius: 35px;
  --border-radius-s: 18px;
  --dark-bg: linear-gradient(132deg,rgb(44, 66, 106) 5%, rgba(15, 23, 42, 1) 80%);
  --step--2: clamp(0.7813rem, 0.7747rem + 0.0326vw, 0.8rem);
  --step--1: clamp(0.9375rem, 0.9158rem + 0.1087vw, 1rem);
  --step-0: clamp(1.125rem, 1.0815rem + 0.2174vw, 1.25rem);
  --step-1: clamp(1.35rem, 1.2761rem + 0.3696vw, 1.5625rem);
  --step-2: clamp(1.62rem, 1.5041rem + 0.5793vw, 1.9531rem);
  --step-3: clamp(1.944rem, 1.771rem + 0.8651vw, 2.4414rem);
  --step-4: clamp(2.3328rem, 2.0827rem + 1.2504vw, 3.0518rem);
  --step-5: clamp(2.7994rem, 2.4462rem + 1.7658vw, 3.8147rem);

}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: var(--font-sans);
  background-color: var(--bg-page);
  color: var(--text-main);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
/* =========================================
   MODIFICADORES DE TEMA (Modo Oscuro)
   ========================================= */
.theme-dark {
  color: var(--text-muted);
  --text-main: #FFFFFF;
  --text-muted: #CBD5E1;
  --bg-surface: rgba(255, 255, 255, 0.05);
  --border-color: rgba(255, 255, 255, 0.07);
  background: var(--dark-bg);
}
.theme-dark .card {
  box-shadow: 0 10px 45px oklch(from var(--accent) l c h / 0.13);
}
.theme-dark .sara-tags li {
  color: var(--text-muted);
}

/* =========================================
   2. LAYOUT & TYPOGRAPHY
   ========================================= */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

section[class^="block-"] {
  padding: 6rem 0;
}

h1, h2, h3, h4 {
  line-height: 1.2;
  font-weight: 600;
  color: var(--text-main);
}
.container h2 {
  font-size: var(--step-4);
  font-weight: 500;
  letter-spacing: -0.06em;
  line-height: 0.95;
}
.container h3 {
  font-size: var(--step-1);
  letter-spacing: -0.05em;
}

.section-title, .section-subtitle {
  margin-bottom: 1rem;
  text-align: center !important;
}

.body-copy, .section-intro {
  font-size: var(--step-0);
  color: var(--text-muted);
  text-align: center;
  max-width: 800px;
  margin: 0 auto 3rem auto;
}

.eyebrow {
  color: var(--accent);
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
  font-size: var(--step--1);
}

.sara-tags ul {
  display: flex;
  justify-content: flex-start; 
  flex-wrap: wrap;
  gap: 0.5rem;
  list-style: none;
  font-size: var(--step--1);
}

.sara-tags li {
  display: flex;
  justify-content: center;
  list-style: none;
  border:solid 1px var(--border-color);
  padding: 0.4rem 1.2rem 0.4rem 1.6rem;
  border-radius: var(--border-radius);
  position: relative;
}

.sara-tags li::before {
  content: '';
  position: absolute;
  left: 7px;
  top: 12px;
  width: 15px;
  height: 15px;
  background-image: url('../images/star.svg');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
/* =========================================
   RESALTADO GLOBAL DE PALABRAS CLAVE
   ========================================= */
h1 em, h2 em, h3 em, 
.headline em, .section-title em, .proof-title em {
  font-style: normal;
  color: var(--accent);
  text-shadow: 0 0 30px oklch(from var(--accent-hover) l c h / 0.6);
}

/* =========================================
   3. BOTONES (CTAs)
   ========================================= */
.btn {
  display: inline-block;
  padding: 0.8rem 1.5rem;
  font-weight: 600;
  border-radius: var(--border-radius);
  text-decoration: none;
  transition: all 0.2s ease;
  cursor: pointer;
}

.btn-primary {
  font-size: var(--step--1);
  background-color: var(--accent);
  color: #fff;
  border: 1px solid var(--accent);
  box-shadow: 0 8px 40px oklch(from var(--accent) l c h / 0.5);
}

.btn-primary:hover {
  background-color: var(--accent-hover);
  border-color: var(--accent-hover);
}

.btn-secondary {
  font-size: var(--step--1);
  background-color: transparent;
  color: var(--accent);
  border: 1px solid var(--accent);
}

.btn-secondary:hover {
  border-color: var(--accent-hover);
  color: var(--accent-hover);
}

.cta-group, .cta-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: 2rem;
}
@media (max-width: 767px) {
  .btn {
    padding: 0.8rem 0.8rem;
  }
  .cta-group {
    gap: 0.5rem;
  }
}

/* =========================================
   4. BLOQUES ESPECÍFICOS
   ========================================= */
/* Hero 2 columns */
.block-hero {
  padding:0 !important;
  overflow: hidden;
  align-content: center;
}

/* Configuramos el Grid (Mobile First) */
.hero-layout {
  display: grid;
  grid-template-columns: 1fr;
}

/* Orden en Móviles: Texto primero, imagen después */
.hero-content {
  order: 1;
  align-content: center;
  padding: 5rem 0 1.5rem 0;
}
.hero-visual {
  order: 2;
  display: flex;
  align-items: flex-end; /* Centramos la persona en móviles */
}

/* Estilos de la imagen / avatar */
.hero-img {
  width: 100%;
  height: auto;
  display: block;
}

/* Tipografía y alineaciones del Hero */
.block-hero h1 {
  font-size: var(--step-5);
  line-height: 1.1;
  letter-spacing: -0.06em;
  margin: 1.5rem 0;
}

.block-hero .subheadline {
  font-size: var(--step-0);
  max-width: 600px;
  margin-bottom: 2.5rem;
}
/* Botones alineados a la izquierda */
.block-hero .cta-group {
  justify-content: flex-start; 
  margin-bottom: 2.5rem;
}

/* Breakpoint para Desktop (2 columnas) */
@media (min-width: 992px) {
  .hero-content {
    padding: 12rem 0;
}
  .hero-layout {
    grid-template-columns: 1.1fr 0.9fr; 
    gap: 0;
  }
  .hero-visual {
    justify-content: flex-end; /* Alineamos a la persona hacia la derecha */
  }
}

/* =========================================
   PROOF STRIP (2 Columnas Dinámicas)
   ========================================= */
.proof-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
/* --- Orden por defecto en móviles --- */
.proof-content {
  order: 1;
}
.proof-visual {
  order: 2;
}

/* Modificador: Si en móviles eligieron "Imagen Arriba" */
.is-mobile-reversed .proof-content {
  order: 2;
}
.is-mobile-reversed .proof-visual {
  order: 1;
}

/* Estilos de la imagen y textos */
.proof-img {
  width: 100%;
  height: auto;
  border-radius: var(--border-radius);
}
.proof-visual .prompt-img {
  width: 100%;
  height: auto;
  border-radius: var(--border-radius);
  box-shadow: 0 8px 35px oklch(from var(--text-main) l c h / 0.3);
}

.proof-title {
  margin-bottom: 1.5rem;
}

.proof-items ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.proof-items li {
  border:solid 1px var(--border-color);
  padding: 0.5rem 1.2rem;
  border-radius: var(--border-radius);
  width: fit-content;
}

/* --- Breakpoint para Desktop --- */
@media (min-width: 992px) {
  .proof-layout {
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
  }
  
  /* Restauramos el orden natural para escritorio por defecto */
  .proof-content { order: 1; }
  .proof-visual { order: 2; }
  
  /* Modificador: Si en escritorio eligieron "Imagen Izquierda" */
  .is-desktop-reversed .proof-content { order: 2; }
  .is-desktop-reversed .proof-visual { order: 1; }
}

/* Grillas comunes (Tarjetas, Motions, Use Cases) */
.cards-grid, .motions-grid, .use-cases-list, .partner-pillars-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

/* Estilo Enterprise de Tarjeta (Cards) */
.card, .motion-card, .use-case-item, .pillar-card {
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
  padding: 2rem;
  border-radius: var(--border-radius-s);
  box-shadow: 0 10px 45px oklch(from var(--text-main) l c h / 0.04);
}

.card-title, .motion-title, .use-case-title {
  font-size: 1.25rem;
  margin-bottom: 1rem;
  color: var(--accent);
}

/* Listas (Viñetas / Bullets) */
ul {
  list-style-position: inside;
  color: var(--text-muted);
}

/* Audience Switcher (Tabs base) */
.tab-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2rem;
}

.tab-btn {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  padding: 1rem 2rem;
  font-family: var(--text-main);
  font-size: var(--step--2);
  font-weight: 600;
  border-radius: var(--border-radius);
  cursor: pointer;
}

.tab-btn.active {
  border-color: var(--text-main);
  background: var(--text-main);
  color: #fff;
}

.bottom-line {
  text-align: center;
  font-weight: 600;
  color: var(--text-muted);
}
/* =========================================
   TOWER CONTROL SECTION
   ========================================= */
.tower-description {
  display: grid;
  grid-template-columns: 1fr;
  gap:1rem;
  margin-top:4rem;
}
.tower-description .tower-tags {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.tower-description .value-statement {
  color: var(--accent);
  font-weight: 600;
  margin-top: 1.5rem;
}
/* =========================================
   DEMO SECTION (2 Columnas Dinámicas)
   ========================================= */
.demo-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
/* --- Orden por defecto en móviles --- */
.demo-content { order: 1; }
.demo-visual { order: 2; }
/* Modificador: Si en móviles eligieron "Visual Arriba" */
.block-demo-section.is-mobile-reversed .demo-content { order: 2; }
.block-demo-section.is-mobile-reversed .demo-visual { order: 1; }
.demo-img {
  width: 100%;
  height: auto;
  border-radius: var(--border-radius);
}
/* --- Breakpoint para Desktop --- */
@media (min-width: 992px) {
  .demo-layout {
    grid-template-columns: 1fr 1fr; /* Dividimos a partes iguales */
    gap: 5rem;
  }
  
  /* Restauramos el orden natural para escritorio por defecto */
  .demo-content { order: 1; }
  .demo-visual { order: 2; }
  
  /* Modificador: Si en escritorio eligieron "Visual Izquierda" */
  .block-demo-section.is-desktop-reversed .demo-content { order: 2; }
  .block-demo-section.is-desktop-reversed .demo-visual { order: 1; }
}
/* =========================================
   6. FAQS
   ========================================= */
.block-faq h2 {
  margin-bottom: 4rem;
}
.faq-item {
  margin-bottom: 1rem;
}
.block-trust {
  text-align: center;
}
.block-trust .section-title {
  margin-bottom: 3rem;
}
.block-trust .sara-tags, .block-ecosystem .sara-tags {
  display:flex;
  justify-content: center;
  margin-bottom: 3rem;
}
.closing-line {
  font-size: var(--step-0);
  color: var(--text-muted);
}
/* =========================================
   5. HEADER & NAVEGACIÓN
   ========================================= */
/* --- Logo --- */
.site-logo {
  height: 30px; /* Ajusta este valor dependiendo de si tu logo es horizontal o cuadrado */
  width: auto;
  display: block;
}
/* En móviles lo podemos hacer un pelín más pequeño si es necesario */
@media (max-width: 767px) {
  .site-logo {
    height: 22px;
  }
}

.site-header {
  background-color: var(--bg-surface);
  border-bottom: 1px solid var(--border-color);
  padding: 0.7rem 0;
  position: sticky;
  top: 0;
  z-index: 100;
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap; /* Permite que el menú móvil caiga a la siguiente línea */
}

/* Controles (Idioma + Hamburguesa) */
.header-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
}

/* --- Dropdown de Idiomas --- */
.lang-dropdown {
  position: relative;
}

.lang-toggle {
  background: transparent;
  border: 1px solid var(--border-color);
  color: var(--text-main);
  padding: 0.5rem 0.75rem;
  border-radius: var(--border-radius);
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  transition: all 0.2s;
}

.lang-toggle:hover {
  background-color: var(--bg-page);
}

.lang-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 0.5rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-s);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  min-width: 160px;
  display: none; /* Oculto por defecto */
  flex-direction: column;
  overflow: hidden;
}

.lang-menu.is-open {
  display: flex;
}

.lang-link {
  padding: 0.75rem 1rem;
  text-decoration: none;
  color: var(--text-muted);
  font-size: 0.875rem;
  font-weight: 600;
  transition: background 0.2s;
}

.lang-link:hover, .lang-link.active {
  background-color: var(--bg-page);
  color: var(--accent);
}

/* --- Botón Hamburguesa --- */
.mobile-toggle {
  display: flex;
  flex-direction: column;
  gap: 5px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.25rem;
}

.hamburger-line {
  width: 24px;
  height: 2px;
  background-color: var(--text-main);
  transition: all 0.3s ease;
}

/* Animación de cruz (X) al abrir */
.mobile-toggle.is-active .hamburger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.mobile-toggle.is-active .hamburger-line:nth-child(2) {
  opacity: 0;
}
.mobile-toggle.is-active .hamburger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* --- Navegación Principal (Mobile First) --- */
.main-nav {
  display: none; /* Oculto por defecto en móviles */
  width: 100%;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem 0 0.5rem 0;
  border-top: 1px solid var(--border-color);
  margin-top: 1rem;
}

.main-nav.is-open {
  display: flex;
}

.nav-link {
  color: var(--text-muted);
  text-decoration: none;
  font-weight: 400;
  transition: color 0.2s;
}

.nav-link:hover {
  color: var(--text-main);
}

/* --- Breakpoint para Desktop --- */
@media (min-width: 768px) {
  .header-inner {
    flex-wrap: nowrap;
  }
  
  .mobile-toggle {
    display: none; /* Ocultamos hamburguesa en PC */
  }
  
  .header-controls {
    order: 3; /* Mandamos los controles a la extrema derecha */
  }
  
  .main-nav {
    display: flex;
    flex-direction: row;
    width: auto;
    border-top: none;
    padding: 0;
    margin-top: 0;
    order: 2; /* Centramos la navegación */
  }
  
  .nav-link {
    font-size: var(--step--1);
  }
}

/* =========================================
   HEADER TRANSPARENTE (Modificador)
   ========================================= */

/* Transiciones suaves para todos los elementos del header */
.site-header, .site-logo, .nav-link, .lang-toggle, .hamburger-line {
  transition: all 0.3s ease;
}

/* 1. ESTADO INICIAL (Arriba del todo) */
.header-transparent {
  position: fixed; /* Lo saca del flujo para que el Hero suba */
  width: 100%;
  top: 0;
  left: 0;
  background-color: transparent;
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

/* Forzamos los textos y botones a blanco */
.header-transparent .nav-link,
.header-transparent .logo a { color: #ffffff; }
.header-transparent .lang-toggle { color: #ffffff; border-color: rgba(255, 255, 255, 0.4); }
.header-transparent .lang-toggle:hover { background-color: rgba(255, 255, 255, 0.1); }
.header-transparent .hamburger-line { background-color: #ffffff; }
.header-transparent .site-logo { filter: brightness(0) invert(1); }

.header-transparent .lang-toggle {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.4);
}

.header-transparent .lang-toggle:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

.header-transparent .hamburger-line {
  background-color: #ffffff;
}

/* El truco mágico: vuelve blanco cualquier logo SVG/PNG oscuro */
.header-transparent .site-logo {
  filter: brightness(0) invert(1);
}


/* 2. ESTADO SCROLLEADO (Vuelve a ser sólido y oscuro) */
.header-transparent.is-scrolled,
.header-transparent.has-open-menu {
  background-color: var(--bg-surface);
  border-bottom-color: var(--border-color);
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
}
/* Revertimos colores a la normalidad en ambos casos */
.header-transparent.is-scrolled .nav-link,
.header-transparent.has-open-menu .nav-link { color: var(--text-muted); }

.header-transparent.is-scrolled .nav-link:hover,
.header-transparent.has-open-menu .nav-link:hover { color: var(--text-main); }

.header-transparent.is-scrolled .lang-toggle,
.header-transparent.has-open-menu .lang-toggle { color: var(--text-main); border-color: var(--border-color); }

.header-transparent.is-scrolled .lang-toggle:hover,
.header-transparent.has-open-menu .lang-toggle:hover { background-color: var(--bg-page); }

.header-transparent.is-scrolled .hamburger-line,
.header-transparent.has-open-menu .hamburger-line { background-color: var(--text-main); }

.header-transparent.is-scrolled .site-logo,
.header-transparent.has-open-menu .site-logo { filter: none; }

/* =========================================
   6. FOOTER
   ========================================= */
.site-footer {
  background-color: var(--text-main); /* El mismo azul profundo del Hero */
  color: #fff;
  padding: 5rem 0 2rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05); /* Línea sutil para separar si el bloque anterior es oscuro */
}

.footer-inner {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-bottom: 4rem;
}

.footer-logo {
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #ffffff;
  margin-bottom: 1rem;
}

.footer-description {
  color: #94A3B8; /* Slate 400 */
  font-size: 1rem;
  line-height: 1.6;
  max-width: 350px;
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.footer-link {
  color: #CBD5E1;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  transition: color 0.2s ease;
}

.footer-link:hover {
  color: var(--accent);
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-copyright {
  color: #64748B; /* Slate 500 */
  font-size: 0.875rem;
}

/* --- Breakpoint para Desktop --- */
@media (min-width: 768px) {
  .footer-inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }

  .footer-links {
    flex-direction: row;
    gap: 2rem;
  }
}
.tmwk {
  font-size: 0.7rem;
  text-decoration: none;
  color:#64748B;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.tmwk img {
  opacity: 0.6;
}

/* =========================================
   7. MODAL DE CONTACTO
   ========================================= */
.modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(15, 23, 42, 0.85);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  
  /* Oculto por defecto con transiciones suaves */
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.modal-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.modal-dialog {
  background-color: var(--bg-surface);
  width: 100%;
  max-width: 480px;
  padding: 2.5rem;
  border-radius: var(--border-radius);
  position: relative;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  
  /* Efecto de entrada desde abajo */
  transform: translateY(20px);
  transition: transform 0.3s ease;
}

.modal-overlay.is-open .modal-dialog {
  transform: translateY(0);
}

.modal-close {
  position: absolute;
  top: 1rem;
  right: 1.5rem;
  background: none;
  border: none;
  font-size: 2rem;
  color: var(--text-muted);
  cursor: pointer;
  line-height: 1;
  transition: color 0.2s;
}

.modal-close:hover {
  color: var(--text-main);
}

.modal-header {
  margin-bottom: 2rem;
  text-align: center;
}

.modal-title {
  font-size: 1.75rem;
  margin-bottom: 0.5rem;
}

.modal-subtitle {
  color: var(--text-muted);
  font-size: 0.95rem;
}

/* --- Estilos del Formulario --- */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-group label {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-main);
}

.form-group input {
  padding: 0.875rem 1rem;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  font-family: inherit;
  font-size: 1rem;
  color: var(--text-main);
  background-color: var(--bg-page);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.form-group input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.1);
}

.form-group input,
.form-group select {
  padding: 0.875rem 1rem;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  font-family: inherit;
  font-size: 1rem;
  color: var(--text-main);
  background-color: var(--bg-page);
  transition: border-color 0.2s, box-shadow 0.2s;
  width: 100%;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%2394A3B8%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem top 50%;
  background-size: 0.65rem auto;
}

.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.1);
}

.btn-block {
  width: 100%;
  margin-top: 1rem;
  padding: 1rem;
  font-size: 1.05rem;
}