/* YY Layout - container, section, grid */

.yy-container {
  width: 100%;
  max-width: var(--yy-container);
  margin-inline: auto;
  padding-inline: var(--yy-sp-4);
}
@media (min-width: 768px) {
  .yy-container { padding-inline: var(--yy-sp-5); }
}
@media (min-width: 1024px) {
  .yy-container { padding-inline: var(--yy-sp-6); }
}

.yy-container-sm { max-width: var(--yy-container-sm); }
.yy-container-xs { max-width: var(--yy-container-xs); }

.yy-section {
  padding-block: var(--yy-sp-7);
  position: relative;
}
@media (min-width: 768px) {
  .yy-section { padding-block: var(--yy-sp-8); }
}
@media (min-width: 1024px) {
  .yy-section { padding-block: var(--yy-sp-9); }
}

.yy-section--tight { padding-block: var(--yy-sp-6); }
.yy-section--loose { padding-block: var(--yy-sp-9); }

/* Section heading block */
.yy-section-head {
  max-width: 760px;
  margin-bottom: var(--yy-sp-6);
}
.yy-section-head--center {
  margin-inline: auto;
  text-align: center;
}
.yy-section-head .yy-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--yy-sp-2);
  padding: var(--yy-sp-1) var(--yy-sp-3);
  background: var(--yy-brand-weak);
  color: var(--yy-accent);
  border-radius: var(--yy-r-full);
  font-size: var(--yy-fs-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: var(--yy-sp-3);
}
.yy-section-head h2 {
  margin-bottom: var(--yy-sp-3);
  text-wrap: balance;
}
.yy-section-head p {
  color: var(--yy-text-mute);
  font-size: var(--yy-fs-lg);
  margin: 0;
  text-wrap: pretty;
}

/* Grid */
.yy-grid {
  display: grid;
  gap: var(--yy-sp-5);
}
.yy-grid-2 { grid-template-columns: 1fr; }
.yy-grid-3 { grid-template-columns: 1fr; }
.yy-grid-4 { grid-template-columns: 1fr; }
.yy-grid-5 { grid-template-columns: 1fr; }
.yy-grid-6 { grid-template-columns: 1fr; }

@media (min-width: 640px) {
  .yy-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .yy-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .yy-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .yy-grid-5 { grid-template-columns: repeat(2, 1fr); }
  .yy-grid-6 { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1024px) {
  .yy-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .yy-grid-4 { grid-template-columns: repeat(4, 1fr); }
  .yy-grid-5 { grid-template-columns: repeat(5, 1fr); }
  .yy-grid-6 { grid-template-columns: repeat(6, 1fr); }
}

/* Two column layout */
.yy-two-col {
  display: grid;
  gap: var(--yy-sp-6);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 1024px) {
  .yy-two-col {
    grid-template-columns: 1fr 1fr;
    gap: var(--yy-sp-8);
  }
  .yy-two-col--reverse > :first-child { order: 2; }
}

/* Stack */
.yy-stack > * + * { margin-top: var(--yy-sp-4); }
.yy-stack-sm > * + * { margin-top: var(--yy-sp-2); }
.yy-stack-lg > * + * { margin-top: var(--yy-sp-6); }

/* Cluster (flex with gap, wraps) */
.yy-cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--yy-sp-3);
  align-items: center;
}

/* Full viewport hero */
.yy-hero {
  min-height: clamp(560px, 88vh, 820px);
  padding-block: var(--yy-sp-8) var(--yy-sp-9);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.yy-dual-entry__grid {
  display: grid;
  gap: var(--yy-sp-5);
  grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
  .yy-dual-entry__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.yy-header__cta {
  display: flex;
  align-items: center;
  gap: var(--yy-sp-3);
}

@media (max-width: 1023px) {
  .yy-header__wa {
    display: none;
  }
}

@media (min-width: 1024px) {
  .yy-header__phone,
  .yy-header__wa {
    min-width: max-content;
  }
}

.yy-section + .yy-section {
  border-top: 1px solid color-mix(in srgb, var(--yy-border) 80%, transparent 20%);
}

.yy-final-cta {
  padding-top: var(--yy-sp-9);
}
