/* ============================================================
   VOLTERRA WordPress Theme — realestate.css
   Energy Infrastructure page specific styles only.
   Global header, footer, back-to-top are in global.css.
   ============================================================ */

.btn-secondary {
  background: var(--secondary);
  color: #fff;
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-xl);
  font-size: var(--fs-base);
  font-weight: 700;
  transition: filter var(--duration-base) var(--ease-out), box-shadow var(--duration-base);
}
.btn-secondary:hover { filter: brightness(1.12); box-shadow: var(--shadow-md); }

/* ── ghost border button (reused from oilgas) ── */
.og-btn-border {
  background: transparent;
  border: 1.5px solid rgba(255,255,255,.70);
  color: #fff;
  transition: background var(--duration-base) var(--ease-out), color var(--duration-base);
}
.og-btn-border:hover { background: #fff; color: var(--primary); }

/* ══════════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════════ */
.re-hero {
  position: relative;
  height: 85vh;
  min-height: 620px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.re-hero-bg { position: absolute; inset: 0; z-index: 0; }

.re-hero-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.06);
  animation: reHeroZoom 14s cubic-bezier(0.22,1,0.36,1) forwards;
  will-change: transform;
}
@keyframes reHeroZoom { to { transform: scale(1); } }

.re-hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(11,28,48,.62) 0%, transparent 75%);
}
.re-hero-energy-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(6,147,231,.28) 0%, rgba(59,101,36,.28) 100%);
}

.re-hero-content {
  position: relative; z-index: 10;
  padding-top: 5rem; width: 100%;
}
.re-hero-text {
  max-width: 42rem;
  display: flex; flex-direction: column; gap: var(--space-lg);
}

.re-label-pill {
  display: inline-block;
  padding: 0.3rem 1rem;
  background: rgba(36,76,13,.14);
  border: 1px solid rgba(36,76,13,.28);
  border-radius: var(--radius-full);
  color: var(--primary);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  width: fit-content;
}

.re-hero-h1 { color: #fff; line-height: 1.05; }
.re-hero-sub { color: rgba(255,255,255,.88); max-width: 36rem; line-height: 1.7; }
.re-hero-cta { display: flex; gap: var(--space-md); flex-wrap: wrap; padding-top: var(--space-sm); }

/* ══════════════════════════════════════════════════════════════
   BENTO GRID
══════════════════════════════════════════════════════════════ */
.re-bento-section { background: var(--surface); }

.re-bento-header {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-md);
  margin-bottom: 4rem;
}
.re-bento-sub { max-width: 36rem; }

.re-bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 2rem;
}

/* Base bento card */
.re-bento-card {
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease;
  cursor: pointer;
}
.re-bento-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); }

/* ── Site Selection (8 cols) ── */
.re-bento-site {
  grid-column: span 8;
  background: var(--surface-white);
  border: 1px solid rgba(194,201,185,.22);
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  min-height: 340px;
  position: relative;
}
.re-bento-site-content {
  padding: 2.5rem;
  display: flex; flex-direction: column; gap: .75rem;
  max-width: 26rem; position: relative; z-index: 2;
  flex: 1;
}
.re-bento-icon-lg { font-size: 2.5rem; display: block; }
.re-card-title  { margin-bottom: .5rem; }
.re-card-body   { flex: 1; }

.re-card-link {
  display: inline-flex; align-items: center; gap: .4rem;
  color: var(--primary); font-weight: 700; font-size: var(--fs-base);
  text-decoration: none;
  transition: gap var(--duration-base) var(--ease-out);
  margin-top: auto; padding-top: .75rem;
}
.re-card-link:hover { gap: .7rem; }
.re-card-link .material-symbols-outlined { font-size: 1.1rem; }

.re-bento-site-img {
  position: absolute; right: 0; top: 0;
  width: 45%; height: 100%;
  opacity: .10;
  transition: opacity var(--duration-slow) var(--ease-out);
}
.re-bento-site:hover .re-bento-site-img { opacity: .22; }
.re-bento-site-img img { width: 100%; height: 100%; object-fit: cover; }

