/* Global styles for WeDoTranslate site (v4) */
:root {
  --bg-page:#f9f9f5;
  --bg-card:#ffffff;
  --text-main:#1a1a1a;
  --text-dim:rgba(26,26,26,.7);
  --text-faint:rgba(26,26,26,.5);
  --accent-main:#3b1b75;
  --accent-main-hover:#2a1255;
  --accent-pill:#e7d6ff;
  --accent-pill-text:#3b1b75;
  --accent-badge:#facc15;
  --border-soft:rgba(0,0,0,.08);
  --radius-lg:1rem;
  --radius-md:.6rem;
  --radius-round:9999px;
  --font-head:'Manrope',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',sans-serif;
  --font-body:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',sans-serif;
}

* {
  margin:0;
  padding:0;
  box-sizing:border-box;
  -webkit-font-smoothing:antialiased;
}

body {
  background:var(--bg-page);
  color:var(--text-main);
  font-family:var(--font-body);
  line-height:1.5;
  font-size:16px;
}

img {max-width:100%;display:block;}
a {color:var(--accent-main);text-decoration:none;}
a:hover {color:var(--accent-main-hover);}

/* HEADER */
.header {
  background:var(--bg-page);
  border-bottom:1px solid var(--border-soft);
}
.header-inner {
  max-width:1280px;
  margin:0 auto;
  padding:1rem;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  row-gap:1rem;
}
.brand-block {
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:.75rem;
}
.brand-logo {
  width:40px;
  height:40px;
  border-radius:var(--radius-md);
  background:var(--accent-main);
  color:#fff;
  font-family:var(--font-head);
  font-size:.7rem;
  line-height:40px;
  font-weight:600;
  text-align:center;
  position:relative;
}
.brand-logo::after {
  content:"";
  position:absolute;
  inset:0;
  border-radius:var(--radius-md);
  border:2px solid rgba(255,255,255,.4);
}
.brand-lines {
  display:flex;
  flex-direction:column;
  line-height:1.2;
}
.brand-name {
  font-family:var(--font-head);
  font-size:.9rem;
  font-weight:600;
  color:var(--text-main);
  letter-spacing:-0.04em;
}
.brand-sub {
  font-size:.7rem;
  font-weight:500;
  color:var(--text-dim);
}

.nav-row {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:1rem 1.5rem;
  font-size:.8rem;
  font-weight:500;
  color:var(--text-main);
}
.nav-row a {color:var(--text-main);}
.nav-row a.active {color:var(--accent-main);font-weight:600;}

.lang-switch {
  display:flex;
  align-items:center;
  gap:.5rem;
  font-size:.7rem;
  font-weight:500;
}
.lang-pill {
  background:var(--accent-pill);
  color:var(--accent-pill-text);
  border-radius:var(--radius-md);
  border:1px solid rgba(59,27,117,.2);
  padding:.4rem .6rem;
  cursor:pointer;
  user-select:none;
}
.lang-pill.active {
  background:var(--accent-main);
  color:#fff;
  border:1px solid var(--accent-main);
}

/* HERO */
.hero {
  background:var(--bg-page);
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--border-soft);
}
.hero-inner {
  max-width:1280px;
  margin:0 auto;
  padding:2.5rem 1rem 3rem;
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
}
@media(min-width:1024px){
  .hero-inner {
    grid-template-columns:minmax(0,1fr) minmax(320px,400px);
    align-items:center;
  }
}
.hero-left {
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  max-width:38rem;
}
.hero-eyebrow {
  font-size:.7rem;
  line-height:1rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent-main);
}
.hero-title {
  font-family:var(--font-head);
  font-size:2rem;
  line-height:1.15;
  font-weight:600;
  color:var(--text-main);
  letter-spacing:-0.045em;
}
@media(min-width:640px){.hero-title{font-size:2.4rem;}}
.hero-desc {
  font-size:1rem;
  line-height:1.5rem;
  color:var(--text-dim);
  font-weight:400;
}
.hero-desc strong {color:var(--text-main);font-weight:600;}
.price-line {
  font-size:.8rem;
  line-height:1.2rem;
  color:var(--text-faint);
}
.price-line strong {color:var(--text-main);font-weight:600;}
.hero-cta-row {
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
}
.btn-primary {
  background:var(--accent-main);
  color:#fff;
  font-size:.9rem;
  line-height:1.25rem;
  font-weight:600;
  border-radius:var(--radius-md);
  border:1px solid var(--accent-main);
  padding:.75rem 1rem;
  box-shadow:0 20px 40px rgba(59,27,117,.35);
  cursor:pointer;
}
.btn-primary:hover {
  background:var(--accent-main-hover);
  border-color:var(--accent-main-hover);
}
.btn-link {
  font-size:.8rem;
  line-height:1rem;
  color:var(--text-main);
  font-weight:500;
  display:flex;
  align-items:center;
  gap:.4rem;
}
.btn-link span {color:var(--accent-main);font-weight:600;}

