/* ════════════════════════════════════════════════════════════════
   Contact page — page hero w/ WhatsApp-first quick links, sticky
   two-column contact body (info panel + lead form), FAQ accordion,
   final CTA.
   ════════════════════════════════════════════════════════════════ */

:root{
  --wa:#25D366;
  --wa-dk:#1da851;
}

/* ── PAGE HERO ───────────────────────────────── */
.page-hero{
  padding:72px 0 64px;position:relative;overflow:hidden;
  background-image:var(--page-hero-image, none);
  background-size:cover;background-position:center 40%;
}
.page-hero.no-image{background:linear-gradient(135deg,#0c1a2e 0%,var(--navy) 60%,#254f7a 100%);}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,rgba(8,18,34,.88) 0%,rgba(20,40,70,.68) 100%);z-index:0;}
.page-hero-inner{position:relative;z-index:1;}
.page-hero h1{font-family:'Montserrat',sans-serif;font-size:clamp(36px,5.5vw,68px);font-weight:900;color:#fff;line-height:1.05;letter-spacing:-.025em;margin-top:18px;max-width:700px;}
.page-hero p{margin-top:18px;font-size:18px;color:rgba(255,255,255,.78);max-width:560px;line-height:1.65;}

.hero-contact-strip{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap;}
.hero-contact-link{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.10);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.20);border-radius:50px;
  font-family:'Montserrat',sans-serif;font-size:13.5px;font-weight:700;
  color:#fff;padding:10px 18px;transition:background .18s,border-color .18s;
}
.hero-contact-link:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.4);}
.hero-contact-link svg{width:16px;height:16px;}

.wa-hero-btn{
  display:inline-flex;align-items:center;gap:12px;background:var(--wa);border-radius:50px;
  font-family:'Montserrat',sans-serif;font-size:15px;font-weight:800;color:#fff;padding:14px 24px;
  transition:background .18s,transform .18s,box-shadow .18s;
}
.wa-hero-btn:hover{background:var(--wa-dk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,.35);}
.wa-hero-btn svg{width:22px;height:22px;}

/* ── CONTACT + FORM (signature layout) ───────── */
.contact-body{padding:80px 0 100px;background:var(--paper);}
.contact-grid{display:grid;grid-template-columns:360px 1fr;gap:64px;align-items:start;}

.contact-info{position:sticky;top:calc(72px + 24px);}
.contact-info-head{margin-bottom:32px;}
.contact-info-head h2{font-family:'Montserrat',sans-serif;font-size:clamp(22px,2.5vw,30px);font-weight:900;color:var(--navy);letter-spacing:-.02em;line-height:1.2;margin-top:10px;}
.contact-info-head p{margin-top:10px;font-size:15px;color:var(--ink-soft);line-height:1.65;}

.contact-details{display:flex;flex-direction:column;gap:16px;margin-bottom:32px;}
.contact-detail{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  padding:16px 18px;transition:border-color .15s,box-shadow .15s;
}
.contact-detail:hover{border-color:rgba(58,124,166,.25);box-shadow:var(--sh);}
.contact-detail-icon{width:38px;height:38px;border-radius:9px;background:var(--blue-pale);flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.contact-detail-icon svg{width:18px;height:18px;color:var(--blue);}
.contact-detail-label{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:3px;}
.contact-detail-val{font-size:15px;font-weight:600;color:var(--navy);line-height:1.3;}
.contact-detail-val a{color:var(--blue);}

.wa-cta-block{
  background:var(--wa);border-radius:var(--r-lg);padding:22px 24px;
  display:flex;align-items:center;gap:16px;
  transition:background .18s,transform .18s,box-shadow .18s;cursor:pointer;text-decoration:none;
}
.wa-cta-block:hover{background:var(--wa-dk);transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.3);}
.wa-cta-block-icon{width:48px;height:48px;background:rgba(255,255,255,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.wa-cta-block-icon svg{width:26px;height:26px;color:#fff;}
.wa-cta-block-text{flex:1;}
.wa-cta-block-label{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:3px;}
.wa-cta-block-num{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:900;color:#fff;line-height:1;}
.wa-cta-block-sub{font-size:12px;color:rgba(255,255,255,.8);margin-top:3px;}
.wa-cta-block-arrow{color:rgba(255,255,255,.8);}
.wa-cta-block-arrow svg{width:20px;height:20px;}

/* form card */
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:40px 36px;}
.form-card-head{margin-bottom:28px;}
.form-card-head h3{font-family:'Montserrat',sans-serif;font-size:20px;font-weight:900;color:var(--navy);}
.form-card-head p{margin-top:6px;font-size:14.5px;color:var(--ink-soft);line-height:1.6;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-family:'Montserrat',sans-serif;font-size:11.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px;}
.form-group label span{color:#E53E3E;}
.form-input-wrap{position:relative;}
.form-input-wrap .fi-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--ink-soft);pointer-events:none;}
.form-input-wrap input,.form-input-wrap select{padding-left:40px;}
.form-group input,.form-group select,.form-group textarea{
  width:100%;font-family:'Open Sans',sans-serif;font-size:15px;
  padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r);
  background:var(--paper);color:var(--ink);transition:border-color .15s,box-shadow .15s,background .15s;
  outline:none;-webkit-appearance:none;appearance:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,124,166,.12);background:var(--white);
}
.form-group textarea{min-height:96px;resize:vertical;padding-left:14px;}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5568' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-error{font-size:12.5px;color:#E53E3E;margin-top:6px;}

