.page-self-media {
  background: #fff;
  color: #1a1a1a;
}

.page-self-media .mobile-menu__panel {
  border: none;
  margin: 0;
}

.self-media-hero {
  height: 357px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: url("../assets/images/marketing/self-media-hero-bg@2x.png") center / cover no-repeat;
}

.self-media-hero__panel {
  width: 408px;
  height: 110px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
  margin-top: 68px;
}

.self-media-hero__panel h1 {
  margin: 0;
  font-size: 32px;
  line-height: 1.2;
  font-weight: 600;
}

.self-media-hero__panel p {
  margin: 10px 0 0;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 0.2em;
  text-indent: 0.72em;
  text-transform: uppercase;
}

.self-operation {
  padding: 23px 0 95px;
  background: #fafafa;
}

.page-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  color: #999;
  font-size: 12px;
  line-height: 22px;
}

.page-breadcrumb a {
  color: inherit;
  transition: color var(--transition);
}

.page-breadcrumb a:hover,
.page-breadcrumb span:last-child {
  color: #111;
}

.self-service {
  display: grid;
  align-items: center;
  justify-content: space-between;
}

.self-service--operation {
  grid-template-columns: minmax(0, 746px) minmax(0, 554px);
  gap: 96px;
  margin-top: 73px;
}

.self-operation-visual {
  position: relative;
  width: 746px;
  min-height: 516px;
  margin: 0;
}

.self-operation-visual__main {
  width: 100%;
  object-fit: cover;
}

.self-operation-visual__bottom {
  position: absolute;
  left: 28px;
  top: 254px;
  z-index: 2;
  display: flex;
  gap: 3px;
}

.self-operation-visual__bottom img {
  display: block;
  height: 254px;
  width: auto;
}

.self-operation-visual__badge {
  position: absolute;
  z-index: 4;
  height: 56px;
  min-width: 145px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 10px;
  background: #fff;
  color: #111;
  font-size: 26px;
  line-height: 1;
  box-shadow: 0 4px 13px rgba(0, 0, 0, 0.25);
}

.self-operation-visual__badge span {
  display: inline-flex;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  background: #d82f2f;
  color: #fff;
  font-size: 15px;
  line-height: 1;
}

.self-operation-visual__badge--left {
  left: 0;
  top: 222px;
}

.self-operation-visual__badge--right {
  right: 0;
  bottom: 0;
}

.self-operation-visual figcaption {
  position: absolute;
  left: 243px;
  top: 390px;
  z-index: 4;
  margin: 0;
  font-family: var(--font-family-oswald);
  font-size: 34px;
  line-height: 33px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  background: linear-gradient(91deg, rgba(255, 255, 255, 0.36) 0%, rgba(216, 47, 47, 0.36) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.self-service__content {
  min-width: 0;
}

.self-section-heading h2 {
  margin: 0;
  font-size: 30px;
  line-height: 46px;
  font-weight: 500;
  color: #111;
}

.self-section-heading p {
  margin: -8px 0 0;
  font-size: 16px;
  line-height: 46px;
  color: #111;
  text-transform: uppercase;
}

.self-section-heading span {
  display: block;
  width: 67px;
  height: 3px;
  margin-top: 8px;
  background: #d82f2f;
}

.self-service__content > p {
  margin: 25px 0 0;
  color: #666;
  font-size: 16px;
  line-height: 26px;
  text-align: justify;
}

.self-service__content > p + p {
  margin-top: 15px;
}

.self-tag-list {
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 34px;
}

.self-service--operation .self-tag-list {
  gap: 12px 64px;
}

.self-tag-list li {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  color: #111;
  font-size: 20px;
  line-height: 46px;
  white-space: nowrap;
}

.self-tag-list li::before {
  content: "";
  width: 9px;
  height: 9px;
  flex: 0 0 auto;
  background: #d82f2f;
}

.self-contact {
  width: 135px;
  height: 45px;
  border-radius: 23px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 16px;
  transition: transform var(--transition), box-shadow var(--transition);
}

.self-contact:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 18px rgba(216, 47, 47, 0.18);
}

.self-contact img {
  width: 15px;
  height: 9px;
}

.self-contact--outline {
  margin-top: 48px;
  border: 1px solid #d82f2f;
  color: #d82f2f;
}

.self-contact--light {
  margin-top: 45px;
  border: 1px solid #fff;
  color: #fff;
}

.self-contact--solid {
  margin-top: 52px;
  background: #d82f2f;
  color: #fff;
}

.self-mcn {
  position: relative;
  min-height: 685px;
  overflow: hidden;
  color: #fff;
  background: url(../assets/images/marketing/hero-bg@2x.png) center / cover no-repeat;
}

.self-mcn__inner {
  position: relative;
  z-index: 1;
  min-height: 685px;
}

.self-section-heading--dark h2,
.self-section-heading--dark p,
.self-service__content--dark .self-tag-list li,
.self-service__content--dark > p {
  color: #fff;
}

.self-service__content--dark {
  padding-top: 118px;
  max-width: 43%;
}

.self-tag-list.self-tag-list--dark {
  gap: 15px 64px;
}
.self-tag-list--dark {
  margin-top: 7px;
}

.self-tag-list--dark li {
  color: #fff;
}

.self-mcn-visual {
  position: relative;
  min-height: 520px;
  margin: 0;
}

.self-mcn-visual__screen {
  position: absolute;
  left: 70px;
  top: 60px;
  width: 601px;
  height: 371px;
  object-fit: contain;
  filter: drop-shadow(0 24px 38px rgba(89, 4, 179, 0.38));
}

.self-mcn-visual__float {
  position: absolute;
  z-index: 2;
  height: auto;
  border-radius: 50%;
  filter: drop-shadow(0 10px 22px rgba(0, 0, 0, 0.38));
}

.self-mcn-visual__float--1 {
  width: 96px;
  left: 78px;
  top: 90px;
}

.self-mcn-visual__float--2 {
  width: 77px;
  left: 248px;
  top: 0;
}

.self-mcn-visual__float--3 {
  width: 89px;
  left: 165px;
  bottom: 32px;
}

.self-mcn-visual__float--4 {
  width: 89px;
  right: 28px;
  top: 302px;
}

.self-mcn-visual__float--5 {
  width: 64px;
  left: 0;
  top: 292px;
}

.self-matrix {
  padding: 119px 0 126px;
  background: #fff;
}

.self-service--matrix {
  grid-template-columns: minmax(0, 552px) minmax(0, 500px);
  gap: 152px;
  justify-content: center;
}

.self-matrix-visual {
  position: relative;
  width: 552px;
  height: 427px;
  margin: 0;
}

.self-service__content--matrix {
  align-self: center;
}

.self-tag-list--single {
  padding-left: 0;
}
