/* ============================================
   ARCHITECTURAL SERVICES - DESIGN SYSTEM STRUCTURE
   ============================================ */

/* Component Wrapper - Handles max-width for Architectural Services */
.asl-component-wrapper.asl-architectural-wrapper {
  max-width: var(--max-width-container) !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

/* Apply full-width breakout to ALL screen sizes */
body .asl-architectural-section {
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
  max-width: 100vw !important;
}

/* Main Section - Design System Variables */
.asl-architectural-section {
  width: 100%;
  padding: var(--padding-desktop) var(--padding-sides-desktop) !important;
  background: var(--color-white) !important;
  position: relative;
  box-sizing: border-box;
}

/* Mist background modifier */
.asl-architectural-section--mist {
  background: var(--color-mist) !important;
}

/* Tablet Section Padding */
@media (max-width: 1024px) {
  .asl-architectural-section {
    padding: var(--padding-tablet) var(--padding-sides-desktop) !important;
  }
}

/* Mobile Section Padding */
@media (max-width: 768px) {
  .asl-architectural-section {
    padding: var(--padding-mobile) var(--padding-sides-mobile) !important;
  }
}

/* ========================================
   HEADER SECTION - Design System
   ======================================== */

.asl-architectural-header {
  text-align: center;
  margin-bottom: var(--gap-large);
}

.asl-architectural-workflow-header {
  text-align: center;
  margin-bottom: var(--gap-large);
  margin-top: var(--gap-large);
}

/* H2 Title - Design System Variables */
.asl-architectural-title {
  font-family: var(--font-body) !important;
  font-size: var(--font-h2) !important;
  font-weight: var(--weight-semibold) !important;
  line-height: var(--line-height-h2) !important;
  letter-spacing: var(--letter-spacing-h2) !important;
  color: var(--color-navy) !important;
  margin: var(--margin-h2) !important;
  margin-bottom: 24px !important;
}

/* Mobile H2 */
@media (max-width: 768px) {
  .asl-architectural-title {
    font-size: var(--font-h2-mobile) !important;
  }
}

/* Subtitle/Description - Design System Variables */
.asl-architectural-description {
  font-family: var(--font-body) !important;
  font-size: var(--font-body) !important;
  font-weight: var(--weight-regular) !important;
  line-height: var(--line-height-body) !important;
  letter-spacing: var(--letter-spacing-body) !important;
  color: var(--color-charcoal) !important;
  max-width: var(--max-width-content) !important;
  margin: 0 auto;
}

/* Mobile Body Text */
@media (max-width: 768px) {
  .asl-architectural-description {
    font-size: var(--font-body-mobile) !important;
  }
}

/* ========================================
   MAIN CONTENT CONTAINER
   ======================================== */

.asl-architectural-wrapper .asl-architectural-container {
  max-width: var(--max-width-container);
  margin: 0 auto;
  width: 100%;
}

/* ========================================
   WHAT'S INCLUDED SECTION
   ======================================== */

.asl-architectural-wrapper .asl-architectural-included {
  background: linear-gradient(135deg, #1e3a5f 0%, #2b3e50 100%);
  border-radius: var(--border-radius-large);
  padding: 48px 40px;
  margin-bottom: var(--gap-large);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

/* Mobile Padding */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-included {
    padding: 32px 24px;
  }
}

/* Included Title (H3) */
.asl-architectural-wrapper .asl-architectural-included-title {
  font-family: var(--font-body) !important;
  font-size: var(--font-h3) !important;
  font-weight: var(--weight-medium) !important;
  line-height: var(--line-height-h3) !important;
  letter-spacing: var(--letter-spacing-h3) !important;
  color: var(--color-gold) !important;
  margin: 0 0 32px 0 !important;
  text-align: center;
}

/* Mobile H3 */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-included-title {
    font-size: var(--font-h3-mobile) !important;
    margin-bottom: 24px !important;
  }
}

/* Included Grid */
.asl-architectural-wrapper .asl-architectural-included-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}

/* Mobile: Single Column */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-included-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* Included Items */
.asl-architectural-wrapper .asl-architectural-included-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: var(--font-body);
  font-size: var(--font-body);
  font-weight: var(--weight-regular);
  line-height: var(--line-height-body);
  letter-spacing: var(--letter-spacing-body);
  color: var(--color-white);
}

