/* Here, 1rem = 1em = 16px */

/**************************/
/* Below 1345px (Smaller desktops) */
/**************************/
@media (max-width: 84em) {
  .section-hero {
    padding: 1.92rem 0 5.76rem 0;
  }

  .hero {
    max-width: 100%;
  }
  .heading-primary {
    font-size: 1.98rem;
    margin-bottom: 1.44rem;
  }

  .hero-cta-text {
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1.3;
    margin-bottom: 2.88rem;
  }

  .hero-cta-input {
    font-size: 0.84rem;
  }

  .grid-identity {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
    column-gap: 4.8rem;
    row-gap: 4.8rem;
  }

  .identity-1 {
    justify-self: end;
  }

  .identity-2 {
    justify-self: start;
  }

  .identity-3 {
    justify-self: center;
    grid-column: 1/3;
  }
}

/**************************/
/* Below 1200px (Smaller desktops) */
/**************************/

@media (max-width: 75em) {
  html {
    /* 9px / 16px = 56.25% */
    font-size: 56.25%;
  }

  .grid {
    column-gap: 2.88rem;
    row-gap: 3.84rem;
  }

  .heading-secondary {
    font-size: 2.16rem;
  }

  .main-nav-list {
    gap: 1.92rem;
  }

  .identity-description h2 {
    font-size: 2.16rem;
  }

  .heading-tertiary {
    font-size: 1.92rem;
  }

  .identity-item-heading {
    font-size: 1.8rem;
  }

  .identity-item-text {
    font-size: 1.44rem;
  }
}

/**************************/
/* Below 980px (Tablets) */
/**************************/
@media (max-width: 61.25em) {
  html {
    /* 8px/16px = 50% */
    font-size: 50%;
  }

  .hero {
    grid-template-columns: 1fr;
    padding: 1.92rem 1.92rem;
    gap: 5.76rem;
  }

  .hero::before {
    top: -2%;
    left: 0%;
    width: 100%;
    height: 50%;
    border-radius: 0 0 15px 15px;
  }

  .heading-primary {
    font-size: 2.88rem;
  }

  .hero-description {
    text-align: center;
  }

  .hero-img {
    width: 95%;
  }

  .hero-cta {
    width: 70%;
  }

  .hero-cta-text {
    font-size: 2.16rem;
    width: 100%;
  }

  .hero-cta-input {
    font-size: 1.2rem;
  }

  .identity-item {
    padding: 1.44rem;
    width: 21.6rem;
    height: 21.6rem;
  }

  .cta {
    grid-template-columns: 2fr 1fr;
  }

  .step-number {
    font-size: 4.44rem;
  }

  .section-hero {
    padding: 1.92rem 0 2.88rem 0;
  }

  .section-identity {
    padding-bottom: 4.8rem;
  }

  .section-how,
  .section-cta,
  .footer {
    padding: 3.84rem 0;
  }

  .cta-text-box {
    padding: 2.88rem 2.88rem 2.88rem;
    color: #541311;
  }
}

/**************************/
/* Below 832px (Mobile) */
/**************************/
@media (max-width: 52em) {
  .hero::before {
    top: -2%;
    height: 46%;
  }

  .btn-mobile-nav {
    display: block;
    z-index: 9999;
  }

  .main-nav {
    background-color: rgba(255, 228, 196, 0.9);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: 1;
    transform: translateX(100%);

    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.5s ease-in;

    /* Hide navigation */
    /* 1). Hide nav visually */
    opacity: 0;

    /* 2). Make it unaccessible to mouse and keyboard */
    pointer-events: none;

    /* 3) Hide it from screen readers */
    visibility: hidden;
  }

  .nav-open .main-nav {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transform: translateX(0);
  }

  .nav-open .icon-mobile-nav[name="close-outline"] {
    display: block;
  }

  .nav-open .icon-mobile-nav[name="menu-outline"] {
    display: none;
  }

  .main-nav-list {
    flex-direction: column;
    gap: 3.84rem;
  }

  .main-nav-link:link,
  .main-nav-link:visited {
    font-size: 1.68rem;
    font-weight: 500;
    color: #333;
  }

  .identity-item-heading {
    font-size: 2.16rem;
    line-height: 1.1;
  }
}