/* ── Sustainable Dev (4 cols, primary green) ── */
.re-bento-dev {
  grid-column: span 4;
  background: var(--primary);
  display: flex; flex-direction: column; justify-content: space-between;
  min-height: 340px;
}
.re-bento-dev-top {
  padding: 2.5rem;
  display: flex; flex-direction: column; gap: .75rem;
}
.re-card-title-light { color: #fff; margin-bottom: .5rem; }
.re-card-body-light  { color: rgba(255,255,255,.80); }

.re-bento-dev-img {
  height: 9rem;
  overflow: hidden;
  margin: 0 1.5rem 1.5rem;
  border-radius: var(--radius-lg);
}
.re-bento-dev-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--duration-slower) var(--ease-out);
}
.re-bento-dev:hover .re-bento-dev-img img { transform: scale(1.08); }

/* ── Infrastructure Stewardship (full 12 cols) ── */
.re-bento-portfolio {
  grid-column: span 12;
  background: var(--surface-container);
  border: 1px solid rgba(194,201,185,.20);
  display: flex; align-items: center; gap: 2rem;
  flex-wrap: wrap; min-height: 260px;
}
.re-bento-port-text {
  flex: 1; min-width: 18rem;
  padding: 2.5rem;
  display: flex; flex-direction: column; gap: .75rem;
}
.re-port-btn { margin-top: .5rem; align-self: flex-start; }

.re-bento-port-img {
  flex: 1; min-width: 16rem; height: 100%; min-height: 220px;
  border-radius: var(--radius-lg); overflow: hidden;
  margin: 1.5rem 1.5rem 1.5rem 0;
  box-shadow: var(--shadow-md);
}
.re-bento-port-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--duration-slower) var(--ease-out);
}
.re-bento-portfolio:hover .re-bento-port-img img { transform: scale(1.04); }

/* ══════════════════════════════════════════════════════════════
   GLOBAL MAP
══════════════════════════════════════════════════════════════ */
.re-map-section {
  background: #131b2e;
  padding-block: var(--space-section);
  overflow: hidden;
}

.re-map-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
}

.re-map-pill {
  display: inline-block;
  padding: .25rem .9rem;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.20);
  border-radius: var(--radius-full);
  color: rgba(255,255,255,.80);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .06em;
  margin-bottom: 1rem;
}