/* Mobile List Item Text */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-included-item {
    font-size: var(--font-body-mobile);
  }
}

/* Checkmark Icon */
.asl-architectural-wrapper .asl-architectural-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-terracotta);
}

/* Callout Box */
.asl-architectural-wrapper .asl-architectural-callout {
  padding: 20px 24px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: var(--border-radius-medium);
  border-left: 4px solid var(--color-terracotta);
}

/* Mobile Callout */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-callout {
    padding: 16px 20px;
  }
}

/* Callout Text */
.asl-architectural-wrapper .asl-architectural-callout-text {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: var(--weight-regular);
  line-height: var(--line-height-body);
  color: var(--color-white);
  margin: 0;
  font-style: italic;
}

/* Callout Label (strong) */
.asl-architectural-wrapper .asl-architectural-callout-text strong {
  font-weight: var(--weight-semibold);
  color: var(--color-gold);
  font-style: normal;
}

/* Mobile Callout Text */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-callout-text {
    font-size: 14px;
  }
}

/* ========================================
   ACCORDION SECTION
   ======================================== */

.asl-architectural-wrapper .asl-architectural-accordion {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 800px;
  margin: 0 auto;
}

/* Accordion Item */
.asl-architectural-wrapper .asl-architectural-accordion-item {
  background: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--border-radius-large);
  overflow: hidden;
  transition: var(--transition-fast);
}

.asl-architectural-wrapper .asl-architectural-accordion-item:hover {
  border-color: var(--color-gold);
}

/* Accordion Button */
.asl-architectural-wrapper .asl-architectural-accordion-button {
  width: 100%;
  padding: 20px 28px;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px !important;
  min-height: 65px !important;
  text-align: left;
  transition: var(--transition-fast);
}

.asl-architectural-wrapper .asl-architectural-accordion-button:hover {
  background: transparent;
}

/* Mobile Button Padding */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-accordion-button {
    padding: 20px 20px;
    gap: 16px;
  }
}

/* Accordion Title */
.asl-architectural-wrapper .asl-architectural-accordion-title {
  font-family: var(--font-body) !important;
  font-size: 18px !important;
  font-weight: var(--weight-semibold) !important;
  line-height: 1.3 !important;
  letter-spacing: 0 !important;
  color: var(--color-navy) !important;
  margin: 0 !important;
  flex: 1 !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
  white-space: normal !important;
  max-width: calc(100% - 60px) !important;
}

/* Mobile H3 */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-accordion-title {
    font-size: 17px !important;
    max-width: calc(100% - 45px) !important;
  }
}

/* Accordion Icon (Chevron) */
.asl-architectural-wrapper .asl-architectural-accordion-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--color-gold);
  transition: transform 0.3s ease;
}

/* Rotate icon when active */
.asl-architectural-wrapper
  .asl-architectural-accordion-item.active
  .asl-architectural-accordion-icon {
  transform: rotate(180deg);
}

/* Accordion Content */
.asl-architectural-wrapper .asl-architectural-accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  border-top: 1px solid var(--color-border);
}

/* Show content when active */
.asl-architectural-wrapper
  .asl-architectural-accordion-item.active
  .asl-architectural-accordion-content {
  max-height: 1000px;
}

/* Phase List */
.asl-architectural-wrapper .asl-architectural-phase-list {
  list-style: none;
  padding: 24px 24px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Mobile List Padding */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-phase-list {
    padding: 20px 20px;
  }
}

/* Phase Item */
.asl-architectural-wrapper .asl-architectural-phase-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: var(--font-body);
  font-size: var(--font-body);
  font-weight: var(--weight-regular);
  line-height: var(--line-height-body);
  letter-spacing: var(--letter-spacing-body);
  color: var(--color-charcoal);
}

/* Mobile Phase Item Text */
@media (max-width: 768px) {
  .asl-architectural-wrapper .asl-architectural-phase-item {
    font-size: var(--font-body-mobile);
  }
}

/* Phase Bullet */
.asl-architectural-wrapper .asl-architectural-phase-bullet {
  width: 8px;
  height: 8px;
  background: var(--color-gold);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
}