/**************************/
/* Below 704px (Mobile Middle) */
/**************************/
@media (max-width: 44em) {
  html {
    /* 7px/16px = 43.75 */
    font-size: 43.75%;
  }

  .hero::before {
    top: -1.8%;
    height: 45%;
  }

  .hero-img {
    width: 100%;
  }

  .grid {
    row-gap: 3.84rem;
  }

  .heading-secondary {
    margin-bottom: 2.16rem;
  }

  .grid-identity {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(3, 1fr);
  }

  .identity-item {
    grid-template-rows: 1fr 1fr;
    row-gap: 0;
  }

  .identity-1 {
    justify-self: center;
  }

  .identity-2 {
    justify-self: center;
  }

  .identity-3 {
    justify-self: center;
    grid-column: 1 / -1;
  }

  .step-icon-box::before {
    width: 50%;
    padding-bottom: 50%;
  }

  .step-icon-box::after {
    width: 40%;
    padding-bottom: 40%;
  }

  .step-icon {
    height: 10.8rem;
  }

  .step-icon-1 {
    order: 2;
  }
  .step-text-1 {
    order: 1;
  }

  .step-icon-2 {
    order: 4;
  }
  .step-text-2 {
    order: 3;
  }

  .step-icon-3 {
    order: 6;
  }
  .step-text-3 {
    order: 5;
  }

  .cta {
    grid-template-columns: 3fr 2fr;
  }

  .cta-form .btn--form {
    margin-top: 1.44rem;
  }

  .section-hero {
    padding: 1.44rem 0 1.92rem 0;
  }

  .section-identity {
    padding-bottom: 3.84rem;
  }

  .identity-description {
    margin: 2.88rem auto;
  }

  .grid-identity {
    row-gap: 3.84rem;
  }

  .section-how,
  .section-cta,
  .footer {
    padding: 2.88rem 0;
  }

  .cta {
    grid-template-columns: 1fr;
  }

  .cta-form {
    grid-template-columns: 1fr;
    width: 100%;
    margin: 0 auto;
  }

  .cta-text {
    line-height: 1.6;
  }

  .cta-text-box {
    padding: 3.84rem 3.84rem 3.84rem;
  }

  .cta-input {
    padding: 0.96rem;
  }

  .btn--form {
    padding: 0.72rem;
    font-size: 1.44rem;
  }

  .cta-img-box {
    height: 19.2rem;
    grid-row: 1;
    background-position-y: 70%;
  }
}

/**************************/
/* Below 544px (Phone) */
/**************************/
@media (max-width: 34em) {
  .logo {
    height: 1.8rem;
  }

  .icon-mobile-nav {
    height: 1.8rem;
  }

  .sticky .header {
    height: 2.4rem;
  }

  .sticky .logo {
    height: 1.8rem;
  }

  .identity-item {
    padding: 0.96rem;
    width: 19.2rem;
    height: 19.2rem;
  }

  .identity-item-heading {
    font-size: 2.16rem;
  }

  .identity-item-text {
    font-size: 1.44rem;
  }

  .heading-tertiary {
    font-size: 1.8rem;
    margin-bottom: 1.44rem;
  }

  .section-hero {
    padding: 0.96rem 0 1.44rem 0;
  }

  .hero {
    padding: 0.72rem;
    gap: 2.88rem;
  }

  .hero::before {
    top: -1.3%;
    height: 40%;
  }

  .hero-description {
    padding: 0 1.44rem;
  }

  .hero-cta {
    width: 100%;
    padding: 0 1.92rem;
  }

  .hero-cta-form section {
    width: 90%;
    margin: 0 auto;
  }

  .hero-cta-text,
  .identity-description {
    line-height: 1.2;
    margin-bottom: 1.92rem;
  }

  .grid--2-cols {
    grid-template-columns: 1fr;
    row-gap: 1.92rem;
  }

  .section-how,
  .section-cta,
  .footer {
    padding: 1.92rem 0;
  }

  .subheading {
    font-size: 0.96rem;
    margin-bottom: 0.24rem;
  }

  .step-icon-1 {
    /* grid-row: 1/2; */
    order: 2;
  }
  .step-text-1 {
    /* grid-row: 2/3; */
    order: 1;
  }

  .step-icon-2 {
    order: 4;
  }
  .step-text-2 {
    order: 3;
  }

  .step-icon-3 {
    /* grid-row: 5/6; */
    order: 6;
  }
  .step-text-3 {
    /* grid-row: 6/7; */
    order: 5;
  }

  .margin-bottom-md {
    margin-bottom: 1.8rem;
  }

  .step-icon-box {
    /* transform: translateY(3rem); */
  }

  .step-icon-box::before {
    width: 30%;
    padding-bottom: 30%;
  }

  .step-icon-box::after {
    width: 24%;
    padding-bottom: 24%;
  }

  .step-icon {
    height: 7.2rem;
  }

  .cta-text-box {
    padding: 1.92rem 1.44rem 1.44rem;
  }

  .cta-text {
    margin-bottom: 1.44rem;
  }

  .cta-img-box {
    height: 14.4rem;
    grid-row: 1;
    background-position-y: 70%;
  }
}

