/* ================================================================
   CREAPAL – Home Contact Block (drop‑in)
   - Same brand palette via CSS variables
   - Similar structure to reference, different design language
   - Safe namespace: .cp-contact*
================================================================ */

:root{
  /* Fallbacks if the main site doesn't define them */
  --cpb-primary: var(--primary-color, #111111);
  --cpb-accent: var(--accent2-color, #C9A227);
  --cpb-muted: var(--gray-text-color, #5D6167);
  --cpb-bg: var(--light-background-color, #F6F7F8);
  --cpb-card: #ffffff;
  --cpb-border: rgba(17,17,17,0.12);
  --cpb-radius-lg: 22px;
  --cpb-radius-md: 16px;
  --cpb-shadow: 0 18px 40px rgba(0,0,0,0.10);
}

.cp-contact{
  background: var(--cpb-bg);
  padding: 78px 0;
}

.cp-contact .cp-container{
  width: min(1240px, calc(100% - 32px));
  margin: 0 auto;
}

/* --- Header (industrial “plate” look, not a blue hero) --- */
.cp-contact__header{
  background:
    radial-gradient(900px 450px at 18% 0%, color-mix(in srgb, var(--cpb-accent) 22%, transparent) 0%, transparent 60%),
    radial-gradient(700px 420px at 86% 20%, rgba(0,0,0,0.08) 0%, transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.65) 0%, rgba(255,255,255,0.0) 100%);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--cpb-radius-lg);
  padding: 34px 28px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  position: relative;
  overflow: hidden;
}

.cp-contact__header::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    linear-gradient(transparent 0, transparent 18px, rgba(0,0,0,0.04) 19px),
    linear-gradient(90deg, transparent 0, transparent 18px, rgba(0,0,0,0.04) 19px);
  background-size: 19px 19px;
  opacity: .45;
  pointer-events:none;
}

.cp-contact__header > *{ position: relative; z-index: 1; }

.cp-contact__badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  border-radius: 999px;
  padding: 10px 14px;
  background: rgba(17,17,17,0.06);
  border: 1px solid rgba(17,17,17,0.10);
  color: #111;
  font-weight: 700;
  letter-spacing: .2px;
  margin-bottom: 14px;
}

.cp-contact__badge i{ color: var(--cpb-accent); }

.cp-contact__title{
  font-family: var(--font-family-heading, inherit);
  font-size: clamp(30px, 3.1vw, 48px);
  letter-spacing: -0.8px;
  color: #111;
  margin: 0 0 10px 0;
}

.cp-contact__subtitle{
  color: var(--cpb-muted);
  line-height: 1.65;
  max-width: 70ch;
}

.cp-contact__meta{
  margin-top: 10px;
  display:flex;
  flex-wrap: wrap;
  align-items:center;
  gap: 10px;
  color: color-mix(in srgb, var(--cpb-muted) 88%, #111);
  font-size: 13px;
  font-weight: 800;
}

.cp-contact__meta i{ color: var(--cpb-accent); }
.cp-contact__meta a{ color:#111; text-decoration:none; font-weight: 900; }
.cp-contact__meta a:hover{ text-decoration: underline; }
.cp-contact__dot{ opacity: .7; }

/* --- Cards row --- */
.cp-contact__cards{
  margin-top: 26px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 980px){
  .cp-contact__cards{ grid-template-columns: 1fr; }
}

.cp-contact__card{
  background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(255,255,255,0.86) 100%);
  border: 1px solid rgba(17,17,17,0.14);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow: 0 12px 28px rgba(0,0,0,0.07);
  position: relative;
  overflow: hidden;
  display:flex;
  flex-direction:column;
  gap: 6px;
}

.cp-contact__card::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(600px 220px at 10% 0%, color-mix(in srgb, var(--cpb-accent) 16%, transparent) 0%, transparent 55%);
  opacity: .75;
  pointer-events:none;
}

.cp-contact__card > *{ position: relative; z-index: 1; }

.cp-contact__card::after{
  content:"";
  position:absolute;
  top: 0; left: 0;
  width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--cpb-accent), color-mix(in srgb, var(--cpb-accent) 25%, transparent));
  opacity: .9;
}

.cp-contact__cardIcon{
  width: 40px; height: 40px;
  border-radius: 12px;
  display:grid;
  place-items:center;
  background: rgba(17,17,17,0.06);
  border: 1px solid rgba(17,17,17,0.10);
  margin-bottom: 12px;
}