/* radio chip group */
.chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px;}
.chip-group input[type=radio]{position:absolute;opacity:0;width:0;height:0;}
.chip-group label{
  display:inline-block;padding:8px 15px;border-radius:50px;
  border:1.5px solid var(--line);background:var(--paper);
  font-family:'Montserrat',sans-serif;font-size:12.5px;font-weight:700;
  color:var(--ink-soft);cursor:pointer;transition:all .15s;user-select:none;
}
.chip-group input[type=radio]:checked + label{background:var(--navy);color:#fff;border-color:var(--navy);}
.chip-group label:hover{border-color:var(--blue);color:var(--blue);}

.form-submit{width:100%;justify-content:center;padding:15px;font-size:15px;border-radius:var(--r);margin-top:6px;}
.form-microcopy{text-align:center;font-size:12.5px;color:var(--ink-soft);margin-top:10px;display:flex;align-items:center;justify-content:center;gap:6px;}
.form-microcopy svg{width:14px;height:14px;color:var(--blue);}

/* success state — toggled via .form-card.is-submitted, same pattern as
   the Partner page form, so it works server-rendered (session flash)
   or instantly via JS without a reload. */
.form-card.is-submitted .form-card-fields{display:none;}
#contact-success{display:none;text-align:center;padding:48px 24px;}
.form-card.is-submitted #contact-success{display:block;}
#contact-success svg{width:56px;height:56px;color:var(--green);margin:0 auto 18px;}
#contact-success h3{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:900;color:var(--navy);margin-bottom:10px;}
#contact-success p{color:var(--ink-soft);font-size:15.5px;line-height:1.65;}

/* ── FAQ ──────────────────────────────────────── */
.faq-section{padding:100px 0;background:var(--white);}
.faq-grid{display:grid;grid-template-columns:320px 1fr;gap:80px;align-items:start;}
.faq-left{position:sticky;top:calc(72px + 24px);}
.faq-left h2{font-family:'Montserrat',sans-serif;font-size:clamp(26px,3vw,38px);font-weight:900;color:var(--navy);letter-spacing:-.02em;line-height:1.15;margin-top:12px;}
.faq-left p{margin-top:16px;color:var(--ink-soft);font-size:15px;line-height:1.7;}
.faq-left .cta-link{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;color:var(--blue);}
.faq-left .cta-link svg{width:14px;height:14px;transition:transform .15s;}
.faq-left .cta-link:hover svg{transform:translateX(4px);}

.faq-list{display:flex;flex-direction:column;gap:0;}
.faq-item{border-top:1px solid var(--line);}
.faq-item:last-child{border-bottom:1px solid var(--line);}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 0;cursor:pointer;
  font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;color:var(--navy);
  user-select:none;background:none;border:none;width:100%;text-align:left;
}
.faq-q:hover{color:var(--blue);}
.faq-icon{
  width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .2s,border-color .2s,transform .3s;
}
.faq-icon svg{width:14px;height:14px;color:var(--navy);transition:transform .3s;}
.faq-item.open .faq-icon{background:var(--navy);border-color:var(--navy);}
.faq-item.open .faq-icon svg{color:#fff;transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;font-size:15.5px;color:var(--ink-soft);line-height:1.75;}
.faq-a p{margin-bottom:10px;}
.faq-a p:last-child{margin-bottom:0;}
.faq-item.open .faq-a{max-height:400px;padding-bottom:22px;}

/* ── FINAL CTA ───────────────────────────────── */
.final-cta{background:var(--navy);padding:100px 0;text-align:center;position:relative;overflow:hidden;}
.final-cta::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(58,124,166,.2) 0%,transparent 70%);pointer-events:none;}
.final-cta-inner{position:relative;z-index:1;}
.final-cta h2{font-family:'Montserrat',sans-serif;font-size:clamp(28px,4vw,52px);font-weight:900;color:#fff;letter-spacing:-.025em;line-height:1.1;margin-top:14px;margin-bottom:16px;}
.final-cta p{color:rgba(255,255,255,.75);font-size:17px;margin-bottom:36px;max-width:460px;margin-left:auto;margin-right:auto;line-height:1.65;}
.final-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.final-cta .btn-whatsapp{background:var(--wa);}
.final-cta .btn-whatsapp:hover{background:var(--wa-dk);}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:1024px){
  .contact-grid{grid-template-columns:1fr;gap:48px;}
  .contact-info{position:static;}
  .faq-grid{grid-template-columns:1fr;gap:40px;}
  .faq-left{position:static;}
}
@media(max-width:768px){
  .form-row{grid-template-columns:1fr;}
  .form-card{padding:28px 20px;}
  .page-hero{padding:56px 0 48px;}
  .wa-cta-block{padding:20px;}
  .wa-cta-block-num{font-size:20px;}
}
