/* ============================================================================
   fitVibe Partners — Επικοινωνία (/partners/contact)
   Faithful port of the Claude Design page, scoped under .fvct. Site header/footer
   come from the partners layout; nav/footer of the design are dropped.
   ============================================================================ */

.fvct{
  --blue:#325DE6; --blue-hover:#1F4ACD; --blue-soft:#E1E8FE; --blue-25:#F4F7FF;
  --ink:#0D1A3D; --ink-2:#2B3865; --ink-3:#5E6B91; --ink-4:#8C97B5;
  --line:#E5E8F1; --line-soft:#EEF0F6; --bg:var(--main-white-color,#F2F2F2); --bg-soft:#FAFBFD;
  --green:#1F8900; --r-lg:24px; --r-md:18px; --r-sm:12px;
  --shadow-card:0 1px 2px rgba(13,26,61,.04),0 8px 24px -16px rgba(13,26,61,.10);
  --shadow-soft:0 1px 2px rgba(13,26,61,.04),0 16px 40px -28px rgba(50,93,230,.30);
  background:var(--bg); color:var(--ink);
  font-family:Manrope,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased; font-size:16px; line-height:1.55;
}
.fvct *{ box-sizing:border-box; }
.fvct img{ max-width:100%; display:block; }
.fvct h1,.fvct h2,.fvct h3{ margin:0; font-weight:800; letter-spacing:-.01em; text-wrap:balance; color:var(--ink); }
.fvct h1{ font-size:clamp(34px,5vw,46px); line-height:1.08; letter-spacing:-.025em; }
.fvct h2{ font-size:clamp(26px,3.4vw,30px); line-height:1.15; letter-spacing:-.02em; }
.fvct h3{ font-size:20px; line-height:1.25; }
.fvct p{ margin:0; color:var(--ink-3); text-wrap:pretty; }
.fvct .fvct-wrap{ max-width:1180px; margin:0 auto; padding:0 24px; }
@media(min-width:961px){ .fvct .fvct-wrap{ max-width:1280px; } }

.fvct-eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); font-weight:700; }
.fvct-eyebrow .dot{ width:6px; height:6px; border-radius:50%; background:var(--blue); }

/* buttons */
.fvct-btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:13px 22px; border-radius:999px;
  font-family:inherit; font-weight:700; font-size:14px; border:1px solid transparent; cursor:pointer; transition:all .15s; white-space:nowrap; }
.fvct-btn svg{ width:16px; height:16px; flex:none; }
.fvct-btn-primary{ background:var(--blue); color:#fff; box-shadow:0 8px 20px -10px rgba(50,93,230,.65); }
.fvct-btn-primary:hover{ background:var(--blue-hover); }
.fvct-btn-primary:disabled{ background:var(--ink-4); box-shadow:none; cursor:not-allowed; }

/* HERO */
.fvct-hero{ padding:48px 0 4px; text-align:center; }
.fvct-hero h1{ margin-top:14px; }
.fvct .fvct-lede{ font-size:17.5px; margin:14px auto 0; max-width:560px; text-align:center; }
.fvct-team{ display:flex; align-items:center; justify-content:center; gap:12px; margin-top:20px; }
.fvct-avatars{ display:flex; }
.fvct-avatars span{ width:38px; height:38px; border-radius:50%; border:2.5px solid var(--bg); display:grid; place-items:center; font-size:12px; font-weight:800; color:#fff; margin-left:-8px; }
.fvct-avatars span:first-child{ margin-left:0; }
.fvct-team-meta{ font-size:13px; font-weight:700; color:var(--ink-2); text-align:left; line-height:1.35; }
.fvct-team-meta b{ color:var(--green); display:inline-flex; align-items:center; gap:5px; }
.fvct-team-meta b i{ width:7px; height:7px; border-radius:50%; background:var(--green); display:inline-block; }

/* MAIN GRID */
.fvct-main{ padding:30px 0 26px; }
.fvct-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:20px; align-items:start; }
.fvct-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-card); }
.fvct-card-head{ padding:22px 26px 0; display:flex; align-items:flex-start; gap:14px; }
.fvct-card-head .ic{ width:42px; height:42px; border-radius:13px; background:var(--blue-soft); color:var(--blue); display:grid; place-items:center; flex:none; }
.fvct-card-head .ic svg{ width:21px; height:21px; }
.fvct-card-head h3{ margin-top:2px; }
.fvct-card-head p{ font-size:13.5px; margin-top:4px; }
.fvct-card-body{ padding:20px 26px 26px; }
.fvct-card-body--cal{ padding:12px 12px 14px; }
.fvct-card-body--cal .calendly-inline-widget{ border-radius:14px; overflow:hidden; min-height:700px; }
/* desktop: taller calendar + roomier message card */
@media(min-width:961px){
  .fvct-card-body--cal{ padding:16px 16px 18px; }
  .fvct-card-body--cal .calendly-inline-widget{ min-height:820px; height:820px !important; }
  .fvct-card-head{ padding:26px 30px 0; }
  .fvct-card-body{ padding:22px 30px 28px; }
}