/**************************/
/* Below 384px (Phone small) */
/**************************/

@media (max-width: 24em) {
  .heading-secondary {
    margin-bottom: 1.44rem;
  }

  .hero-description {
    padding: 0.96rem;
  }

  .hero-cta {
    width: 100%;
  }

  .step-icon-box::before {
    width: 35%;
    padding-bottom: 35%;
  }

  .step-icon-box::after {
    width: 28%;
    padding-bottom: 28%;
  }

  .step-icon {
    width: 6rem;
  }

  .grid--footer {
    column-gap: 1.2rem;
  }
  .step-icon-1 {
    order: 2;
  }
  .step-text-1 {
    order: 1;
  }

  .step-icon-2 {
    order: 4;
  }
  .step-text-2 {
    order: 3;
  }

  .step-icon-3 {
    order: 6;
  }
  .step-text-3 {
    order: 5;
  }
}

/* Fixing Safari gap */

/*
- Font Size(px)
10 / 12 / 14 / 16 / 18 / 20 / 24 / 30 / 36 / 44 / 52 / 62 / 74 / 86 / 98

- Spacing System (px)
2 / 4 / 8 / 12 / 16 / 24 / 32 / 48 / 64 / 80 / 96 / 128
*/

/**************************/
/* HEADER */
/**************************/
.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;

  padding: 0.6rem 2.88rem 0.24rem 2.88rem;
}

.logo {
  height: 3.6rem;
}

/**************************/
/* NAVIGATION */
/**************************/

.main-nav-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 2.88rem;
}

.main-nav-link:link,
.main-nav-link:visited {
  display: inline-block;
  text-decoration: none;
  color: #555;
  font-weight: 400;
  font-size: 1.08rem;
  transition: all 0.3s;
}

.main-nav-link:hover,
.main-nav-link:active {
  color: #e19e05;
}

.main-nav-link.nav-cta:link,
.main-nav-link.nav-cta:visited {
  padding: 0.72rem 1.44rem;
  border-radius: 9px;
  color: #fff;
  background-color: #e4827f;
}

.main-nav-link.nav-cta:hover,
.main-nav-link.nav-cta:active {
  background-color: #e19e05;
}

/* MOBILE */
.btn-mobile-nav {
  border: none;
  background: none;
  cursor: pointer;

  display: none;
}

.icon-mobile-nav {
  height: 2.88rem;
  width: 2.88rem;
  color: #333;
}

.icon-mobile-nav[name="close-outline"] {
  display: none;
}

/* STICKY NAVIGATION */
.sticky .header {
  position: fixed;
  background-color: rgba(255, 255, 255, 0.93);
  top: 0;
  width: 100%;
  height: 4.2rem;
  padding-top: 0;
  padding-bottom: 0;
  z-index: 999;
  box-shadow: 0 0.72rem 1.92rem rgba(0, 0, 0, 0.07);
}

.sticky .section-hero {
  margin-top: 4.41rem;
}

/**************************/
/* HERO SECTION */
/**************************/
.section-hero {
  padding: 2.88rem 0 5.76rem 0;
}

.hero {
  max-width: 100%;
  /* max-width: 78rem; */
  margin: 0 auto;
  position: relative;

  display: grid;
  grid-template-columns: 1.5fr 1fr;
  align-items: center;
  justify-items: center;
}

.hero-description {
  padding: 0 2.88rem;
  color: #fff;
}

/* Set the background-color on the hero section */
.hero::before {
  position: absolute;
  content: "";
  /* top: -30%; */
  left: -40%;
  top: -5.7%;
  background-color: #d22f2a;
  width: 100%;
  height: 100%;
  z-index: -1;
  border-radius: 30px;
}

