html { font-size: 62.5%; }
:root { --black: #000000; --white: #ffffff; --red: #ed1c24; --grey: rgba(255, 255, 255, 0.06); }
@font-face { font-family: inter; src: url("../../assets/fonts/Inter/Inter-VariableFont_opsz\,wght.ttf"); }
@font-face { font-family: apercu; src: url("../../assets/fonts/Apercu/Apercu"); font-weight: 400; }
@font-face { font-family: futurak; src: url("../../assets/fonts/futurak/futurak.ttf"); }
body { font-family: inter; }

.about-intro, .about-subtitle, .about-content, .express-card, .village-grid { opacity: 0; transform: translateY(40px); transition: opacity 0.8s ease-out, transform 0.8s ease-out; }
.about-intro.animate, .about-subtitle.animate, .about-content.animate, .express-card.animate, .village-grid.animate { opacity: 1; transform: translateY(0); }
.express-card { transition-delay: calc(var(--card-index, 0) * 0.1s); }
.express-card:nth-child(1) { --card-index: 0; }
.express-card:nth-child(2) { --card-index: 1; }
.express-card:nth-child(3) { --card-index: 2; }
.express-card:nth-child(4) { --card-index: 3; }
.express-card:nth-child(5) { --card-index: 4; }
.express-card:nth-child(6) { --card-index: 5; }
.express-card:nth-child(7) { --card-index: 6; }
.express-card:nth-child(8) { --card-index: 7; }
.express-card:nth-child(9) { --card-index: 8; }

/* Header */
.header { padding: 8px 0px; height: 92px; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.header .container { height: 100%; position: relative; }
.mobile-menu-toggle { display: none; background: transparent; border: none; color: var(--white); font-size: 2.4rem; cursor: pointer; padding: 8px; z-index: 1000; }
.main-logo { width: 165px; }
.nav { gap: 0px; }
.nav-link { font-size: 1.6rem; padding: 17px 36px 0px 0px; font-weight: 400; }
.franchise-btn { border: 1px solid var(--white); background-color: transparent; color: var(--white); padding: 12px 16.5px; border-radius: 35px; font-size: 1.4rem; cursor: pointer; margin: 0px 12px 0px 0px; font-weight: 500; height: 50px; display: inline-block; text-decoration: none; line-height: 26px; }
.order-btn { border: 1px solid var(--red); background-color: var(--red); color: var(--white); padding: 12px 13.5px; border-radius: 35px; font-size: 1.4rem; cursor: pointer; font-weight: 500; height: 50px; display: flex; align-items: center; }
.arrow-icon { background-color: var(--white); color: var(--red); padding: 6px 7px; border-radius: 23px; margin-left: 7px; display: inline-flex; align-items: center; justify-content: center; width: 27px; height: 27px; }

/* About Section */
.about-section { padding: 70px 0; }
.about-intro { text-align: center; margin-bottom: 70px; }
.about-title { font-size: 4rem; font-family: apercu; font-weight: 400; margin-bottom: 24px; line-height: 4.6rem; }
.about-text { font-size: 1.6rem; font-family: apercu; color: rgba(255, 255, 255, 0.7); line-height: 2.1rem; letter-spacing: 0.03em; margin-bottom: 15px; }
.about-subtitle { font-size: 3.2rem; font-family: apercu; font-weight: 400; margin: 70px 0 24px; line-height: 3.8rem; text-align: center; }
.about-content { margin-bottom: 70px; gap: 40px; }
.about-content-text { flex: 1; min-width: 300px; }
.about-content-img { flex: 1; min-width: 300px; }
.about-content-img img { width: 100%; border-radius: 4px; }
.about-heading { font-size: 3.2rem; font-family: apercu; font-weight: 400; margin-bottom: 24px; line-height: 3.8rem; }
.brand-name { font-family: futurak; font-size: 3.2rem; line-height: 2.9rem; }
.express-location { font-size: 1.2rem; font-family: apercu; color: var(--red); text-transform: uppercase; letter-spacing: 0.48em; display: block; margin-bottom: 8px; font-weight: 500; line-height: 1.5rem; margin-top: 24px; }
.express-name { font-size: 2.4rem; font-family: apercu; font-weight: 400; margin-bottom: 18px; line-height: 2.9rem; }
.express-name .brand-name { font-size: 2.4rem; line-height: 2.9rem; }
.express-address, .express-phone { font-size: 1.4rem; font-family: apercu; color: rgba(255, 255, 255, 0.7); margin-bottom: 12px; letter-spacing: 0.03em; line-height: 1.7rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; text-overflow: ellipsis; word-wrap: break-word; overflow: hidden; min-height: 36px; }
.express-address i, .express-phone i { margin-right: 8px; }
.express-phone a { color: rgba(255, 255, 255, 0.7); text-decoration: none; }
.express-grid { max-width: 1140px; margin: 0 auto; padding: 0 15px; row-gap: 32px; column-gap: 30px; }
.express-card { flex: 0 0 calc(33.333% - 20px); max-width: 350px; text-align: center; margin-bottom: 0px; display: flex; flex-direction: column; align-items: center; }
.express-img { width: 100%; height: 250px; object-fit: cover; border-radius: 4px; display: block; }
.direction-btn { background-color: transparent; border: 1px solid rgba(255, 255, 255, 0.3); color: var(--white); padding: 0px; border-radius: 50px; font-size: 1.4rem; cursor: pointer; margin-top: 20px; width: 174px; height: 50px; line-height: 21px; font-weight: 500; }
.direction-btn .arrow-icon { background-color: var(--white); color: var(--red); width: 27px; height: 27px; padding: 0px; border-radius: 30px; margin-left: 10px; }
.direction-btn .arrow-icon i { transform: rotate(-37deg); }
.express-section { padding: 70px 0px 38px; text-align: center; position: relative; overflow: hidden; background: transparent; }
.express-title { font-size: 4.8rem; font-family: apercu; font-weight: 400; margin-bottom: 30px; line-height: 6rem; padding: 0 15px; }
.village-section { padding: 48px 0px; background: rgba(255, 255, 255, 0.06); overflow: hidden; }
.village-title { font-size: 4.8rem; font-family: apercu; font-weight: 400; margin-bottom: 32px; line-height: 6rem; padding: 0 15px; }
.village-grid { gap: 0px; align-items: center; padding: 0 15px; }
.village-img { flex: 1; min-width: 300px; }
.village-img img { width: 100%; border-radius: 4px; }
.village-text { flex: 1; min-width: 300px; padding-left: 40px; }
.village-location { font-size: 1.6rem; font-family: apercu; color: var(--red); text-transform: uppercase; letter-spacing: 0.48em; display: block; margin-bottom: 8px; font-weight: 500; line-height: 2rem; }
.village-name { font-size: 3.2rem; font-family: apercu; font-weight: 400; margin-bottom: 24px; line-height: 3.8rem; }
.village-name .brand-name { font-size: 3.2rem; line-height: 2.9rem; }
.village-address, .village-phone { font-size: 1.6rem; font-family: apercu; color: rgba(255, 255, 255, 0.7); margin-bottom: 10px; letter-spacing: 0.03em; line-height: 1.9rem; }
.village-phone a { color: rgba(255, 255, 255, 0.7); text-decoration: none; }

/* Footer */
.footer { background: rgba(255, 255, 255, 0.06); padding: 70px 15px 0px; position: relative; }
.footer-snp-layer { position: absolute; bottom: 0px; left: 30px; z-index: 0; }
.footer-snp-layer img { width: 200px; }
.footer-content { display: grid; grid-template-columns: 1.5fr 0.8fr 1fr 0.8fr; gap: 30px 45px; padding-bottom: 55px; position: relative; z-index: 1; }
.footer-col { display: flex; flex-direction: column; }
.footer-logo { width: 140px; padding-bottom: 24px; }
.footer-text { font-size: 1.5rem; font-family: apercu; color: rgba(255, 255, 255, 0.7); line-height: 2.1rem; letter-spacing: 0.03em; padding-bottom: 16px; margin: 0; }
.social-links { margin-bottom: 24px; gap: 8px; }
.social-link { font-size: 1.7rem; color: var(--white); background-color: var(--red); width: 40px; height: 40px; border-radius: 50px; text-decoration: none; }
.footer-heading { font-size: 1.6rem; font-family: apercu; font-weight: 700; padding-bottom: 24px; line-height: 1.9rem; margin: 0; }
.footer-link { font-size: 1.5rem; font-family: apercu; color: rgba(255, 255, 255, 0.7); text-decoration: none; display: block; padding-bottom: 16px; letter-spacing: 0.03em; line-height: 2rem; }
.footer-link:hover { color: rgba(255, 255, 255, 0.6); }
.footer-info { font-size: 1.6rem; font-family: apercu; color: var(--white); padding-bottom: 16px; letter-spacing: 0.03em; line-height: 1.9rem; margin: 0; font-weight: 700; }
.app-links { gap: 10px; }
.app-links a { display: block; }
.app-links img { width: 100%; max-width: 150px; }

@media (max-width: 992px) {
  .mobile-menu-toggle { display: block; }
  .header { height: auto; padding: 15px 0; }
  .header .container { flex-wrap: wrap; padding: 0 20px; }
  .main-logo { width: 140px; }
  .nav { position: fixed; top: 0; right: -100%; width: 280px; height: 100vh; background: var(--black); flex-direction: column; gap: 0px; align-items: flex-start; padding: 80px 20px 20px; transition: right 0.3s ease; z-index: 999; overflow-y: auto; box-shadow: -2px 0 10px rgba(0, 0, 0, 0.5); }
  .nav.active { right: 0; }
  .nav-link { padding: 15px 0; font-size: 1.8rem; width: 100%; border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
  .franchise-btn, .order-btn { width: 100%; max-width: 100%; margin: 10px 0; justify-content: center; height: 55px; font-size: 1.6rem; }
  .about-section { padding: 30px 20px; }
  .about-intro { margin-bottom: 30px; padding: 0; }
  .about-title { font-size: 3rem; line-height: 3.6rem; margin-bottom: 20px; }
  .about-text { font-size: 1.5rem; line-height: 2rem; margin-bottom: 12px; }
  .about-subtitle { font-size: 2.6rem; line-height: 3.2rem; margin: 35px 0 18px; padding: 0; }
  .about-heading { font-size: 2.4rem; line-height: 3rem; margin-bottom: 16px; }
  .brand-name { font-size: 2.6rem; }
  .about-content { flex-direction: column; margin-bottom: 35px; gap: 16px; padding: 0; }
  .about-content-text { order: 2; }
  .about-content-img { order: 1; }
  .express-section { padding: 30px 20px; }
  .express-grid { row-gap: 0px; padding: 0; }
  .express-card { flex: 0 0 100%; max-width: 100%; margin-bottom: 28px; padding: 0; }
  .express-img { height: 200px; }
  .express-location { font-size: 1.1rem; margin-top: 16px; }
  .express-name { font-size: 2.2rem; margin-bottom: 14px; }
  .express-name .brand-name { font-size: 2.2rem; }
  .express-address, .express-phone { font-size: 1.3rem; line-height: 1.6rem; min-height: 32px; }
  .direction-btn { width: 160px; height: 46px; font-size: 1.3rem; margin-top: 16px; }
  .village-section { padding: 30px 20px; }
  .village-title { font-size: 2.8rem; line-height: 3.4rem; margin-bottom: 24px; padding: 0; }
  .village-grid { flex-direction: column; gap: 16px; padding: 0; }
  .village-text { padding: 0; }
  .village-img { padding: 0; }
  .village-location { font-size: 1.4rem; }
  .village-name { font-size: 2.6rem; line-height: 3.2rem; margin-bottom: 18px; }
  .village-name .brand-name { font-size: 2.6rem; }
  .village-address, .village-phone { font-size: 1.5rem; line-height: 1.8rem; }
  .footer { padding: 40px 20px 0; }
  .footer-content { grid-template-columns: 1fr; gap: 25px; padding-bottom: 25px; }
  .footer-col { text-align: left; align-items: flex-start; }
  .footer-logo { width: 120px; padding-bottom: 16px; }
  .footer-text { font-size: 1.4rem; line-height: 1.9rem; padding-bottom: 12px; }
  .footer-heading { font-size: 1.5rem; padding-bottom: 16px; }
  .footer-link { font-size: 1.4rem; padding-bottom: 12px; }
  .footer-info { font-size: 1.5rem; padding-bottom: 12px; }
  .social-links { margin-bottom: 16px; }
  .social-link { width: 36px; height: 36px; font-size: 1.5rem; }
  .app-links img { max-width: 130px; }
  .footer-snp-layer { display: none; }
}