.cp-contact__cardIcon i{
  color: var(--cpb-primary);
  font-size: 17px;
}

.cp-contact__card h3{
  margin: 0 0 6px 0;
  font-size: 18px;
  font-weight: 800;
  color:#111;
}

.cp-contact__card p{
  margin: 0;
  color: var(--cpb-muted);
  line-height: 1.55;
  font-size: 13.5px;
}

.cp-contact__card a{
  display:inline-block;
  margin-top: 10px;
  font-weight: 800;
  color: var(--cpb-primary);
  text-decoration: none;
}

.cp-contact__card a:hover{ text-decoration: underline; }

/* --- Main grid: form + info panel --- */
.cp-contact__main{
  margin-top: 22px;
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 18px;
  align-items: start;
}

@media (max-width: 980px){
  .cp-contact__main{ grid-template-columns: 1fr; }
}

.cp-contact__formWrap{
  background: var(--cpb-card);
  border: 1px solid var(--cpb-border);
  border-radius: var(--cpb-radius-lg);
  padding: 26px;
  box-shadow: var(--cpb-shadow);
}

.cp-contact__kicker{
  color: var(--cpb-accent);
  font-weight: 900;
  letter-spacing: .8px;
  font-size: 12px;
  text-transform: uppercase;
}

.cp-contact__headline{
  margin: 10px 0 8px 0;
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -0.8px;
}

.cp-contact__lead{
  color: var(--cpb-muted);
  line-height: 1.65;
  margin-bottom: 18px;
}

.cp-contact__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 620px){
  .cp-contact__grid{ grid-template-columns: 1fr; }
}

.cp-contact label{
  display:block;
  font-size: 13px;
  font-weight: 800;
  color:#111;
  margin-bottom: 7px;
}

.cp-contact input,
.cp-contact select,
.cp-contact textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(17,17,17,0.14);
  background: rgba(246,247,248,0.7);
  padding: 12px 14px;
  outline: none;
  transition: box-shadow .15s ease, border-color .15s ease, background-color .15s ease;
}

