/* ═══════════════════════════════════════════════════════════════════
   MAKENA BUILDING GROUP — Layout System
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Site Grid ─── */
.site-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
}

/* ─── Hero Layout ─── */
.hero-left {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 4rem 5rem;
  background: var(--ink);
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 2rem;
  opacity: 0;
  animation: fadeUp .8s ease .3s forwards;
}

.hero-badge::before {
  content: '';
  width: 30px;
  height: 1px;
  background: var(--gold);
}

.hero-h1 {
  font-family: var(--font-heading);
  font-size: clamp(3.8rem, 6vw, 7rem);
  font-weight: 300;
  line-height: .95;
  letter-spacing: -0.02em;
  color: var(--white);
  margin-bottom: 2rem;
  opacity: 0;
  animation: fadeUp .9s ease .5s forwards;
}

.hero-h1 em { font-style: italic; color: var(--gold); }
.hero-h1 .outline {
  -webkit-text-stroke: 1px rgba(245,240,232,.3);
  color: transparent;
}

.hero-sub {
  font-family: var(--font-main);
  font-size: .85rem;
  color: var(--text);
  line-height: 1.8;
  max-width: 360px;
  margin-bottom: 3rem;
  opacity: 0;
  animation: fadeUp .8s ease .7s forwards;
}

.hero-sub strong { color: var(--sand); font-weight: 400; }
.hero-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp .8s ease .9s forwards;
}

.hero-vert {
  position: absolute;
  left: 1.5rem;
  top: 50%;
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: center;
  font-family: var(--font-mono);
  font-size: .58rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--border);
  white-space: nowrap;
}

.hero-scroll {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  opacity: 0;
  animation: fadeUp .6s ease 1.5s forwards;
}

.hero-scroll-line {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

.hero-scroll span {
  font-family: var(--font-mono);
  font-size: .55rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--text);
}

/* ─── Brick Hero Panel ─── */
.hero-brick {
  position: relative;
  overflow: hidden;
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 38px,
      rgba(0,0,0,0.15) 38px,
      rgba(0,0,0,0.15) 40px
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 113px,
      rgba(0,0,0,0.12) 113px,
      rgba(0,0,0,0.12) 115px
    ),
    repeating-linear-gradient(
      0deg,
      #a0522d,
      #8b4513 2px,
      #9b5523 4px,
      #7a3e10 40px
    );
}

.hero-brick::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,.45) 100%);
  z-index: 1;
}

.brick-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to right, var(--ink) 0%, transparent 30%);
}

.brick-content {
  position: absolute;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .8rem;
  text-align: center;
}

.brick-label {
  font-family: var(--font-mono);
  font-size: .6rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold-l);
}

.brick-rule {
  width: 40px;
  height: 1px;
  background: var(--gold);
}

.brick-sub {
  font-family: var(--font-mono);
  font-size: .55rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(245,240,232,.5);
}

/* ─── Ticker ─── */
.ticker {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: .7rem 0;
  overflow: hidden;
  background: var(--ink2);
}

.ticker-track {
  display: flex;
  gap: 5rem;
  white-space: nowrap;
  animation: ticker 32s linear infinite;
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text);
}

.ticker-track .sep { color: var(--gold); }

@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─── Grid Layouts ─── */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8rem;
  align-items: center;
}

.about-visual {
  display: grid;
  grid-template-columns: 3fr 2fr;
  grid-template-rows: 2fr 1fr;
  gap: 8px;
  height: 560px;
}

.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid #D4C4A8;
  border-left: 1px solid #D4C4A8;
}

.stat-cell {
  padding: 1.5rem;
  border-right: 1px solid #D4C4A8;
  border-bottom: 1px solid #D4C4A8;
}

.stat-num {
  font-family: var(--font-heading);
  font-size: 2.8rem;
  font-weight: 300;
  color: var(--gold-d);
  line-height: 1;
  letter-spacing: -0.02em;
}

.stat-lbl {
  font-family: var(--font-mono);
  font-size: .55rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: #8A7A6A;
  margin-top: .4rem;
}

.services-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: end;
  margin-bottom: 5rem;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.why-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8rem;
  align-items: start;
  margin-top: 4rem;
}

.why-right { position: sticky; top: 120px; }

.process-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
}

.process-steps::before {
  content: '';
  position: absolute;
  top: 36px;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(to right, var(--gold), transparent 80%);
}

/* ─── CTA Section ─── */
#cta {
  position: relative;
  overflow: hidden;
  background: var(--ink2);
  padding: 10rem 0;
}

.cta-bg-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font-heading);
  font-size: clamp(8rem, 20vw, 20rem);
  font-weight: 300;
  color: rgba(184,151,90,.03);
  white-space: nowrap;
  pointer-events: none;
  letter-spacing: -0.02em;
}

.cta-glow {
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(184,151,90,.06) 0%, transparent 65%);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.cta-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

.cta-eyebrow {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
}

.cta-eyebrow::before,
.cta-eyebrow::after {
  content: '';
  width: 30px;
  height: 1px;
  background: var(--gold);
}

.cta-h2 {
  font-family: var(--font-heading);
  font-size: clamp(3rem, 6vw, 6rem);
  font-weight: 300;
  line-height: .95;
  letter-spacing: -0.02em;
  color: var(--white);
  margin-bottom: 1.5rem;
}

.cta-h2 em { font-style: italic; color: var(--gold); }
.cta-sub {
  font-family: var(--font-main);
  font-size: 1rem;
  color: var(--text);
  line-height: 1.75;
  margin-bottom: 3rem;
}

.cta-actions {
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.cta-contacts {
  display: flex;
  justify-content: center;
  gap: 3rem;
  margin-top: 3rem;
  flex-wrap: wrap;
}

.cta-contact-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .08em;
  color: var(--text);
}

.cta-contact-item span { color: var(--gold); }