.hero-p {
  font-size: 1.44rem;
  line-height: 1.3;
  letter-spacing: 1px;
  margin-bottom: 1.2rem;
}

.hero-img {
  width: 100%;
  border-radius: 15px;
  box-shadow: 0 1.44rem 2.88rem rgba(0, 0, 0, 0.15);
  overflow: hidden;
}

.hero-cta {
  padding: 0 3.84rem;
}

.hero-cta-text {
  color: #d7443f;
  font-size: 2.16rem;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 3.84rem;
  text-align: center;
  width: 95%;
}

.hero-cta-form {
  display: flex;
  flex-direction: column;
  gap: 1.92rem;
}

.hero-cta-form label {
  display: block;
  font-size: 0.96rem;
  font-style: italic;
  font-weight: 500;
  /* margin-bottom: 0.48rem; */
}

.hero-cta-input {
  width: 100%;
  padding: 0.72rem;
  font-size: 1.08rem;
  border: solid 1px;
  border-radius: 15px;
  /* background-color: #fdf2e9; */
  font-family: inherit;
}

.hero-cta-input::placeholder {
  color: #aaa;
}

.hero-submittion {
  margin-top: 1.92rem;
  text-align: center;
  font-size: 1.44rem;
}

.hero-btn--form {
  align-self: center;
  padding: 1.44rem;
}

/**************************/
/* Identity SECTION */
/**************************/

.section-identity {
  padding-bottom: 5.76rem;
}

.identity-content {
  max-width: 100%;
  padding: 0.96rem;
  align-items: center;
  justify-items: center;
}

.grid-identity {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 1.68rem;
}

.identity-1 {
  justify-self: end;
}

.identity-3 {
  justify-self: start;
}

.identity-description {
  margin: 0 auto 3.84rem;
  text-align: center;
}

.identity-description h2 {
  font-size: 2.64rem;
}

.identity-item {
  display: grid;
  grid-template-rows: 1fr 1.5fr;
  align-items: center;
  justify-items: center;
  row-gap: 1.44rem;

  background-color: #d7443f;
  color: #fff;
  border-radius: 30px;
  padding: 1.92rem;
  text-align: center;

  width: 21.6rem;
  height: 21.6rem;
  box-shadow: 0 1.44rem 2.88rem rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: all 0.4s;
}

.identity-item:hover {
  transform: translateY(-0.84rem);
  box-shadow: 0 1.92rem 3.84rem rgba(0, 0, 0, 0.15);
}

.identity-item-text {
  font-weight: 400;
  font-style: italic;
  line-height: 1.2;
  font-size: 1.44rem;
}

/**************************/
/* HOW IT WORKS SECTION */
/**************************/

.section-how {
  padding: 4.8rem 0;
  /* background-color: #f6d5d4; */
}

.step-number {
  font-size: 5.16rem;
  font-weight: 600;
  color: #e6e6e6;
  margin-bottom: 0 !important;
}

.step-description {
  font-size: 1.2rem;
  line-height: 1.6;
}

.style-italic {
  font-style: italic;
  font-weight: 700;
}

.step-icon-box {
  position: relative;

  display: flex;
  justify-content: center;
  align-items: center;
  color: #666;
}