.hero-right-card {
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  box-shadow:0 30px 80px rgba(0,0,0,.07);
  position:relative;
  padding:1rem;
  display:flex;
  flex-direction:column;
  gap:.75rem;
  min-height:260px;
  overflow:hidden;
}
.hero-right-photo {
  width:100%;
  border-radius:var(--radius-md);
  overflow:hidden;
  border:1px solid var(--border-soft);
  box-shadow:0 20px 40px rgba(0,0,0,.08);
}
.hero-right-photo img {
  width:100%;
  height:auto;
  object-fit:cover;
}
.hero-badge-row {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.5rem;
  font-size:.7rem;
  line-height:1rem;
  font-weight:500;
}
.hero-badge {
  background:var(--accent-badge);
  color:#1a1a1a;
  border-radius:var(--radius-round);
  padding:.4rem .6rem;
  border:1px solid rgba(0,0,0,.1);
  font-weight:600;
  font-size:.7rem;
  line-height:1rem;
}
.hero-langs {
  font-size:.7rem;
  line-height:1rem;
  color:var(--text-dim);
}
.hero-note {
  font-size:.7rem;
  line-height:1rem;
  color:var(--text-faint);
}

/* SECTIONS */
.section {
  max-width:1280px;
  margin:0 auto;
  padding:2.5rem 1rem 3rem;
}
.section-head {
  max-width:48rem;
  margin:0 auto 2rem;
  text-align:center;
}
.section-eyebrow {
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent-main);
  margin-bottom:.5rem;
}
.section-title {
  font-family:var(--font-head);
  font-size:1.4rem;
  line-height:1.2;
  font-weight:600;
  color:var(--text-main);
  letter-spacing:-0.04em;
  margin-bottom:.75rem;
}
.section-desc {
  font-size:.9rem;
  line-height:1.4rem;
  color:var(--text-dim);
}

/* CARDS */
.cards-3 {
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
}
@media(min-width:768px){
  .cards-3 {grid-template-columns:repeat(3,1fr);}
}
.card {
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  box-shadow:0 20px 60px rgba(0,0,0,.05);
  padding:1rem 1rem 1.25rem;
  display:flex;
  flex-direction:column;
  gap:.75rem;
  text-align:left;
}
.card-icon {
  width:44px;
  height:44px;
  border-radius:var(--radius-md);
  background:var(--accent-pill);
  border:1px solid rgba(59,27,117,.25);
  color:var(--accent-main);
  font-size:.7rem;
  line-height:44px;
  font-weight:600;
  text-align:center;
  box-shadow:0 20px 40px rgba(59,27,117,.15);
}
.card-title {
  font-size:1rem;
  line-height:1.3rem;
  font-weight:600;
  color:var(--text-main);
  letter-spacing:-0.03em;
}
.card-text {
  font-size:.9rem;
  line-height:1.4rem;
  color:var(--text-dim);
}