/* form fields */
.fvct-frow{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.fvct-field{ display:flex; flex-direction:column; gap:6px; margin-top:10px; }
.fvct-field label{ font-size:13px; font-weight:700; color:var(--ink-2); }
.fvct-field label .opt{ color:var(--ink-4); font-weight:600; }
.fvct-field input,.fvct-field textarea{ font-family:inherit; font-size:14.5px; font-weight:600; color:var(--ink);
  background:var(--bg-soft); border:1.5px solid var(--line); border-radius:12px; padding:12px 14px; outline:none; transition:border-color .15s; width:100%; }
.fvct-field input:focus,.fvct-field textarea:focus{ border-color:var(--blue); background:#fff; }
.fvct-field textarea{ resize:vertical; min-height:110px; }
.fvct-field.has-error input,.fvct-field.has-error textarea{ border-color:#D62424; background:#fff; }
.fvct-err{ display:none; font-size:12px; font-weight:700; color:#D62424; }
.fvct-field.has-error .fvct-err{ display:block; }
.fvct-contact-err{ color:#D62424; font-size:12.5px; font-weight:700; margin-top:10px; min-height:0; }
.fvct-contact-err:empty{ display:none; }

.fvct-submit-row{ display:flex; align-items:center; gap:14px; margin-top:16px; flex-wrap:wrap; }
.fvct-btn-label{ display:inline; }
.fvct-dots{ display:none; gap:4px; }
.fvct-submit.is-loading .fvct-dots,.fvct-btn.is-loading .fvct-dots{ display:inline-flex; }
.fvct-btn.is-loading .fvct-btn-label,.fvct-btn.is-loading .fvct-btn-ic{ display:none; }
.fvct-dots span{ width:6px; height:6px; border-radius:50%; background:#fff; opacity:.6; animation:fvctDot 1s infinite ease-in-out; }
.fvct-dots span:nth-child(2){ animation-delay:.15s; } .fvct-dots span:nth-child(3){ animation-delay:.3s; }
@keyframes fvctDot{ 0%,100%{ opacity:.35; transform:translateY(0); } 40%{ opacity:1; transform:translateY(-3px); } }

.fvct-success{ display:none; align-items:center; gap:12px; background:#EDF7EA; border:1px solid #CDE8C5; border-radius:14px;
  padding:14px 16px; margin-top:18px; font-size:14px; font-weight:700; color:var(--green); }
.fvct-success.show{ display:flex; }
.fvct-success svg{ width:20px; height:20px; flex:none; }

/* honeypot */
.fvct-hp{ position:absolute !important; left:-9999px !important; top:-9999px !important; width:1px; height:1px; overflow:hidden; opacity:0; }

/* channels */
.fvct-channels{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:18px; }
.fvct-chan{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:20px; display:flex; align-items:center; gap:14px;
  box-shadow:var(--shadow-card); transition:all .15s; text-decoration:none; }
.fvct-chan:hover{ border-color:var(--blue); box-shadow:var(--shadow-soft); }
.fvct-chan .ic{ width:40px; height:40px; border-radius:12px; background:var(--blue-soft); color:var(--blue); display:grid; place-items:center; flex:none; }
.fvct-chan .ic svg{ width:19px; height:19px; }
.fvct-chan .t{ font-size:12px; font-weight:700; color:var(--ink-4); text-transform:uppercase; letter-spacing:.05em; display:block; }
.fvct-chan .v{ font-size:15px; font-weight:800; color:var(--ink); margin-top:2px; display:block; }

/* (FAQ uses the shared partners/_faq-accordion module — css/terms/faq.css) */

/* mobile tabs */
.fvct-tabs{ display:none; background:#fff; border:1.5px solid var(--line); border-radius:999px; padding:4px; margin:0 0 18px; gap:4px; }
.fvct-tab{ flex:1; display:flex; align-items:center; justify-content:center; gap:7px; min-height:46px; border:none; border-radius:999px;
  background:transparent; font-family:inherit; font-size:14px; font-weight:700; color:var(--ink-3); cursor:pointer; transition:all .18s; }
.fvct-tab svg{ width:16px; height:16px; flex:none; }
.fvct-tab.sel{ background:var(--blue); color:#fff; box-shadow:0 6px 16px -8px rgba(50,93,230,.65); }

@media (max-width:960px){
  .fvct-hero{ padding:38px 0 2px; }
  .fvct-hero h1{ margin-top:12px; }
  .fvct .fvct-lede{ margin-top:12px; font-size:16px; }
  .fvct-team{ margin-top:16px; }
  .fvct-main{ padding:24px 0 22px; }
  .fvct-grid{ grid-template-columns:1fr; }
  .fvct-channels{ grid-template-columns:1fr; }
  .fvct-frow{ grid-template-columns:1fr; }
  .fvct-card-head{ padding:20px 20px 0; }
  .fvct-card-body{ padding:18px 20px 22px; }
  .fvct-card-body--cal{ padding:10px 10px 12px; }
  .fvct-card-body--cal .calendly-inline-widget{ min-height:640px; height:640px !important; }
  .fvct-tabs{ display:flex; }
  .fvct-grid .fvct-card{ display:none; }
  .fvct-grid .fvct-card.fvct-tab-on{ display:block; }
  .fvct-channels{ gap:10px; margin-top:14px; }
  .fvct-chan{ padding:16px; }
}