.step-icon-box::before,
.step-icon-box::after {
  content: "";
  display: block;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.step-icon-box::before {
  width: 55%;
  padding-bottom: 55%;
  background-color: #fbeaea;
  z-index: -2;
}

.step-icon-box::after {
  width: 45%;
  padding-bottom: 45%;
  background-color: #f6d5d4;
  z-index: -1;
}

.step-img {
  width: 50%;
}

.step-icon {
  width: 100%;
  height: 12rem;
}

/**************************/
/* CTA SECTION */
/**************************/

.section-cta {
  padding: 5.76rem 0;
}

.cta {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  background-color: #f6d5d4;
  box-shadow: 0 1.44rem 2.88rem rgba(0, 0, 0, 0.15);
  border-radius: 11px;

  background-image: linear-gradient(to right bottom, #e4827f, #db5955);
  overflow: hidden;
}

.cta-text {
  font-size: 1.2rem;
  line-height: 1.8;
  margin-bottom: 2.88rem;
}

.cta-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 1.92rem;
  row-gap: 1.44rem;
}

.cta-form label {
  display: block;
  font-size: 0.96rem;
  font-style: italic;
  font-weight: 500;
  /* margin-bottom: 0.48rem; */
}

.cta-text-box {
  padding: 2.88rem 3.84rem 3.84rem;
  color: #541311;
}

.cta .heading-secondary {
  color: #541311;
}

.cta-img-box {
  background-image: linear-gradient(to right bottom, hsla(2, 65%, 70%, 0.171), rgba(219, 89, 85, 0.101)), url(../image/img02.jpg);
  background-size: cover;
  background-position: bottom;
}

.cta-input {
  width: 100%;
  padding: 0.72rem;
  font-size: 1.08rem;
  border-radius: 15px;
  font-family: inherit;
  border: none;
  background-color: #fdf2e9;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.cta-input::placeholder {
  color: #aaa;
}

.cta *:focus {
  outline: none;
  box-shadow: 0 0 0 0.48rem rgba(170, 170, 170, 0.5);
}

/**************************/
/* FOOTER SECTION */
/**************************/

.footer {
  padding: 5.76rem 1.44rem;
  border-top: 1px solid #eee;
}

.grid--footer {
  /* grid-template-columns: 2fr 2fr 1fr; */
  grid-template-columns: repeat(2, 1fr);
}

.logo-col {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.92rem;
}

.footer-logo {
  display: block;
  /* margin-bottom: 1.44rem; */
}

/* For Social icon */
/* .social-links {
  list-style: none;
  display: flex;
  gap: 1.44rem;
}

.social-icon {
  height: 1.44rem;
  width: 1.44rem;
} */

.copyright {
  font-size: 0.84rem;
  line-height: 1.2;
  color: #767676;
  /* margin-top: auto; */
}

.footer-heading {
  font-size: 1.08rem;
  font-weight: 500;
  justify-self: center;
  padding: 1.44rem 0;
}

.contacts {
  font-style: normal;
  font-size: 0.96rem;
  line-height: 1.2;
}

.address-col {
  display: flex;
  flex-direction: column;
  gap: 1.44rem;
}

.address {
  margin-bottom: 1.44rem;
}

.nav-col {
  display: flex;
  flex-direction: column;
  gap: 1.44rem;
}

.footer-nav {
  list-style: none;
  display: grid;
  flex-direction: column;
  gap: 1.44rem;
}

.footer-link:link,
.footer-link:visited {
  text-decoration: none;
  font-size: 0.96rem;
  color: #767676;
  word-break: break-all;
  transition: all 0.3s;
}

.footer-link:hover,
.footer-link:active {
  color: #333;
}

/* Header Logo 20250527*/
img.lazy {
  min-height: 1px;
}

/* 
--- 01 TYPOGRAPHY SYSTEM 

- Font Size(px)
10 / 12 / 14 / 16 / 18 / 20 / 24 / 30 / 36 / 44 / 52 / 62 / 74 / 86 / 98

- Font weights
Default: 400
Mediam: 500
Semi-bold: 600
Bold: 700

- Line heights
Default: 1
Small: 1.05
Medium: 1.2
Paragraph default: 1.6
Large: 1.8

- Letter apacing
0.5px
0.75px

--- 02 COLOR

- Primary: #d22f2a
- Secondary: #d7443f
- Tints: #f6d5d4 #e4827f #db5955
- Shades: #541311
- Accents:
- Button: #fab005
- Greys:
#4c4b4c (Lightest grey allowed on #fff)
#767676
#6f6f6f (Lightest grey allowed on #fdf2e9 )
#555
#333

--- 05 SHADOWS
0 1.44rem 2.88rem rgba(0, 0, 0, 0.075);

--- 06 BORDER-RADIUS
Default: 9px
Medium: 11px

--- 07 WHITESPACE
- Spacing System (px)
2 / 4 / 8 / 12 / 16 / 24 / 32 / 48 / 64 / 80 / 96 / 128

*/

/**************************/
/* GENERAL REUSABLE COMPONENTS */
/**************************/

* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

html {
  /* 10px / 16px = 0.625 = 62.5% */
  /* 1rem = 10px */
  /* Percentage of user's browser font-size setting */
  font-size: 62.5%;
  overflow-x: hidden;
}

body {
  font-family: "Rubik", "Inter", sans-serif;
  line-height: 1;
  font-weight: 400;
  color: #555;
  overflow-x: hidden;
}

h2 {
  font-size: 2.52rem;
}

h3 {
  font-size: 2.16rem;
}

*:focus {
  outline: none;
  box-shadow: 0 0 0 0.48rem rgba(250, 176, 5, 0.501);
}

.margin-bottom-md {
  margin-bottom: 5.76rem;
}

.margin-bottom-sm {
  margin-bottom: 1.92rem;
}

.margin-bottom-sm-cta {
  margin-bottom: 0.72rem;
}

.heading-primary,
.heading-secondary,
.heading-tertiary {
  font-weight: 700;
  letter-spacing: -0.5px;
}

.heading-primary {
  color: #fff;
  font-size: 3.12rem;
  line-height: 1.1;
  margin-bottom: 1.92rem;
}

.heading-secondary {
  font-size: 2.64rem;
  line-height: 1.2;
  color: #2a0908;
}

.heading-tertiary {
  font-size: 1.8rem;
  line-height: 1.2;
  margin-bottom: 1.92rem;
}

.subheading {
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
  color: #a82622;
  text-transform: uppercase;
  margin-bottom: 0.96rem;
  letter-spacing: 0.75px;
}

/***********/
.btn,
.btn:link,
.btn:visited {
  display: inline-block;

  text-decoration: none;
  font-family: inherit;
  font-size: 1.2rem;
  font-weight: 600;
  /* padding: 0.96rem 1.92rem; */
  border-radius: 15px;
  border: none;
  background-color: #fab005;
  color: #fff;

  cursor: pointer;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
  transition: all 0.3s;
}

.btn:hover,
.btn:active {
  background-color: #e19e05;
  cursor: pointer;
}

.btn--form {
  color: #fdf2e9;
  align-self: end;
  padding: 0.72rem;
}

.btn--form:hover {
  background-color: #fdf2e9;
  color: #555;
}

.container {
  max-width: 72rem;
  padding: 0 2.88rem;
  margin: 0 auto;
}

.grid {
  display: grid;
  column-gap: 3.84rem;
  row-gap: 7.68rem;
}

.grid:not(:last-child) {
  margin-bottom: 5.76rem;
}

.grid--2-cols {
  grid-template-columns: repeat(2, 1fr);
}

.grid--3-cols {
  grid-template-columns: repeat(3, 1fr);
}

.grid--4-cols {
  grid-template-columns: repeat(4, 1fr);
}

.gird--center-v {
  align-items: center;
}

/* お知らせ欄のスタイル */
.announcement {
  background-color: #ffdd57; /* 明るい黄色 */
  padding: 10px 0; /* 上下のパディング */
  font-size: 1.2rem;
  line-height: 1.6;
}

.announcement p {
  margin: 0; /* マージンの初期化 */
  color: #333; /* テキストの色 */
  font-weight: bold; /* テキストを太字に */
}

.announcement a {
  color: #d43f00; /* リンクの色 */
  text-decoration: underline; /* アンダーラインの装飾 */
}

.about .message .pic-scenery {
  position: relative;
  width: 600px;
  height: 570px;
  z-index: 0;
}

.about .message .discription {
  position: relative;
  width: 50%;
  margin: -400px 0 0 480px;
  z-index: 1;
  padding: 40px 24px;
  background-color: #d22f2a;
}
.about .aboutus table {
  display: block;
  width: 100%;
  padding-left: 24px;
  font-family: "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.about .message .borderless {
  position: absolute;
  top: 70px;
  right: 80px;
  z-index: 2;
}

.about .aboutus table tbody tr th {
  width: 144px;
  text-align: left;
  vertical-align: top;
}

body.about td,
body.about th {
  background: none;
  border: none;
}
.about .aboutus table tbody tr td {
  width: 792px;
}

@media (max-width: 768px) {
  .container {
    padding: 0 1rem;
  }
  .grid {
    row-gap: 2rem;
  }
  .heading-secondary {
    font-size: 1.5rem;
    margin-bottom: 2rem;
  }
  .grid--2-cols {
    grid-template-columns: 100%;
  }
  .step-number {
    font-size: 3rem;
  }
  .step-icon {
    height: 6rem;
  }
  .heading-tertiary {
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
  }
}
