/* ==========================================================================
   VIRETTO — Page-Specific Styles
   Hero, Home sections, About, Properties, Contact, Individual pages
   ========================================================================== */

/* ==========================================================================
   HERO
   ========================================================================== */

.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding-top: 80px;
}

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

.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: hero-ken-burns 25s ease-in-out infinite alternate;
}

@keyframes hero-ken-burns {
  0%   { transform: scale(1) translate(0, 0); }
  100% { transform: scale(1.08) translate(-1%, -1%); }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      135deg,
      rgba(12, 17, 23, 0.92) 0%,
      rgba(12, 17, 23, 0.75) 40%,
      rgba(27, 58, 75, 0.35) 100%
    );
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 700px;
  padding: var(--v-space-9) 0;
}

.hero .overline {
  margin-bottom: var(--v-space-4);
  display: inline-block;
}

.hero-title {
  font-family: var(--v-font-heading);
  font-size: var(--v-fs-display);
  font-weight: 700;
  line-height: var(--v-lh-tight);
  letter-spacing: var(--v-ls-tight);
  color: var(--v-white);
  margin-bottom: var(--v-space-5);
}

.hero-title .accent {
  color: var(--v-copper);
}

.hero-title .italic {
  font-family: var(--v-font-display);
  font-style: italic;
  font-weight: 400;
  color: var(--v-copper);
}

.hero-subtitle {
  font-size: var(--v-fs-body-lg);
  color: var(--v-gray-300);
  line-height: var(--v-lh-body);
  margin-bottom: var(--v-space-7);
  max-width: 560px;
}

.hero-actions {
  display: flex;
  gap: var(--v-space-4);
  flex-wrap: wrap;
}

.hero-scroll-indicator {
  position: absolute;
  bottom: var(--v-space-2);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--v-space-2);
  color: #fff;
  font-size: var(--v-fs-overline);
  letter-spacing: var(--v-ls-overline);
  text-transform: uppercase;
  animation: scroll-bounce 2s ease-in-out infinite;
}

@keyframes scroll-bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(8px); }
}

.hero-scroll-indicator svg {
  width: 20px;
  height: 20px;
}

/* ── Page Hero (Internal pages) ──────────────────────────────────────────── */
.page-hero {
  padding: calc(var(--v-space-12) + 80px) 0 var(--v-space-9);
  background:
    linear-gradient(
      180deg,
      var(--v-dark) 0%,
      var(--v-dark-card) 100%
    );
  text-align: center;
}

.page-hero .overline {
  margin-bottom: var(--v-space-3);
  display: block;
}

.page-hero h1 {
  margin-bottom: var(--v-space-4);
}

.page-hero p {
  font-size: var(--v-fs-body-lg);
  color: var(--v-text-secondary);
  max-width: 640px;
  margin: 0 auto;
}

/* ==========================================================================
   HOME — Value Proposition
   ========================================================================== */

.value-props {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--v-space-6);
}

/* ==========================================================================
   HOME — Process / How It Works
   ========================================================================== */

.process-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--v-space-5);
}

.process-line {
  display: none; /* decorative connecting line between steps on lg screens */
}

/* ==========================================================================
   HOME — Featured Properties
   ========================================================================== */

.properties-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--v-space-6);
}

.properties-actions {
  display: flex;
  justify-content: center;
  margin-top: var(--v-space-7);
}

/* ==========================================================================
   HOME — AI / Technology Section
   ========================================================================== */

.ai-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--v-space-9);
  align-items: center;
}

.ai-visual {
  position: relative;
  border-radius: var(--v-radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--v-dark-elevated);
}

.ai-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ai-badge {
  position: absolute;
  bottom: var(--v-space-4);
  left: var(--v-space-4);
  display: flex;
  align-items: center;
  gap: var(--v-space-2);
  padding: var(--v-space-2) var(--v-space-4);
  background: rgba(12, 17, 23, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: var(--v-radius-pill);
  border: 1px solid rgba(184, 115, 51, 0.2);
}

.ai-badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--v-copper);
  animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.4; }
}

.ai-badge span {
  font-family: var(--v-font-heading);
  font-size: var(--v-fs-overline);
  font-weight: 600;
  color: var(--v-copper);
  text-transform: uppercase;
  letter-spacing: var(--v-ls-overline);
}

.ai-content .overline {
  margin-bottom: var(--v-space-3);
  display: block;
}

