:root{
  --fsfs-ink:#092a49;
  --fsfs-slate:#5a6b7a;
  --fsfs-muted:rgba(90,107,122,.88);
  --fsfs-border:rgba(9,42,73,.12);
  --fsfs-card-solid:#ffffff;
  --fsfs-grad-1:#0796fe;
  --fsfs-grad-2:#092a49;
  --fsfs-danger:#d11a2a;
  --fsfs-success:#0f9d58;
  --fsfs-shadow:0 16px 48px rgba(9,42,73,.10);
  --fsfs-radius:18px;
  --fsfs-field-radius:12px;
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto!important}
  *,*::before,*::after{transition:none!important;animation:none!important}
}

/* ========== Contact page shell ========== */
.contact.contact--modern{
  position:relative;
  padding:50px 0 70px;
  background:#ffffff;
  overflow:hidden;
}
.contact.contact--modern::before,
.contact.contact--modern::after{
  content:none;
}
.contact.contact--modern > .container{
  position:relative;
  z-index:1;
}

/* Page hero */
.contact-hero{
  max-width:720px;
  margin:0 auto 42px;
}
.contact-hero__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 14px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--fsfs-grad-1);
}
.contact-hero__badge i{
  font-size:13px;
  transform:rotate(-18deg);
}
.contact-hero__title{
  margin:0 0 14px;
  font-size:clamp(28px, 4vw, 40px);
  font-weight:700;
  line-height:1.15;
  color:var(--fsfs-ink);
  font-family:'Oswald', sans-serif;
  letter-spacing:.01em;
}
.contact-hero__desc{
  margin:0 auto;
  max-width:560px;
  font-size:16px;
  line-height:1.65;
  color:var(--fsfs-muted);
}
.contact-hero__line{
  display:block;
  width:56px;
  height:4px;
  margin:20px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg, var(--fsfs-grad-1), rgba(7,150,254,.35));
}

