/* =============================================
   CONTACT PAGE STYLES
   ============================================= */

/* --- CONTACT GRID --- */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:60px; align-items:start; }

/* --- INFO PANEL --- */
.contact-info-title { font-size:clamp(2rem,3.5vw,2.6rem); color:#fff; margin-bottom:18px; }
.contact-info p { margin-bottom:36px; }

.contact-items { display:flex; flex-direction:column; gap:20px; margin-bottom:40px; }
.contact-item {
  display:flex; align-items:flex-start; gap:16px; padding:20px;
  background:rgba(255,255,255,.03); border:var(--glass-border);
  border-radius:var(--r-md); transition:.3s var(--ease);
}
.contact-item:hover { border-color:rgba(168,85,247,.3); background:rgba(168,85,247,.05); }
.ci-icon {
  width:42px; height:42px; border-radius:9px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
  background:rgba(168,85,247,.12); border:1px solid rgba(168,85,247,.25);
  color:var(--neon-purple);
}
.ci-icon.red  { background:rgba(244,63,94,.12); border-color:rgba(244,63,94,.25); color:var(--neon-red); }
.ci-icon.green { background:rgba(16,185,129,.12); border-color:rgba(16,185,129,.25); color:var(--neon-green); }
.ci-label { font-family:var(--font-mono); font-size:.7rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:3px; }
.ci-value { color:#fff; font-size:.95rem; }
.ci-value a { color:#fff; }
.ci-value a:hover { color:var(--neon-purple); }

/* --- CONTACT FORM --- */
.contact-form {
  background:#06080f; border:1px solid #1a2744;
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.4);
}
.form-titlebar {
  background:#0d1424; padding:12px 20px;
  display:flex; align-items:center; gap:8px;
  border-bottom:1px solid #1a2744;
}
.ftdot { width:11px; height:11px; border-radius:50%; }
.ftdot-r { background:#ef4444; } .ftdot-y { background:#f59e0b; } .ftdot-g { background:#10b981; }
.form-file { font-family:var(--font-mono); font-size:.72rem; color:var(--text-dim); margin-left:8px; }
.form-body { padding:32px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { margin-bottom:22px; }
.form-group label {
  display:block; font-family:var(--font-mono); font-size:.72rem;
  color:var(--neon-blue); margin-bottom:8px; letter-spacing:.5px;
}
.form-input, .form-textarea, .form-select {
  width:100%; background:#0d1424; border:1px solid #1a2744;
  color:#fff; padding:13px 16px; border-radius:var(--r-sm);
  font-family:var(--font-mono); font-size:.85rem;
  transition:.3s var(--ease);
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  outline:none; border-color:var(--neon-purple);
  box-shadow:0 0 0 3px rgba(168,85,247,.1);
  background:#0f1730;
}
.form-textarea { resize:vertical; min-height:130px; }
.form-select option { background:#0d1424; }

.form-submit-wrap { display:flex; align-items:center; gap:16px; margin-top:8px; }
.form-status { font-family:var(--font-mono); font-size:.78rem; color:var(--neon-green); opacity:0; transition:.3s; }
.form-status.visible { opacity:1; }

/* --- OFFICE LOCATIONS --- */
.offices-block { margin-top: 28px; }

.offices-label {
  font-size: .72rem; color: var(--text-dim);
  letter-spacing: 2px; text-transform: uppercase;
  margin-bottom: 14px; display: block;
}

.office-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.office-card {
  border-radius: var(--r-md); padding: 20px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.02);
  position: relative; overflow: hidden;
  transition: all .3s var(--ease);
}
.office-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
}
.office-card-hq::before { background: linear-gradient(to right, var(--neon-purple), var(--neon-red)); }
.office-card-dev::before { background: linear-gradient(to right, var(--neon-blue), var(--neon-cyan)); }

.office-card:hover {
  background: rgba(255,255,255,.04);
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(0,0,0,.3);
}
.office-card-hq:hover { border-color: rgba(168,85,247,.3); }
.office-card-dev:hover { border-color: rgba(59,130,246,.3); }

.office-card-header {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 10px;
}

.office-badge {
  font-family: var(--font-mono); font-size: .65rem;
  font-weight: 700; letter-spacing: 1.5px;
  padding: 3px 10px; border-radius: 4px;
}
.office-badge-hq  { background: rgba(168,85,247,.2); color: var(--neon-purple); border: 1px solid rgba(168,85,247,.3); }
.office-badge-dev { background: rgba(59,130,246,.2);  color: var(--neon-blue);   border: 1px solid rgba(59,130,246,.3); }

.office-city {
  font-size: .8rem; color: var(--text-muted);
  font-family: var(--font-mono);
}

.office-name {
  font-size: 1rem; font-weight: 700; color: #fff;
  margin-bottom: 10px;
}

.office-address {
  font-size: .82rem; color: var(--text-muted);
  line-height: 1.65; margin-bottom: 14px;
}
.office-address i { color: var(--neon-red); margin-right: 6px; font-size: .75rem; }

.office-map-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: .72rem;
  color: var(--neon-purple); letter-spacing: .5px;
  transition: .25s;
}
.office-card-dev .office-map-link { color: var(--neon-blue); }
.office-map-link:hover { gap: 10px; }
.office-map-link i { font-size: .65rem; }

/* --- FAQ --- */
.faq-list { display:flex; flex-direction:column; gap:14px; margin-top:48px; }
.faq-item {
  background:var(--glass-bg); border:var(--glass-border);
  border-radius:var(--r-md); overflow:hidden;
}
.faq-q {
  width:100%; display:flex; justify-content:space-between; align-items:center;
  padding:18px 22px; color:#fff; font-size:.95rem; font-weight:600;
  transition:.25s; text-align:left;
}
.faq-q:hover { color:var(--neon-purple); }
.faq-q .faq-arrow { color:var(--neon-purple); font-size:.8rem; transition:.3s; }
.faq-item.open .faq-arrow { transform:rotate(180deg); }
.faq-a {
  padding:0 22px; max-height:0; overflow:hidden;
  transition:max-height .4s var(--ease), padding .4s;
}
.faq-item.open .faq-a { max-height:200px; padding-bottom:18px; }
.faq-a p { font-size:.9rem; }

/* --- RESPONSIVE --- */
@media (max-width:900px) {
  .contact-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .office-cards { grid-template-columns:1fr; }
}