.ai-content h2 {
  margin-bottom: var(--v-space-4);
}

.ai-content p {
  color: var(--v-text-secondary);
  margin-bottom: var(--v-space-5);
  line-height: var(--v-lh-body);
}

.ai-features {
  display: flex;
  flex-direction: column;
  gap: var(--v-space-4);
}

.ai-feature {
  display: flex;
  gap: var(--v-space-3);
  align-items: flex-start;
}

.ai-feature-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--v-radius-sm);
  background: rgba(184, 115, 51, 0.1);
  color: var(--v-copper);
  flex-shrink: 0;
}

.ai-feature-icon svg {
  width: 18px;
  height: 18px;
}

.ai-feature-text h4 {
  font-size: var(--v-fs-body);
  font-weight: 600;
  margin-bottom: var(--v-space-1);
}

.ai-feature-text p {
  font-size: var(--v-fs-body-sm);
  color: var(--v-text-tertiary);
  margin-bottom: 0;
}

/* ==========================================================================
   HOME — Investor Section
   ========================================================================== */

.investor-section {
  position: relative;
  overflow: hidden;
}

.investor-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:
    radial-gradient(
      ellipse at 30% 50%,
      rgba(27, 58, 75, 0.15) 0%,
      transparent 60%
    );
  pointer-events: none;
}

.investor-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--v-space-9);
  align-items: center;
}

.investor-text .overline {
  margin-bottom: var(--v-space-3);
  display: block;
}

.investor-text h2 {
  margin-bottom: var(--v-space-4);
}

.investor-text .text-display-accent {
  font-size: var(--v-fs-h3);
  display: block;
  margin-bottom: var(--v-space-4);
}

.investor-text p {
  color: var(--v-text-secondary);
  margin-bottom: var(--v-space-6);
}

.investor-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--v-space-6);
}

.investor-stat {
  padding: var(--v-space-5);
  background: var(--v-bg-card);
  border: var(--v-border-subtle);
  border-radius: var(--v-radius-lg);
  text-align: center;
}

/* ==========================================================================
   HOME — Credibility / Social Proof
   ========================================================================== */

.credibility-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--v-space-6);
  text-align: center;
}

/* ==========================================================================
   HOME — CTA Final
   ========================================================================== */

.cta-final {
  text-align: center;
  padding: var(--v-space-11) 0;
  position: relative;
  overflow: hidden;
}

.cta-final::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      ellipse at 50% 0%,
      rgba(184, 115, 51, 0.08) 0%,
      transparent 70%
    );
  pointer-events: none;
}

.cta-final .overline {
  margin-bottom: var(--v-space-3);
  display: block;
}

.cta-final h2 {
  margin-bottom: var(--v-space-4);
}

.cta-final p {
  color: var(--v-text-secondary);
  font-size: var(--v-fs-body-lg);
  max-width: 560px;
  margin: 0 auto var(--v-space-7);
}

.cta-final-actions {
  display: flex;
  justify-content: center;
  gap: var(--v-space-4);
  flex-wrap: wrap;
}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */

.about-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--v-space-9);
  align-items: center;
}

.about-intro-text .overline {
  margin-bottom: var(--v-space-3);
  display: block;
}

.about-intro-text h2 {
  margin-bottom: var(--v-space-4);
}

.about-intro-text p {
  color: var(--v-text-secondary);
  margin-bottom: var(--v-space-4);
  line-height: var(--v-lh-body);
}

.about-intro-image {
  border-radius: var(--v-radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--v-dark-elevated);
}

.about-intro-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--v-space-6);
}

/* ==========================================================================
   PROPERTY / LAND INDIVIDUAL PAGE
   ========================================================================== */

.property-header {
  padding-top: calc(80px + var(--v-space-6));
  padding-bottom: var(--v-space-6);
}

.property-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--v-space-2);
  font-size: var(--v-fs-caption);
  color: var(--v-text-tertiary);
  margin-bottom: var(--v-space-4);
}

.property-breadcrumb a {
  color: var(--v-text-tertiary);
  transition: color var(--v-duration-fast) var(--v-ease-out);
}

.property-breadcrumb a:hover {
  color: var(--v-copper);
}

.property-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--v-space-6);
  flex-wrap: wrap;
}

.property-title-row h1 {
  flex: 1;
}

.property-price-block {
  text-align: right;
}

.property-price-block .text-price {
  font-size: var(--v-fs-h2);
  display: block;
}