.cp-contact input:focus,
.cp-contact select:focus,
.cp-contact textarea:focus{
  border-color: color-mix(in srgb, var(--cpb-accent) 55%, #111);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--cpb-accent) 25%, transparent);
  background: #fff;
}

.cp-contact textarea{ min-height: 150px; resize: vertical; }

.cp-contact__full{ grid-column: 1 / -1; }

.cp-contact__consent{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  margin-top: 14px;
  color: var(--cpb-muted);
  font-size: 13px;
  line-height: 1.5;
}

.cp-contact__consent input{ width: 18px; height: 18px; margin-top: 2px; }

.cp-contact__consent a{ color: var(--cpb-primary); font-weight: 800; }

.cp-contact__actions{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-top: 16px;
}

.cp-contact__btn{
  appearance:none;
  border: 0;
  border-radius: 999px;
  padding: 12px 18px;
  background: var(--cpb-primary);
  color: #fff;
  font-weight: 900;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  box-shadow: 0 14px 30px rgba(0,0,0,0.18);
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}

.cp-contact__btn:hover{ transform: translateY(-1px); box-shadow: 0 18px 40px rgba(0,0,0,0.22); }
.cp-contact__btn:disabled{ opacity: .55; cursor: not-allowed; transform:none; }

.cp-contact__hint{
  font-size: 13px;
  color: var(--cpb-muted);
}

/* --- Info panel (dark “toolbox” card) --- */
.cp-contact__panel{
  background:
    radial-gradient(900px 520px at 10% 10%, color-mix(in srgb, var(--cpb-accent) 14%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, #0d0f12 0%, #121417 100%);
  color: #fff;
  border-radius: var(--cpb-radius-lg);
  padding: 22px;
  box-shadow: var(--cpb-shadow);
}


.cp-contact__panel h3{
  margin: 0 0 12px 0;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -0.3px;
}

.cp-contact__panelList{
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.cp-contact__panelItem{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}

.cp-contact__panelItem i{
  color: var(--cpb-accent);
  margin-top: 2px;
}

.cp-contact__panelItem b{ display:block; font-weight: 900; }
.cp-contact__panelItem span{ display:block; opacity: .85; line-height: 1.45; }

.cp-contact__social{
  display:flex;
  gap: 10px;
  margin-top: 14px;
}

.cp-contact__social a{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  color:#fff;
  text-decoration:none;
}

.cp-contact__social a:hover{ border-color: rgba(255,255,255,0.22); }

.cp-contact__emoji{
  font-size: 20px;
  line-height: 1;
}


/* --- Map --- */
.cp-contact__map{
  margin-top: 18px;
  border-radius: var(--cpb-radius-lg);
  overflow:hidden;
  border: 1px solid var(--cpb-border);
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
  background: #fff;
}

.cp-contact__mapInner{ position:relative; }
.cp-contact__map iframe{ width: 100%; height: 340px; border:0; pointer-events:none; }
.cp-contact__mapInner[data-active="1"] iframe{ pointer-events:auto; }
.cp-contact__mapOverlay{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(180deg, rgba(13,15,18,0.55) 0%, rgba(13,15,18,0.35) 100%);
  color:#fff;
  font-weight: 900;
  letter-spacing: .2px;
  cursor:pointer;
  z-index: 2;
}
.cp-contact__mapOverlay span{
  display:inline-flex; align-items:center; gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(6px);
}
.cp-contact__mapInner[data-active="1"] .cp-contact__mapOverlay{ display:none; }

.cp-contact__mapActions{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px;
  background: #fff;
  border-top: 1px solid var(--cpb-border);
}
.cp-contact__mapBtn{
  appearance:none;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;

  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  background: var(--cpb-primary);
  color:#fff;
  font-weight: 900;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  cursor:pointer;
  box-shadow: 0 12px 26px rgba(0,0,0,0.16);
}
.cp-contact__mapBtn:hover{ transform: translateY(-1px); }
.cp-contact__mapBtn--ghost{
  background: rgba(17,17,17,0.06);
  color:#111;
  border: 1px solid rgba(17,17,17,0.12);
  box-shadow: none;
}
.cp-contact__mapBtn--ghost:hover{ border-color: rgba(17,17,17,0.18); }


/* --- Status message states (optional) --- */
.cp-contact [data-cp-contact-status][data-type="success"]{ color: #0b6b3a; font-weight: 800; }
.cp-contact [data-cp-contact-status][data-type="error"]{ color: #b42318; font-weight: 800; }
.cp-contact [data-cp-contact-status][data-type="info"]{ color: var(--cpb-muted); font-weight: 700; }


/* --- Card link pills --- */
.cp-contact__cardLinks{
  display:flex;
  flex-direction:column;
  gap: 8px;
  margin-top: 8px;
}

.cp-contact__linkPill{
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(17,17,17,0.06);
  border: 1px solid rgba(17,17,17,0.10);
  color: #111;
  font-weight: 900;
  text-decoration: none;
  margin-top: 0;
}

.cp-contact__linkPill:hover{
  border-color: rgba(17,17,17,0.18);
  background: rgba(17,17,17,0.075);
  text-decoration: none;
}
/* Map UX: desktop always interactive, mobile toggle */
.cp-contact__mapInner { position: relative; }
.cp-contact__mapInner iframe { width: 100%; height: 100%; border: 0; }

/* Toggle button (hidden on desktop by default) */
.cp-contact__mapToggle{
  position: absolute;
  right: 14px;
  bottom: 14px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,14,18,.72);
  color: #fff;
  font-weight: 600;
  cursor: pointer;
  backdrop-filter: blur(8px);
  display: none;
}

/* Mobile behavior */
@media (max-width: 900px){
  .cp-contact__mapToggle{ display: inline-flex; align-items: center; gap: 8px; }
  .cp-contact__mapInner iframe{ pointer-events: none; }            /* scroll works */
  .cp-contact__mapInner[data-active="1"] iframe{ pointer-events: auto; } /* map works */
  .cp-contact__mapInner[data-active="1"] .cp-contact__mapToggle::after{
    content: " • activă";
    opacity: .85;
    font-weight: 500;
  }
}

/* Desktop: always active */
@media (min-width: 901px){
  .cp-contact__mapInner iframe{ pointer-events: auto; }
}
/* FORCE MAP INTERACTIVE - FINAL OVERRIDE */
.cp-contact__mapOverlay { display: none !important; }
.cp-contact__mapInner, .cp-contact__map { pointer-events: auto !important; }
.cp-contact__mapInner iframe { pointer-events: auto !important; }