/* FAQ */
.faq-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
}
@media(min-width:1024px){
  .faq-grid {
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  }
}
.faq-left {
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.faq-left-note {
  font-size:.8rem;
  line-height:1.3rem;
  color:var(--text-dim);
  max-width:28rem;
}
.faq-list {max-width:40rem;}
.faq-item {
  border-top:1px solid var(--border-soft);
  padding-top:1rem;
  margin-bottom:1rem;
}
.faq-q {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  cursor:pointer;
}
.faq-question {
  font-size:1rem;
  line-height:1.4rem;
  color:var(--text-main);
  font-weight:600;
  letter-spacing:-0.03em;
}
.faq-toggle {
  font-size:.75rem;
  line-height:1rem;
  color:var(--text-faint);
}
.faq-answer {
  font-size:.9rem;
  line-height:1.4rem;
  color:var(--text-dim);
  margin-top:.75rem;
  display:none;
}
.faq-item.open .faq-answer {display:block;}

/* CONTACT FORM PAGE */
.contact-singlecol {
  max-width:480px;
  margin:0 auto;
}

.form-card {
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  box-shadow:0 30px 80px rgba(0,0,0,.07);
  padding:1rem 1rem 1.25rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.form-field label {
  font-size:.75rem;
  line-height:1rem;
  font-weight:500;
  color:var(--text-faint);
  display:block;
  margin-bottom:.4rem;
}
.form-field input,
.form-field textarea {
  width:100%;
  font-family:var(--font-body);
  font-size:.9rem;
  line-height:1.3rem;
  color:var(--text-main);
  background:#fff;
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  padding:.7rem .75rem;
  outline:none;
  box-shadow:0 20px 40px rgba(0,0,0,.03) inset;
}
.form-field textarea {
  resize:none;
  min-height:5rem;
}
.form-submit {
  display:inline-block;
  text-align:center;
  background:var(--accent-main);
  color:#fff;
  font-size:.9rem;
  line-height:1.25rem;
  font-weight:600;
  padding:.75rem 1rem;
  border-radius:.6rem;
  border:1px solid var(--accent-main);
  box-shadow:0 20px 40px rgba(59,27,117,.35);
  cursor:pointer;
  width:100%;
}
.form-submit:hover {
  background:var(--accent-main-hover);
  border-color:var(--accent-main-hover);
}

/* Pop-up success */
.popup-overlay {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.4);
  display:none;
  align-items:center;
  justify-content:center;
  padding:1rem;
  z-index:9999;
}
.popup-overlay.show {display:flex;}
.popup-card {
  background:#fff;
  border-radius:1rem;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 40px 120px rgba(0,0,0,.4);
  max-width:320px;
  width:100%;
  padding:1.5rem 1.25rem;
  text-align:center;
  font-family:var(--font-body);
}
.popup-title {
  font-family:var(--font-head);
  font-size:1.1rem;
  line-height:1.3rem;
  font-weight:600;
  color:var(--text-main);
  margin-bottom:.5rem;
  letter-spacing:-0.03em;
}
.popup-text {
  font-size:.9rem;
  line-height:1.4rem;
  color:var(--text-dim);
  margin-bottom:1rem;
}
.popup-close-btn {
  background:var(--accent-main);
  color:#fff;
  font-size:.9rem;
  line-height:1.25rem;
  font-weight:600;
  border-radius:.6rem;
  border:1px solid var(--accent-main);
  padding:.6rem 1rem;
  width:100%;
  box-shadow:0 20px 40px rgba(59,27,117,.35);
  cursor:pointer;
}
.popup-close-btn:hover {
  background:var(--accent-main-hover);
  border-color:var(--accent-main-hover);
}

.warning-hint {
  font-size:.8rem;
  line-height:1.3rem;
  text-align:center;
  color:var(--text-main);
  max-width:40rem;
  margin:1.5rem auto 0;
  font-weight:500;
}

/* FOOTER */
.footer {
  border-top:1px solid var(--border-soft);
  background:var(--bg-page);
  padding:2rem 1rem 4rem;
  font-size:.7rem;
  line-height:1.4rem;
  color:var(--text-faint);
  text-align:center;
}

/* RU / UA toggle visibility */
.text-block[data-lang="ru"] {display:inline;}
.text-block[data-lang="ua"] {display:none;}
body.ua .text-block[data-lang="ru"] {display:none;}
body.ua .text-block[data-lang="ua"] {display:inline;}

/* fade reveal */
.fade-up {
  opacity:0;
  transform:translateY(20px);
  transition:all .5s cubic-bezier(.16,1,.3,1);
}
.fade-up.show {
  opacity:1;
  transform:translateY(0);
}

.brand-logo-img {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.brand-logo-img img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 8px;
}

.translators-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  margin: 3rem 0;
}

.translator-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
  text-align: center;
  padding: 2rem 1.5rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.translator-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
}

.translator-photo {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  margin: 0 auto 1rem;
  background-size: cover;
  background-position: center;
}

.translator-card h2 {
  font-size: 1.3rem;
  font-weight: 600;
  margin: 0.5rem 0 0.2rem;
  color: #1a1a1a;
}

.position {
  color: #6b6b6b;
  font-size: 0.9rem;
  margin-bottom: 1rem;
}

.bio {
  color: #444;
  font-size: 0.95rem;
  line-height: 1.5;
}
.nav-row a.active-link {
  color: var(--accent-main);
  font-weight: 600;
  transition: color 0.2s ease;
}