/* ============================================================
   M'arte Studio — CONTACTO.CSS
   ============================================================ */

.cont-hero {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  padding: 120px 40px 80px;
}
.cont-bg { position: absolute; inset: 0; pointer-events: none; }
.cont-orb { position: absolute; border-radius: 50%; filter: blur(120px); opacity: 0.1; }
.cont-orb--1 { width: 600px; height: 600px; background: var(--c5); right: -200px; top: -150px; }
.cont-orb--2 { width: 500px; height: 500px; background: var(--c3); left: -150px; bottom: -100px; }

.cont-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 80px;
  align-items: start;
  position: relative;
}

/* CHANNELS */
.cont-channels { margin: 36px 0; display: flex; flex-direction: column; gap: 12px; }

.cont-channel {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--card-bg);
  transition: var(--transition);
  text-decoration: none;
  color: var(--white);
}
.cont-channel:hover {
  border-color: rgba(255,32,121,0.5);
  transform: translateX(6px);
  box-shadow: 0 0 25px rgba(255,32,121,0.1);
}

.cc-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(255,32,121,0.1);
  border: 1px solid rgba(255,32,121,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--c5);
  flex-shrink: 0;
}
.cc-icon--wa { background: rgba(37,211,102,0.1); border-color: rgba(37,211,102,0.25); color: #25d366; }
.cc-icon--ig { background: rgba(225,48,108,0.1); border-color: rgba(225,48,108,0.25); color: #e1306c; }
.cc-icon--cal { background: rgba(68,11,212,0.1); border-color: rgba(68,11,212,0.25); color: var(--c4); }

.cc-text { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.cc-label { font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.35); }
.cc-val { font-size: 0.95rem; color: rgba(255,255,255,0.8); }
.cc-arrow { color: rgba(255,255,255,0.2); font-size: 0.9rem; transition: var(--transition); }
.cont-channel:hover .cc-arrow { color: var(--c5); transform: translateX(4px); }

.cont-note {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  background: rgba(255,32,121,0.06);
  border: 1px solid rgba(255,32,121,0.15);
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
}
.cont-note i { color: var(--c5); }
.cont-note strong { color: var(--white); }

/* FORM */
.cont-form-wrap {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 40px;
  backdrop-filter: blur(10px);
}
.cont-form h2 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.cont-form > p {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.45);
  margin-bottom: 28px;
  line-height: 1.5;
}
.cont-form > p a { color: var(--c5); }

.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cf-field { margin-bottom: 18px; }
.cf-field label {
  display: block;
  font-family: var(--font-display);
  font-size: 0.75rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
}
.req { color: var(--c5); }

.cf-field input,
.cf-field select,
.cf-field textarea {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-md);
  padding: 13px 16px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--white);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
  resize: vertical;
  -webkit-appearance: none;
}
.cf-field select { cursor: pointer; }
.cf-field select option { background: var(--c1); }
.cf-field input:focus,
.cf-field select:focus,
.cf-field textarea:focus {
  border-color: var(--c5);
  box-shadow: 0 0 0 3px rgba(255,32,121,0.1);
}
.cf-field input::placeholder,
.cf-field textarea::placeholder { color: rgba(255,255,255,0.2); }

.cf-privacy { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.cf-check { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.cf-check input[type="checkbox"] { width: 16px; height: 16px; flex-shrink: 0; margin-top: 3px; accent-color: var(--c5); }
.cf-check span { font-size: 0.85rem; color: rgba(255,255,255,0.45); line-height: 1.5; }
.cf-check a { color: var(--c5); }

/* RESPONSIVE */
@media (max-width: 1000px) {
  .cont-inner { grid-template-columns: 1fr; gap: 50px; }
  .cont-hero { padding: 120px 24px 60px; }
}
@media (max-width: 600px) {
  .cf-row { grid-template-columns: 1fr; }
  .cont-form-wrap { padding: 24px 20px; }
}