/* ═══════════════════════════════════════════════════════════
   TAC DESIGN SYSTEM — RESET + BASE
═══════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  font-family: var(--font-b);
  color: var(--t1);
  background: var(--bg0);
  line-height: 1.6;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: var(--font-b); cursor: pointer; }

/* Override GeneratePress defaults */
body .site-content,
body .inside-article,
body .entry-content,
body .content-area,
body .inside-page-header { padding: 0; margin: 0; max-width: none; }

/* Remove GP header/footer/nav — replaced by custom template parts */
body .site-header,
body .site-footer,
body .site-info,
body .main-navigation,
body .mobile-menu-control-wrapper,
body .page-header { display: none !important; }

/* Remove GP container wrapper styling — CRITICAL for full-width layout */
body .site.grid-container.container,
body .grid-container {
  max-width: none !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block !important;
}
body .site-content {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
}
body .separate-containers .inside-article,
body .separate-containers .comments-area,
body .separate-containers .page-header,
body .separate-containers .paging-navigation {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Remove GP content width constraints */
body .site-content .content-area,
body .content-area {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
body .is-right-sidebar,
body .is-left-sidebar { display: none !important; }
body .site-main {
  margin: 0 !important;
  padding: 0 !important;
}
body .entry-content {
  max-width: none !important;
  padding: 0 !important;
}

/* Override GP body background and inline container padding */
body.separate-containers { background: var(--bg0) !important; }
body .one-container .site-content,
body .separate-containers .inside-article { padding: 0 !important; }
body .inside-page-header { padding: 0 !important; }
body .entry-content .alignwide,
body .entry-content .alignfull { margin-left: 0 !important; width: 100% !important; max-width: 100% !important; }

/* Prevent horizontal overflow — clip preserves sticky positioning, hidden breaks it */
body {
  overflow-x: clip;
}
html {
  overflow-x: clip;
}

/* ═══════════════════════════════════════════════════════════
   LAYOUT UTILITIES
═══════════════════════════════════════════════════════════ */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 24px; }
.section    { padding: 64px 0; }
.section-sm { padding: 40px 0; }
.section-hdr {
  display: flex; align-items: baseline;
  justify-content: space-between; margin-bottom: 28px;
}
.section-title {
  font-family: var(--font-d);
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 400; color: var(--t1); letter-spacing: -.01em;
}
.section-link {
  font-size: 13px; color: var(--t2);
  border-bottom: 1px solid var(--br-md);
  padding-bottom: 1px; transition: color .2s, border-color .2s;
}
.section-link:hover { color: var(--gold); border-color: var(--gold); }

/* Divider */
.divider { height: .5px; background: var(--br); max-width: var(--max-w); margin: 0 auto; }

/* ═══════════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════════ */
.btn-primary {
  font-size: 13px; font-weight: 500;
  font-family: var(--font-b);
  padding: 10px 20px; border-radius: var(--r);
  border: none; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: background .2s, transform .1s;
  background: var(--gold); color: #fff;
}
.btn-primary:hover { background: var(--gold-dim); }
.btn-primary:active { transform: scale(.98); }

.btn-outline {
  font-size: 13px; font-weight: 500;
  font-family: var(--font-b);
  padding: 10px 20px; border-radius: var(--r);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: background .2s, border-color .2s;
  background: transparent; color: var(--t1);
  border: .5px solid var(--br-md);
}
.btn-outline:hover { background: var(--bg2); border-color: var(--t3); }

.btn-wa {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--wa); color: #fff;
  font-size: 12.5px; font-weight: 500;
  padding: 7px 13px; border-radius: 7px;
  border: none; cursor: pointer; white-space: nowrap;
  font-family: var(--font-b);
  transition: background .2s;
}
.btn-wa:hover { background: var(--wa-dark); }
.btn-wa svg { width: 13px; height: 13px; fill: #fff; flex-shrink: 0; }

.btn-tg {
  display: inline-flex; align-items: center; gap: 6px;
  background: #229ED9; color: #fff;
  font-size: 12.5px; font-weight: 500;
  padding: 7px 13px; border-radius: 7px;
  border: none; cursor: pointer; white-space: nowrap;
  font-family: var(--font-b);
  transition: background .2s;
  text-decoration: none;
}
.btn-tg:hover { background: #1989B8; color: #fff; }
.btn-tg svg { width: 13px; height: 13px; fill: #fff; flex-shrink: 0; }

.btn-destiny {
  font-size: 13px; font-weight: 500;
  font-family: var(--font-b);
  padding: 10px 20px; border-radius: var(--r);
  border: none; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: background .2s;
  background: var(--gold-l); color: var(--gold-dim);
}
.btn-destiny:hover { background: #f0e8c8; }

/* ═══════════════════════════════════════════════════════════
   SCROLL ANIMATIONS
═══════════════════════════════════════════════════════════ */
.fade-up {
  opacity: 0; transform: translateY(20px);
  transition: opacity .55s ease, transform .55s ease;
}
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* Shorthand class used in some templates */
.fu { opacity: 0; transform: translateY(20px); transition: opacity .55s ease, transform .55s ease; }
.fu.visible { opacity: 1; transform: translateY(0); }