.re-map-stats { display: flex; align-items: center; gap: 1.5rem; }
.re-map-stat { text-align: right; }
.re-map-stat-num {
  font-size: 1.875rem; font-weight: 700;
  color: var(--primary-fixed-dim);
  min-height: 1.2em;
}
.re-map-stat:last-child .re-map-stat-num { color: var(--secondary-container); }
.re-map-stat-label {
  font-size: var(--fs-xs); font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.re-map-divider { width: 1px; height: 2.5rem; background: rgba(255,255,255,.20); }

/* Map container */
.re-map-wrap {
  position: relative;
  width: 100%; aspect-ratio: 16 / 7;
  background: var(--tertiary);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  cursor: crosshair;
}
.re-map-img {
  width: 100%; height: 100%;
  object-fit: cover; opacity: .60;
  transition: opacity var(--duration-base) var(--ease-out);
  display: block;
}
.re-map-wrap:hover .re-map-img { opacity: .75; }

.re-map-tooltip {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.re-map-tooltip > div,
.re-map-tooltip {
  pointer-events: none;
}
.re-map-tooltip-inner {
  padding: 2rem 2.5rem;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-xl);
  max-width: 22rem; text-align: center;
}
.re-map-tooltip-title { font-size: var(--fs-lg); font-weight: 700; color: #fff; margin-bottom: .5rem; }
.re-map-tooltip-body  { font-size: var(--fs-sm); color: rgba(255,255,255,.68); line-height: 1.6; }

/* Pins */
.re-map-pin {
  position: absolute;
  width: .875rem; height: .875rem;
  border-radius: 50%;
  border: 2px solid #fff;
  cursor: pointer;
  transform: translate(-50%, -50%);
  transition: transform var(--duration-base) var(--ease-spring);
  z-index: 10;
}
.re-map-pin::after {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 1.5px solid currentColor;
  opacity: .4;
  animation: rePinPulse 2s ease-in-out infinite;
}
@keyframes rePinPulse {
  0%,100% { transform: scale(1); opacity: .4; }
  50% { transform: scale(1.5); opacity: 0; }
}
.re-map-pin[data-type="primary"]   { background: var(--primary-fixed-dim); color: var(--primary-fixed-dim); }
.re-map-pin[data-type="secondary"] { background: var(--secondary-container); color: var(--secondary-container); }
.re-map-pin[data-type="accent"]    { background: #fff; color: #fff; }
.re-map-pin:hover { transform: translate(-50%,-50%) scale(1.5); }

/* Floating pin label */
.re-pin-label {
  position: absolute;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: .3rem .8rem;
  border-radius: var(--radius-full);
  pointer-events: none;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity var(--duration-base), transform var(--duration-base);
  white-space: nowrap;
  z-index: 20;
}
.re-pin-label.visible { opacity: 1; transform: translateY(0); }

/* ══════════════════════════════════════════════════════════════
   CTA SECTION
══════════════════════════════════════════════════════════════ */
.re-cta-section { background: var(--surface-white); }

.re-cta-card {
  background: var(--surface-white);
  border: 1px solid rgba(194,201,185,.22);
  border-radius: 3rem;
  box-shadow: var(--shadow-xl);
  overflow: hidden;
  position: relative;
}

.re-cta-top-bar {
  height: 3px;
  background: var(--gradient-energy);
  width: 100%;
}

.re-cta-inner {
  padding: 4rem 5rem;
  display: flex; align-items: center; gap: 4rem;
  flex-wrap: wrap;
}

.re-cta-text { flex: 1; min-width: 18rem; }
.re-cta-headline { margin-bottom: 1.25rem; }
.re-cta-body     { margin-bottom: 2rem; }

/* Inline form */
.re-inline-form {
  display: flex; flex-direction: column; gap: .75rem;
  max-width: 28rem;
}
.re-form-input {
  width: 100%;
  padding: 1rem 1.25rem;
  border-radius: var(--radius-xl);
  background: var(--surface);
  border: 1px solid rgba(194,201,185,.35);
  font-family: var(--font-family);
  font-size: var(--fs-base);
  color: var(--on-surface);
  outline: none;
  transition: border-color var(--duration-base);
}
.re-form-input:focus { border-color: var(--secondary); }
.re-form-input::placeholder { color: rgba(66,73,61,.50); }

.re-select { appearance: none; cursor: pointer; }
.re-textarea { resize: vertical; min-height: 6rem; }

.re-form-btn {
  padding: 1rem 1.5rem;
  font-size: var(--fs-lg);
  font-weight: 700;
  border-radius: var(--radius-xl);
}

.re-form-privacy {
  display: flex; align-items: center; gap: .4rem;
  font-size: var(--fs-xs); color: var(--on-surface-variant);
  margin-top: .5rem;
}
.re-form-privacy .material-symbols-outlined { font-size: 1rem; }

/* Image col */
.re-cta-img-col { flex: 1; min-width: 16rem; position: relative; }
.re-cta-glow {
  position: absolute;
  top: -3rem; right: -3rem;
  width: 16rem; height: 16rem;
  background: radial-gradient(circle, var(--surface-container), transparent 70%);
  border-radius: 50%;
  filter: blur(40px);
  pointer-events: none;
}
.re-cta-img {
  width: 100%; border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl); display: block;
  position: relative; z-index: 1;
  transition: transform var(--duration-base) var(--ease-out);
}
.re-cta-img:hover { transform: translateY(-4px); }

/* ══════════════════════════════════════════════════════════════
   FORM MODAL
══════════════════════════════════════════════════════════════ */
.re-modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(11,28,48,.55);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-lg);
  opacity: 0; visibility: hidden;
  transition: opacity var(--duration-base) var(--ease-out), visibility var(--duration-base);
}
.re-modal-overlay.open { opacity: 1; visibility: visible; }

.re-modal {
  background: var(--surface-white);
  border-radius: 2rem;
  box-shadow: 0 32px 80px rgba(0,0,0,.22);
  width: 100%; max-width: 36rem;
  max-height: 90vh; overflow-y: auto;
  position: relative;
  transform: translateY(24px) scale(.97);
  transition: transform var(--duration-slow) var(--ease-spring);
  scrollbar-width: thin;
}
.re-modal-overlay.open .re-modal { transform: translateY(0) scale(1); }

.re-modal-close {
  position: absolute; top: 1.25rem; right: 1.25rem;
  width: 2.25rem; height: 2.25rem;
  border-radius: 50%;
  background: var(--surface);
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--on-surface-variant);
  transition: background var(--duration-fast), transform var(--duration-fast);
  z-index: 10;
}
.re-modal-close:hover { background: var(--surface-container); transform: scale(1.1); }
.re-modal-close .material-symbols-outlined { font-size: 1.25rem; }