/* Layout */
.contact-layout{
  align-items:flex-start;
}
.contact-layout__side{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.contact-layout__form{
  margin-bottom:0;
}

/* Homepage (index) — left info stack matches form card height */
@media (min-width: 992px){
  .contact.contact--home .contact-layout.row{
    display:grid;
    grid-template-columns:repeat(12, 1fr);
    column-gap:30px;
    align-items:stretch;
    margin-left:0;
    margin-right:0;
  }
  .contact.contact--home .contact-layout > [class*="col-"]{
    max-width:none;
    flex:none;
    width:auto;
    padding-left:0;
    padding-right:0;
  }
  .contact.contact--home .contact-layout__side{
    grid-column:span 5;
    display:grid;
    grid-template-rows:repeat(3, minmax(0, 1fr));
    gap:16px;
    align-self:stretch;
  }
  .contact.contact--home .contact-layout__form{
    grid-column:span 7;
    align-self:stretch;
  }
  .contact.contact--home .contact-layout__side .contact-info{
    height:100%;
    margin:0!important;
    align-items:center;
    overflow:visible;
  }
  .contact.contact--home .contact-layout__side .contact-info::before{
    align-self:stretch;
  }
}

/* Contact info cards */
.contact.contact--modern .contact-info{
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:20px 22px 20px 0;
  margin:0;
  border:0;
  border-radius:var(--fsfs-radius);
  background:var(--fsfs-card-solid);
  box-shadow:var(--fsfs-shadow);
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.contact.contact--modern .contact-info::before{
  content:"";
  flex:0 0 4px;
  align-self:stretch;
  margin-right:2px;
  border-radius:0 4px 4px 0;
  background:linear-gradient(180deg, var(--fsfs-grad-1), var(--fsfs-grad-2));
}
.contact.contact--modern .contact-info:hover{
  transform:translateY(-2px);
  box-shadow:0 20px 52px rgba(9,42,73,.14);
  border-color:transparent;
}
.contact.contact--modern .contact-icon{
  flex:0 0 auto;
  width:48px;
  height:48px;
  margin-left:18px;
  border:0;
  border-radius:50%;
  background:rgba(7,150,254,.12);
}
.contact.contact--modern .contact-icon i{
  font-size:18px;
  color:var(--fsfs-grad-1);
}
.contact.contact--modern .contact-text{
  padding:0;
  flex:1;
  min-width:0;
}
.contact.contact--modern .contact-text h3{
  margin:0 0 6px;
  font-size:17px;
  font-weight:700;
  letter-spacing:0;
  color:var(--fsfs-ink);
  font-family:'Oswald', sans-serif;
}
.contact.contact--modern .contact-text p{
  margin:0 0 4px;
  font-size:14px;
  line-height:1.55;
  color:var(--fsfs-muted);
}
.contact.contact--modern .contact-text p:last-child{
  margin-bottom:0;
}

/* Map card */
.contact.contact--modern .contact-map{
  padding:0;
  margin:4px 0 0;
  border:0;
  border-radius:var(--fsfs-radius);
  background:var(--fsfs-card-solid);
  box-shadow:var(--fsfs-shadow);
  overflow:hidden;
}
.contact.contact--modern .contact-map:hover{
  box-shadow:0 20px 52px rgba(9,42,73,.14);
  border-color:transparent;
}
.contact.contact--modern .contact-map iframe{
  display:block;
  width:100%;
  min-height:260px;
  border-radius:var(--fsfs-radius);
}

/* Form wrapper */
.contact.contact--modern .contact-form{
  padding:0;
  border:0;
  margin:0;
  background:transparent;
  box-shadow:none;
}
.contact.contact--modern .contact-form:hover{
  box-shadow:none;
  border-color:transparent;
}

.fsfs-contact{
  position:relative;
  padding:32px 34px 28px;
  border-radius:var(--fsfs-radius);
  background:var(--fsfs-card-solid);
  box-shadow:var(--fsfs-shadow);
  border:1px solid rgba(255,255,255,.85);
}
.fsfs-contact > *{position:relative; z-index:1;}

/* Form header */
.fsfs-contact__head{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin:0 0 26px;
  padding-bottom:22px;
  border-bottom:1px solid rgba(9,42,73,.08);
}
.fsfs-contact__head-icon{
  flex:0 0 auto;
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:#fff;
  font-size:20px;
  background:linear-gradient(135deg, var(--fsfs-grad-1), #0580d8);
  box-shadow:0 8px 20px rgba(7,150,254,.28);
}
.fsfs-contact__head-text{
  flex:1;
  min-width:0;
  padding-top:2px;
}
.fsfs-contact__title{
  margin:0 0 4px;
  font-size:22px;
  font-weight:700;
  line-height:1.2;
  color:var(--fsfs-ink);
  font-family:'Oswald', sans-serif;
}
.fsfs-contact__lead{
  margin:0;
  font-size:14px;
  line-height:1.5;
  color:var(--fsfs-muted);
}

/* Fields — labels above inputs */
.fsfs-contact__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px 16px;
}
.fsfs-field--full{grid-column:1 / -1;}
.fsfs-field{min-width:0;}
.fsfs-control{display:flex; flex-direction:column; gap:8px;}
.fsfs-label{
  position:static;
  transform:none;
  padding:0;
  font-size:14px;
  font-weight:700;
  line-height:1.2;
  color:var(--fsfs-ink);
  background:transparent;
  pointer-events:auto;
  white-space:normal;
}
.fsfs-req{
  color:var(--fsfs-grad-1);
  font-weight:700;
}

.contact .contact-form .fsfs-input,
.contact .contact-form input.fsfs-input,
.contact .contact-form textarea.fsfs-input{
  width:100%;
  height:auto;
  border:1px solid var(--fsfs-border)!important;
  border-radius:var(--fsfs-field-radius)!important;
  background:#f8fafc!important;
  padding:13px 15px!important;
  color:var(--fsfs-ink)!important;
  font-size:15px;
  line-height:1.4;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.fsfs-textarea{
  min-height:130px;
  resize:vertical;
}
.fsfs-input::placeholder{
  color:rgba(90,107,122,.65);
}
.fsfs-input:focus{
  border-color:var(--fsfs-grad-1)!important;
  background:#fff!important;
  box-shadow:0 0 0 3px rgba(7,150,254,.12)!important;
  outline:none;
}
.fsfs-input[aria-invalid="true"]{
  border-color:rgba(209,26,42,.55)!important;
  box-shadow:0 0 0 3px rgba(209,26,42,.10)!important;
}

.fsfs-error{
  min-height:18px;
  margin-top:2px;
  font-size:12px;
  line-height:1.35;
  font-weight:600;
  color:rgba(209,26,42,.92);
}
.fsfs-error:empty{
  min-height:0;
  margin-top:0;
}

.fsfs-hp{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

/* Submit */
.fsfs-contact__actions{
  margin-top:24px;
  display:flex;
  justify-content:flex-end;
}
.contact .contact-form .fsfs-submit,
.contact .contact-form .btn.fsfs-submit{
  width:auto;
  min-width:190px;
  margin:0;
  border:0!important;
  border-radius:999px!important;
  padding:14px 30px!important;
  color:#fff!important;
  font-size:15px;
  font-weight:700;
  letter-spacing:.02em;
  background:var(--fsfs-grad-1)!important;
  box-shadow:0 10px 28px rgba(7,150,254,.32);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.fsfs-submit__icon{
  font-size:14px;
  transform:rotate(-18deg);
}
.contact .contact-form .fsfs-submit:hover,
.contact .contact-form .btn.fsfs-submit:hover{
  color:#fff!important;
  background:#0688e8!important;
  border-color:transparent!important;
  transform:translateY(-2px);
  box-shadow:0 14px 32px rgba(7,150,254,.38);
}
.fsfs-submit:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(7,150,254,.35), 0 10px 28px rgba(7,150,254,.28)!important;
}
.fsfs-submit:disabled{
  cursor:not-allowed;
  opacity:.82;
  transform:none;
}
.fsfs-spinner{
  width:18px;
  height:18px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  display:none;
  animation:fsfsSpin .8s linear infinite;
}
@keyframes fsfsSpin{to{transform:rotate(360deg)}}
.fsfs-contact.is-submitting .fsfs-spinner{display:inline-block;}
.fsfs-contact.is-submitting .fsfs-submit__icon{display:none;}
.fsfs-contact.is-submitting .fsfs-submit__text{opacity:.95;}
.fsfs-submit-status{
  margin:10px 0 0;
  font-size:13px;
  line-height:1.4;
  font-weight:600;
  color:var(--fsfs-muted);
  text-align:right;
  width:100%;
}
.fsfs-submit-status[hidden]{display:none;}
.fsfs-contact.is-submitting{opacity:.98;}

.fsfs-privacy{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin:18px 0 0;
  padding-top:16px;
  border-top:1px solid rgba(9,42,73,.06);
  font-size:13px;
  line-height:1.45;
  color:var(--fsfs-muted);
  text-align:center;
}
.fsfs-privacy i{
  flex:0 0 auto;
  font-size:12px;
  color:var(--fsfs-grad-1);
}

/* Homepage contact block (no full page hero) */
.contact:not(.contact--modern) .fsfs-contact{
  padding:28px 26px 24px;
  border-radius:var(--fsfs-radius);
  background:var(--fsfs-card-solid);
  box-shadow:var(--fsfs-shadow);
}
.contact:not(.contact--modern) .contact-info{
  position:relative;
  border-radius:var(--fsfs-radius);
  box-shadow:var(--fsfs-shadow);
  border:0;
  background:#fff;
  overflow:hidden;
  padding-left:22px;
}
.contact:not(.contact--modern) .contact-info::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  background:linear-gradient(180deg, var(--fsfs-grad-1), var(--fsfs-grad-2));
}
.contact:not(.contact--modern) .contact-icon{
  border:0;
  border-radius:50%;
  background:rgba(7,150,254,.12);
}

/* Modal */
.fsfs-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:99999;
}
.fsfs-modal.is-open{display:flex;}
.fsfs-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(9,42,73,.55);
  backdrop-filter:blur(8px);
}
.fsfs-modal__card{
  position:relative;
  width:min(520px, 100%);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.90));
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 30px 90px rgba(0,0,0,.28);
  overflow:hidden;
  transform:translateY(10px) scale(.98);
  opacity:0;
  animation:fsfsModalIn .22s ease forwards;
}
@keyframes fsfsModalIn{
  to{transform:translateY(0) scale(1); opacity:1;}
}
.fsfs-modal__top{
  padding:18px 20px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.fsfs-modal__icon{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  color:#fff;
  flex:0 0 auto;
  background:linear-gradient(135deg, var(--fsfs-grad-1), var(--fsfs-grad-2));
  box-shadow:0 12px 24px rgba(7,150,254,.20);
}
.fsfs-modal[data-type="error"] .fsfs-modal__icon{
  background:linear-gradient(135deg, #ff3b6b, #a8001b);
  box-shadow:0 12px 24px rgba(209,26,42,.16);
}
.fsfs-modal__title{
  margin:0;
  font-size:18px;
  color:var(--fsfs-ink);
}
.fsfs-modal__msg{
  margin:6px 0 0;
  color:rgba(11,27,42,.70);
  line-height:1.55;
}
.fsfs-modal__close{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--fsfs-ink);
  font-size:22px;
  line-height:1;
  padding:2px 6px;
  border-radius:10px;
}
.fsfs-modal__actions{
  padding:0 20px 18px;
  display:flex;
  justify-content:flex-end;
  gap:10px;
}
.fsfs-modal .fsfs-modal__btn{
  appearance:none;
  border:1px solid rgba(0,0,0,.25)!important;
  border-radius:14px!important;
  padding:10px 16px!important;
  font-weight:800!important;
  background:#fff!important;
  color:#000!important;
}
.fsfs-modal .fsfs-modal__btn--primary{
  background:var(--fsfs-grad-1)!important;
  border-color:var(--fsfs-grad-1)!important;
  color:#fff!important;
}
.fsfs-modal .fsfs-modal__btn--primary:hover{
  background:var(--fsfs-grad-2)!important;
  border-color:var(--fsfs-grad-2)!important;
}

@media (max-width: 991.98px){
  .contact-layout__side{margin-bottom:28px;}
}

@media (max-width: 767.98px){
  .contact.contact--modern{padding:36px 0 50px;}
  .contact-hero{margin-bottom:30px;}
  .fsfs-contact{padding:22px 18px 20px;}
  .fsfs-contact__head{flex-direction:column; gap:12px;}
  .fsfs-contact__grid{grid-template-columns:1fr; gap:16px;}
  .fsfs-contact__actions{justify-content:stretch;}
  .contact .contact-form .fsfs-submit,
  .contact .contact-form .btn.fsfs-submit{width:100%;}
}