.property-price-block .badge {
  margin-top: var(--v-space-2);
}

.property-details {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--v-space-8);
  padding: var(--v-space-8) 0;
}

.property-main h2 {
  font-size: var(--v-fs-h3);
  margin-bottom: var(--v-space-4);
}

.property-description {
  color: var(--v-text-secondary);
  margin-bottom: var(--v-space-7);
  line-height: var(--v-lh-body);
}

.property-features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--v-space-3);
  margin-bottom: var(--v-space-7);
}

.property-feature {
  display: flex;
  align-items: center;
  gap: var(--v-space-2);
  font-size: var(--v-fs-body-sm);
  color: var(--v-text-secondary);
}

.property-feature svg {
  width: 16px;
  height: 16px;
  color: var(--v-copper);
  flex-shrink: 0;
}

.property-specs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--v-space-4);
  padding: var(--v-space-5);
  background: var(--v-bg-card);
  border: var(--v-border-subtle);
  border-radius: var(--v-radius-lg);
  margin-bottom: var(--v-space-7);
}

.property-spec {
  display: flex;
  flex-direction: column;
  gap: var(--v-space-1);
}

.property-spec-label {
  font-size: var(--v-fs-caption);
  color: var(--v-text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--v-ls-wide);
}

.property-spec-value {
  font-family: var(--v-font-heading);
  font-size: var(--v-fs-body-lg);
  font-weight: 600;
}

/* Sidebar */
.property-sidebar {
  position: sticky;
  top: calc(80px + var(--v-space-6));
}

.sidebar-card {
  padding: var(--v-space-6);
  background: var(--v-bg-card);
  border: var(--v-border-subtle);
  border-radius: var(--v-radius-lg);
  margin-bottom: var(--v-space-5);
}

.sidebar-card h3 {
  font-size: var(--v-fs-h4);
  margin-bottom: var(--v-space-4);
}

.sidebar-card .btn {
  width: 100%;
  margin-top: var(--v-space-4);
}

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

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--v-space-9);
  align-items: start;
}

.contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--v-space-6);
}

.contact-item {
  display: flex;
  gap: var(--v-space-4);
}

.contact-item-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--v-radius-md);
  background: rgba(184, 115, 51, 0.1);
  color: var(--v-copper);
  flex-shrink: 0;
}

.contact-item-icon svg {
  width: 22px;
  height: 22px;
}

.contact-item h4 {
  font-size: var(--v-fs-body);
  margin-bottom: var(--v-space-1);
}

.contact-item p {
  font-size: var(--v-fs-body-sm);
  color: var(--v-text-secondary);
}

.contact-form-card {
  padding: var(--v-space-7);
  background: var(--v-bg-card);
  border: var(--v-border-subtle);
  border-radius: var(--v-radius-lg);
}

.contact-form-card h2 {
  font-size: var(--v-fs-h3);
  margin-bottom: var(--v-space-2);
}

.contact-form-card > p {
  color: var(--v-text-secondary);
  font-size: var(--v-fs-body-sm);
  margin-bottom: var(--v-space-6);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--v-space-4);
}

/* ==========================================================================
   RESPONSIVE — Page specifics
   ========================================================================== */

@media (max-width: 1024px) {
  .ai-section,
  .investor-content,
  .about-intro,
  .property-details,
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .property-sidebar {
    position: static;
  }

  .credibility-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .hero {
    min-height: 85vh;
  }

  .hero-content {
    padding: var(--v-space-6) 0;
  }

  .hero-actions {
    flex-direction: column;
  }

  .hero-actions .btn {
    width: 100%;
  }

  .hero-scroll-indicator {
    display: none;
  }

  .value-props {
    grid-template-columns: 1fr;
  }

  .process-grid {
    grid-template-columns: 1fr;
  }

  .properties-grid {
    grid-template-columns: 1fr;
  }

  .about-values {
    grid-template-columns: 1fr;
  }

  .investor-stats {
    grid-template-columns: 1fr;
  }

  .credibility-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .property-title-row {
    flex-direction: column;
  }

  .property-price-block {
    text-align: left;
  }

  .property-features {
    grid-template-columns: 1fr;
  }

  .property-specs-grid {
    grid-template-columns: 1fr;
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .page-hero {
    text-align: left;
    padding: calc(var(--v-space-11) + 80px) 0 var(--v-space-8);
  }

  .page-hero p {
    margin: 0;
  }
}