.re-modal-content { padding: 2.5rem; }

.re-modal-icon {
  width: 3.5rem; height: 3.5rem;
  border-radius: var(--radius-lg);
  background: rgba(36,76,13,.10);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
  color: var(--primary);
}
.re-modal-icon-secondary { background: rgba(0,98,157,.10); color: var(--secondary); }
.re-modal-icon .material-symbols-outlined { font-size: 1.875rem; }

.re-modal-title {
  font-size: 1.5rem; font-weight: 700; margin-bottom: .5rem; color: var(--on-surface);
}
.re-modal-sub {
  font-size: var(--fs-sm); color: var(--on-surface-variant); margin-bottom: 1.75rem; line-height: 1.6;
}

.re-modal-form { display: flex; flex-direction: column; gap: 1rem; }

.re-field-group { display: flex; flex-direction: column; gap: .4rem; }
.re-field-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.re-label {
  font-size: var(--fs-xs); font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: var(--on-surface-variant);
}
.re-input {
  padding: .85rem 1rem;
  border-radius: var(--radius-lg);
  border: 1.5px solid rgba(194,201,185,.40);
  background: var(--surface);
  font-family: var(--font-family);
  font-size: var(--fs-base);
  color: var(--on-surface);
  outline: none;
  transition: border-color var(--duration-base), box-shadow var(--duration-base);
  width: 100%;
}
.re-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(36,76,13,.12);
}
.re-input.error { border-color: var(--error); box-shadow: 0 0 0 3px rgba(186,26,26,.10); }

.re-modal-submit {
  padding: 1rem; font-size: var(--fs-base); font-weight: 700;
  border-radius: var(--radius-xl); width: 100%; margin-top: .5rem;
}

.re-modal-privacy {
  display: flex; align-items: center; justify-content: center; gap: .35rem;
  font-size: var(--fs-xs); color: var(--on-surface-variant); margin-top: .25rem;
}
.re-modal-privacy .material-symbols-outlined { font-size: .9rem; }

/* Success state */
.re-modal-success {
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding: clamp(2.25rem, 5vw, 4rem) clamp(1.25rem, 4vw, 3rem);
  border-radius: 0 0 var(--radius-lg, 24px) var(--radius-lg, 24px);
  background: radial-gradient(circle at 50% 0%, rgba(163, 212, 134, 0.10), transparent 35%), linear-gradient(145deg, rgba(22, 33, 55, 0.98), rgba(14, 23, 39, 0.98));
  color: #fff;
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 28px 80px rgba(0,0,0,.22);
}
.re-success-icon {
  width: 3rem; height: 3rem; margin: 0 auto 2rem; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 4px solid var(--primary-fixed-dim); color: var(--primary-fixed-dim);
  font-size: 2rem; font-variation-settings: 'FILL' 1;
  animation: successPop .5s var(--ease-spring) forwards;
}
@keyframes successPop { from { transform: scale(0); } to { transform: scale(1); } }
.re-success-title { color: var(--primary-fixed-dim); font-size: clamp(1.6rem, 3vw, 2.25rem); font-weight: 850; margin: 0 0 1.35rem; }
.re-success-body  { color: rgba(255,255,255,.72); font-size: clamp(1rem, 1.5vw, 1.15rem); line-height: 1.75; margin-bottom: 2rem; }
.re-modal-success .btn { background: transparent; color: var(--primary-fixed-dim); border: 1.5px solid var(--primary-fixed-dim); }
.re-modal-success .btn:hover { background: var(--primary-fixed-dim); color: var(--primary); }


/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .re-bento-site      { grid-column: span 12; }
  .re-bento-dev       { grid-column: span 12; min-height: auto; }
  .re-bento-portfolio { flex-direction: column; }
  .re-bento-port-img  { margin: 0 1.5rem 1.5rem; height: 220px; min-width: unset; width: auto; }
}

@media (max-width: 900px) {
  .re-cta-inner { padding: 2.5rem; flex-direction: column; }
  .re-map-header { flex-direction: column; align-items: flex-start; }
  .re-map-stats  { align-self: flex-start; }
}

@media (max-width: 700px) {
  .re-hero-cta { flex-direction: column; }
  .re-field-row { grid-template-columns: 1fr; }
  .re-map-wrap  { aspect-ratio: 4/3; }
  .re-cta-inner { padding: 2rem 1.5rem; }
}
