/* ========================================
   HAKOB LP
   assets/css/hakob.css
======================================== */

/* ----------------------------------------
   Theme reset for this page only
---------------------------------------- */
body.tax-service_cat.term-hakob,
body.tax-service_cat.term-hakob .site,
body.tax-service_cat.term-hakob #page {
  background: #F8F5F2;
}

/* 既存テーマのヘッダーが重なる場合に使用
   実サイトのクラスに合わせて必要なら追加調整 */
body.tax-service_cat.term-hakob #masthead,
body.tax-service_cat.term-hakob .site-header {
  display: none;
}

body.tax-service_cat.term-hakob .site-content,
body.tax-service_cat.term-hakob #primary,
body.tax-service_cat.term-hakob #content {
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: none;
}

html.is-hakob-drawer-open,
body.is-hakob-drawer-open {
  overflow: hidden;
}

/* ----------------------------------------
   Base
---------------------------------------- */
.hakob-lp {
  --bg-main: #c56f4e;
  --bg-main-dark: #b95f3f;
  --bg-dark: #111111;
  --bg-beige: #f1e9e4;
  --bg-soft: #f7f3f0;
  --bg-soft-2: #f7eeea;
  --bg-soft-3: #efefec;
  --text-main: #1f1f1f;
  --text-sub: #5f5a57;
  --white: #ffffff;
  --navy: #1A3A5C;
  --line-light: rgba(255, 255, 255, 0.28);
  --line-dark: rgba(0, 0, 0, 0.08);
  --shadow-soft: 0 16px 40px rgba(0, 0, 0, 0.12);
  --shadow-card: 0 12px 30px rgba(0, 0, 0, 0.08);
  --container: 1200px;
  --mix: 0;
  color: var(--text-main);
  overflow: clip;
  position: relative;
}

.hakob-font01 {
  font-family: fot-tsukuaoldmin-pr6n, sans-serif;
}

.hakob-font02 {
  font-family: ryo-gothic-plusn, sans-serif;
}

.hakob-font03 {
  font-family: "Inter", sans-serif;
}


.hakob-lp *,
.hakob-lp *::before,
.hakob-lp *::after {
  box-sizing: border-box;
}

.hakob-lp img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

.hakob-lp a {
  color: inherit;
  text-decoration: none;
}

.hakob-lp button,
.hakob-lp input,
.hakob-lp textarea,
.hakob-lp select {
  font: inherit;
}

.hakob-lp picture {
  display: block;
}

.hakob-container {
  width: min(calc(100% - 0px), var(--container));
  margin-inline: auto;
}

.hakob-section {
  position: relative;
  padding: 120px 0;
}

.hakob-only-pc {
  display: block!important;
}
.hakob-only-pc.line-text {
    display: inline-block !important;
}
.hakob-only-sp {
  display: none!important;
}

.hakob-en {
  display: inline-block;
  margin-bottom: 14px;
  color: #b55c3c;
  color: #ffffff;
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 0.04em;
  /* text-transform: uppercase; */
}

.hakob-sec-head {
  margin-bottom: 56px;
  text-align: center;
}

.hakob-sec-head h2 {
  margin: 0;
  font-size: 42px;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.hakob-sec-head p {
  max-width: 760px;
  margin: 18px auto 0;
  font-size: 16px;
  line-height: 2;
  color: var(--text-sub);
}

.hakob-btn {
  min-width: 160px;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 15px;
  border: 1px solid transparent;
  font-size: 14px;
  line-height: 1;
  transition:
    opacity 0.35s ease,
    transform 0.35s ease,
    background-color 0.35s ease,
    color 0.35s ease,
    border-color 0.35s ease;
  cursor: pointer;
  font-weight: 500;
}

.hakob-btn:hover {
  opacity: 0.82;
}

.hakob-btn--navy {
  background: var(--navy);
  color: #fff!important;
}

.hakob-btn--navy:hover {
  background: #ffffff;
  color: #1A3A5C!important;
  opacity: 1;
}
.hakob-btn.hakob-btn--outline:hover {
    background: #1A3A5C;
    color: #ffffff !important;
  opacity: 1;
}
.hakob-btn--line {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.8);
}

.hakob-btn--line:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.hakob-btn--light {
  background: #fff;
  color: #222;
  border-color: rgba(0, 0, 0, 0.12);
}

.hakob-btn--light:hover {
  background: #f6f6f6;
}

.hakob-btn--dark {
  background: #222;
  color: #fff;
}

/* ----------------------------------------
   Scroll reveal
---------------------------------------- */
.js-reveal {
  opacity: 0;
  transform: translateY(42px);
  transition:
    opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform, opacity;
}

.js-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.hakob-contact-intro__container {
    max-width: 1040px;
}
/* ----------------------------------------
   Floating header
---------------------------------------- */
.hakob-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 1000;
  background: #F8F5F2;
  backdrop-filter: blur(10px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.05);
  transform: translateY(-110%);
  transition: transform 0.45s ease;
}

.hakob-header.is-visible {
  transform: translateY(0);
}
#header.deformation {
  display: none;
}
#header.is-visible {
  display: none;
}
.hakob-header__inner {
  width: min(calc(100% - 48px), 1240px);
  min-height: 86px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 40px;
}

.hakob-header__logo {
  flex: 0 0 auto;
  width: 132px;
}

.hakob-header__logo img {
  display: block;
  width: 100%;
}

.hakob-header__nav {
  margin-left: auto;
}

.hakob-header__nav ul {
  display: flex;
  align-items: center;
  gap: 48px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.hakob-header__nav li {
  margin: 0;
  padding: 0;
}

.hakob-header__nav a {
  position: relative;
  display: inline-block;
  padding: 0;
  font-size: 15px;
  line-height: 1.4;
  transition: opacity 0.3s ease;
  color: #222222!important;
  font-weight: 500;
  letter-spacing: 0.02em;
  overflow: hidden;
  transition: transform 1.2s cubic-bezier(0.14, 1, 0.34, 1);
}

.hakob-header__nav a::after {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 100%;
  height: 5rem;
  background: #B8522E;
  transform: translateX(-50%) scaleX(0);
  transform-origin: center center;
  transition: transform 0.35s ease;
}

.hakob-header__nav a:hover::after,
.hakob-header__nav a.is-active::after {
  transform: translateX(-50%) scaleX(1);
}

.hakob-header__cta {
  flex: 0 0 auto;
}

.hakob-header__spBtn {
  display: none;
}

/* ----------------------------------------
   SP drawer
---------------------------------------- */
.hakob-drawer {
  display: none;
}

/* ----------------------------------------
   Hero
---------------------------------------- */
.hakob-hero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  color: #ffffff;
  padding-top: 105px;
  background: #F8F5F2;
}

.hakob-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background: #F8F5F2;
}

.hakob-hero__posterEnd {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}

.hakob-hero__posterEnd img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.hakob-hero__video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: opacity 0.8s ease;
  padding-top: 105px;
}

.hakob-hero__bg.is-video-ended .hakob-hero__video {
  opacity: 0;
  pointer-events: none;
}

.hakob-hero__inner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 80px), 1240px);
  min-height: calc(100svh - 105px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}

.hakob-hero__main {
  width: 100%;
  text-align: center;
  transform: translateY(8px);
}

.hakob-hero__heading h2 {
  margin: 0;
  font-size: 62px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #ffffff;
}

.hakob-hero__heading p {
  margin: 34px auto 0;
  font-size: 17px;
  line-height: 2.1;
  font-weight: 700;
  color: #ffffff;
}

.hakob-hero__cta {
  margin-top: 0;
  margin-bottom: 80px;
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}

.hakob-hero__cta .hakob-btn {
  min-width: 175px;
  min-height: 40px;
  padding: 0 20px;
  font-size: 15px;
  letter-spacing: 0.02em;
}

.hakob-btn--navy {
  background: #1A3A5C;
  color: #ffffff;
  border: 1px solid #1A3A5C;
}

.hakob-btn--line {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.8);
}

.hakob-hero__scroll {
  position: absolute;
  left: 50%;
  bottom: 35px;
  transform: translateX(-50%);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 12px;
  line-height: 1.4;
  letter-spacing: 0.04em;
  color: #ffffff!important;
}

.hakob-hero__scroll.js-heroItem.is-show {
  transform: translateX(-50%) translateY(25px);
}

.hakob-hero__scroll::before,
.hakob-hero__scroll::after {
  width: 11px;
  height: 1px;
  background: currentColor;
}

.js-heroItem {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.9s cubic-bezier(.22,1,.36,1),
    transform 0.9s cubic-bezier(.22,1,.36,1);
}

.js-heroItem.is-show {
  opacity: 1;
  transform: translateY(0);
}

/* ----------------------------------------
   Worries
---------------------------------------- */
.hakob-worries {
  position: relative;
  padding: 0;
  background: linear-gradient(90deg, #6D6E70 0%, #272425 100%);
  color: #ffffff;
  overflow-y: visible;
  transition: opacity 0.3s ease, background-color 0.5s cubic-bezier(.4, .6, .23, 1);
  --worries-tone: 0;
}

.hakob-worries::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #F8F5F2;
  opacity: var(--worries-tone);
  z-index: 0;
  pointer-events: none;
}

.hakob-worries__sticky,
.hakob-worries__cards {
  position: relative;
  z-index: 1;
}

.hakob-worries__title,
.hakob-worries__title h2,
.hakob-worries__title .hakob-en {
  transition: none;
}

.hakob-worries__title {
  color: rgba(
    calc(255 - (255 - 34) * var(--worries-tone)),
    calc(255 - (255 - 27) * var(--worries-tone)),
    calc(255 - (255 - 25) * var(--worries-tone)),
    1
  );
}

.hakob-worries__title .hakob-en {
  color: rgba(
    calc(255 - (255 - 34) * var(--worries-tone)),
    calc(255 - (255 - 27) * var(--worries-tone)),
    calc(255 - (255 - 25) * var(--worries-tone)),
    calc(1.0 + 0.3 * var(--worries-tone))
  );
}
.hakob-worries__title {
  text-align: center;
  transition: color 0.4s ease;
}

.hakob-worries__title .hakob-en {
  transition: color 0.4s ease;
}

.hakob-lp.is-worries-after .hakob-worries {
  background: #f1e9e4;
  color: #221b19;
}

.hakob-lp.is-worries-after .hakob-worries .hakob-en,
.hakob-lp.is-worries-after .hakob-worries .hakob-worries__title,
.hakob-lp.is-worries-after .hakob-worries .hakob-worries__title h2 {
}


.hakob-worries__scroll {
  position: relative;
  z-index: 1;
  padding: 0 0 0;
}

.hakob-worries__sticky {
  position: sticky;
  top: 0;
  height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  pointer-events: none;
}

.hakob-worries__title {
  text-align: center;
  transition: color 0.4s ease;
}

.hakob-worries__title .hakob-en {
  margin-bottom: 20px;
  font-weight: 500;
}

.hakob-worries__title h2 {
  margin: 0;
  font-size: 25px;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.02em;
  font-feature-settings: "palt" 0;
}

.hakob-worries[data-tone="light"] .hakob-worries__title,
.hakob-worries[data-tone="light"] .hakob-worries__title .hakob-en {
  color: #221b19;
}

.hakob-worries__cards {
  position: relative;
  z-index: 3;
  width: 1000px;
  margin: 0vh auto 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.hakob-worries__bubble {
  width: 470px;
}

.hakob-worries__bubble:nth-child(odd) {
  margin-right: auto;
}

.hakob-worries__bubble:nth-child(even) {
  margin-left: auto;
}

.hakob-worries__bubbleBox {
  position: relative;
  background: #ffffff;
  box-shadow: 25px 30px 15px #0000004D;
}

.hakob-worries__bubbleBox::after {
  content: "";
  position: absolute;
  bottom: -22px;
  width: 30px;
  height: 30px;
  /* background: #ffffff; */
  transform: rotate(180deg);
  border-left: 22px solid #fff;
  border-top: 22px solid transparent;
  border-bottom: 22px solid transparent;
}

.hakob-worries__bubble:nth-child(odd) .hakob-worries__bubbleBox::after {
  left: 208px;
}

.hakob-worries__bubble:nth-child(even) .hakob-worries__bubbleBox::after {
  left: 220px;
  transform: rotate(0deg);
}

.hakob-worries__bubbleInner {
  padding: 60px;
}

.hakob-worries__meta {
  margin-bottom: 19px;
  text-align: center;
  font-size: 15px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #707070;
  font-weight: 500;
}

.hakob-worries__bubbleTitle {
  margin: 0;
  text-align: center;
  font-size: 22px;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.01em;
}

.hakob-worries__bubbleText {
  margin: 20px 0 0;
  text-align: center;
  font-size: 15px;
  line-height: 1.8;
  color: #222222;
  font-weight: 400;
}

.hakob-worries__illust {
  margin: 0 auto;
  margin-top: 30px;
  width: 300px;
}

.hakob-worries__illust img {
  display: block;
  width: 100%;
  height: auto;
}

/* 個別位置調整 */
.hakob-worries__bubble--1 {
  transform: translateX(0);
}

.hakob-worries__bubble--2 {
  transform: translateX(0) translateY(-120px);
}

.hakob-worries__bubble--3 {
  transform: translateX(0) translateY(-90px);
}

.hakob-worries__bubble--4 {
  transform: translateX(0) translateY(-210px);
}

.hakob-worries__bubble--5 {
  transform: translateX(0) translateY(-180px);
}

.hakob-worries__bubble--6 {
  transform: translateX(0) translateY(-300px);
}


.hakob-problems {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.hakob-problems__item {
  padding: 60px;
  background: #fff;
}

.hakob-problems__item img {
  display: block;
  width: 100%;
}

/* ----------------------------------------
   Value
---------------------------------------- */
.hakob-value {
  background: #fff;
}

.hakob-value__grid {
}

.hakob-value__item {
  background: #fff;
}

.hakob-value__item img {
  display: block;
  width: 100%;
}

/* ----------------------------------------
   Can do / scene
---------------------------------------- */


/* ----------------------------------------
   Experience
---------------------------------------- */
.hakob-experience {
  background: #fff;
}

.hakob-exp-block {
  padding-top: 40px;
}

.hakob-exp-block + .hakob-exp-block {
  margin-top: 68px;
}

.hakob-exp-block__head {
  margin-bottom: 35px;
  text-align: center;
}

.hakob-exp-block__num {
  display: inline-block;
  margin-bottom: 18px;
  padding: 8px 18px;
  background: #bf6d4d;
  color: #fff;
  font-size: 14px;
  line-height: 1.4;
  letter-spacing: 0.12em;
}

.hakob-exp-block__head h3 {
  margin: 0;
  font-size: 34px;
  line-height: 1.5;
  font-weight: 500;
}

.hakob-exp-block__head p {
}

.hakob-exp-browser {
}

.hakob-exp-browser__window {}

.hakob-exp-browser__bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
}

.hakob-exp-browser__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #e0d5d0;
}

.hakob-exp-browser__screen img {
  display: block;
  width: 100%;
}

.hakob-exp5 {
  position: relative;
}

.hakob-exp5__tabs {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-bottom: 20px;
}

.hakob-exp5__tab {
  min-width: 120px;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #fff;
  color: #444;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease,
    opacity 0.3s ease;
  cursor: pointer;
}

.hakob-exp5__tab:hover {
  opacity: 0.82;
}

.hakob-exp5__tab.is-active {
  background: #B8522E;
  color: #fff;
  border-color: #B8522E;
}

.hakob-exp5__panels {
  position: relative;
}

.hakob-exp5__panel {
  display: none;
}

.hakob-exp5__panel.is-active {
  display: block;
}

/* ----------------------------------------
   Plan
---------------------------------------- */


/* ----------------------------------------
   Works
---------------------------------------- */
.hakob-works {
  /* display: none; */
}

/* ----------------------------------------
   Contact intro
---------------------------------------- */

/* ----------------------------------------
   Contact / HubSpot
---------------------------------------- */

#hakobHubspotForm .hs-form-field {
  margin-bottom: 22px;
}

#hakobHubspotForm label {
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
  line-height: 1.7;
}

#hakobHubspotForm .hs-input,
#hakobHubspotForm select,
#hakobHubspotForm textarea {
  width: 100%;
  min-height: 54px;
  padding: 12px 14px;
  border: 1px solid #d8d2cd;
  background: #fff;
  box-shadow: none;
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
}

#hakobHubspotForm textarea {
  min-height: 180px;
  resize: vertical;
}

#hakobHubspotForm .inputs-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

#hakobHubspotForm .inputs-list li {
  margin-bottom: 10px;
}

#hakobHubspotForm .hs-richtext,
#hakobHubspotForm .legal-consent-container,
#hakobHubspotForm .hs_recaptcha {
  font-size: 13px;
  line-height: 1.9;
  color: var(--text-sub);
}

#hakobHubspotForm .hs-button,
#hakobHubspotForm input[type="submit"] {
  min-width: 220px;
  min-height: 56px;
  padding: 12px 32px !important;
  border: 0 !important;
  background: #222 !important;
  color: #fff !important;
  border-radius: 0 !important;
  transition: opacity 0.3s ease;
}

#hakobHubspotForm .hs-button:hover,
#hakobHubspotForm input[type="submit"]:hover {
  opacity: 0.82;
}

#hakobHubspotForm .hs_submit {
  margin-top: 30px;
  text-align: center;
}

#hakobHubspotForm .hs-error-msgs {
  list-style: none;
  margin: 0;
  padding: 6px 0 0;
  font-size: 13px;
  color: #c0392b;
}

#hakobHubspotForm .submitted-message {
  text-align: center;
  font-size: 15px;
  line-height: 2;
}

.hakob-worries__after {
  padding-top: 80px;
  padding-bottom: 70px;
}

.hakob-problems__head {
  margin-bottom: 60px;
}

.hakob-problems__head .hakob-en {
  color: #707070;
  margin-bottom: 20px;
}

.hakob-problems__head h2 {
  font-size: 25px;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-problems {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.hakob-problems__item {
  background: #B8522E;
  color: #ffffff;
}

.hakob-problems__inner {
  position: relative;
  text-align: center;
}

.hakob-problems__label {
  margin-bottom: 18px;
  font-size: 15px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-weight: 500;
}

.hakob-problems__title {
  margin: 0;
  font-size: 22px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.hakob-problems__text {
  margin: 20px 0 0;
  font-size: 15px;
  line-height: 1.7;
  font-weight: 400;
}

.hakob-problems__illust {
  margin-top: 30px;
}

.hakob-problems__illust img {
  display: block;
  width: 100%;
  height: auto;
}

/* 真ん中カードの矢印風装飾を入れたい場合の余地 */
.hakob-problems__item.is-separate .hakob-problems__inner {
  overflow: hidden;
}



/* ----------------------------------------
   Bottom gap
---------------------------------------- */
.hakob-bottom-gap {
  height: 0;
}
#breadClumnb {
  display: none;
}

/* ----------------------------------------
   Reduced motion
---------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .js-reveal,
  .hakob-header,
  .hakob-header__nav a::after,
  .hakob-drawer__nav a::after,
  .hakob-btn,
  .hakob-worries__bubble,
  .hakob-exp5__tab,
  .hakob-header__spBtn span,
  .hakob-header__spBtn::before,
  .hakob-header__spBtn::after {
    transition: none !important;
  }
}


.hakob-why {
  background: #F8F5F2;
  padding-top: 80px;
  padding-bottom: 70px;
  overflow: hidden;
}

.hakob-why__head {
  text-align: center;
}

.hakob-why__eyebrow {
  margin: 0;
  font-size: 18px;
  line-height: 1.4;
  font-weight: 700;
  color: #707070;
}

.hakob-why__title {
  margin: 0;
  font-size: 34px;
  line-height: 2;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: #222222;
}

.hakob-why__divider {
  width: 1px;
  height: 80px;
  margin: 10px auto 30px;
  background: #707070;
}

.hakob-why__logo {
  width: 350px;
  margin: 0 auto;
}

.hakob-why__logo img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-why__body {
  margin-top: 150px;
  display: block;
  position: relative;
}

.hakob-why__visual {
  margin: 0;
}

.hakob-why__visual img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-why__desc {
  position: relative;
  padding-top: 0;
  position: absolute;
  width: 450px;
  right: 0;
  top: 80px;
}

.hakob-why__descLine {
  position: absolute;
  top: 18px;
  left: -150px;
  width: 130px;
  height: 1px;
  background: #d6a48f;
}

.hakob-why__descLine::before {
  content: "";
  position: absolute;
  left: -6px;
  top: 50%;
  width: 8px;
  height: 8px;
  border: 1px solid #d6a48f;
  border-radius: 50%;
  transform: translateY(-50%);
  background: #f1eeeb;
}

.hakob-why__descLine::after {
  content: "";
  position: absolute;
  right: 12px;
  top: 0;
  width: 1px;
  height: 88px;
  background: #d6a48f;
}

.hakob-why__descTexts {
  position: relative;
}

.hakob-why__descTexts::after {
}

.hakob-why__desc p {
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  font-weight: 400;
  color: #222222;
}

.hakob-why__desc p + p {
  margin-top: 28px;
}

.hakob-value {
  background: #F8F5F2;
  padding-top: 80px;
  padding-bottom: 130px;
}

.hakob-value__head {
  margin-bottom: 60px;
}

.hakob-value__head .hakob-en {
  color: #707070;
  font-weight: 500;
  margin-bottom: 20px;
}

.hakob-value__head h2 {
  font-size: 25px;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-value__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.hakob-value__item {
  background: #ffffff;
}

.hakob-value__inner {
  padding: 60px 40px;
}

.hakob-value__num {
  margin-bottom: 20px;
  text-align: center;
  font-size: 15px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-weight: 500;
  color: #B8522E;
}

.hakob-value__image {
  width: 100%;
}

.hakob-value__image img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-value__title {
  margin: 30px 0 0;
  text-align: center;
  font-size: 20px;
  line-height: 1.55;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: #222222;
}

.hakob-value__text {
  margin: 20px 20px 0;
  font-size: 15px;
  line-height: 2;
  font-weight: 400;
  color: #222222;
}

.hakob-experience {
  background: #FFFFFF;
  padding-top: 100px;
  padding-bottom: 130px;
}

.hakob-experience__intro {
  text-align: center;
}

.hakob-experience__catch {
  margin: 0;
  font-size: 45px;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: -0.02em;
}
.hakob-experience__catch span {
  color: #B8522E;
  font-size: 90px;
  line-height: 0.5;
  position: relative;
  top: 30px;
  margin: 0 15px;
}
.hakob-experience__intro h2 {
  margin: 16px 0 0;
  font-size: 16px;
  line-height: 1.6;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.02em;
}

.hakob-experience__anchors {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  background: #F6F6F6;
  padding: 30px;
}

.hakob-experience__anchor {
  padding: 15px;
  background: #FFFFFF;
  text-align: center;
  border-radius: 5px;
}
.hakob-experience__anchor:hover {
  opacity: 0.7;
}
.hakob-experience__anchor:last-child {
  border-right: 0;
}

.hakob-experience__anchorLabel {
  display: block;
  font-size: 16px;
  line-height: 1.4;
  color: #B8522E;
  font-weight: 500;
}
.hakob-experience__anchorLabel span {
  font-size: 20px;
}
.hakob-experience__anchorTitle {
  display: block;
  margin-top: 15px;
  margin-bottom: 25px;
  font-size: 16px;
  line-height: 1.6;
  color: #222222;
  font-weight: 500;
  position: relative;
}
.hakob-experience__anchorTitle:after {
    content: "";
    position: absolute;
    bottom: -23px;
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 10px solid #DEDEDE;
    left: 50%;
    transform: translateX(-50%);
}
.hakob-exp-block {
  margin-top: 40px;
}

.hakob-exp-block__head {
  text-align: center;
}

.hakob-exp-block__label {
  display: inline-block;
  padding: 10px 15px;
  background: #B8522E;
  color: #ffffff;
  font-size: 16px;
  line-height: 1.4;
  font-weight: 400;
  position: relative;
}
.hakob-exp-block__label:after {
    content: "";
    position: absolute;
    bottom: -10px;
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 10px solid #B8522E;
    left: 50%;
    transform: translateX(-50%);
}
.hakob-exp-block__label span span {
  font-size: 20px;
}
.hakob-exp-block__head h3 {
  margin: 25px 0 0;
  font-size: 28px;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.02em;
}

.hakob-exp-block__body {
  margin: 35px auto 0;
  max-width: unset;
  font-size: 15px;
  line-height: 1.8;
  color: #222222;
}

.hakob-exp-browser__screen img,
.hakob-exp-browser__screen video {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-exp-block__summary {
  margin: 35px auto 0;
  max-width: 915px;
  display: grid;
  grid-template-columns: 1fr 354px;
  gap: 15px;
  border: 1px solid #B8522E;
  border-radius: 10px;
  padding: 30px;
  align-items: center;
}

.hakob-exp-block__points {
  list-style: none;
  margin: 0;
  padding: 0;
}

.hakob-exp-block__points li {
  position: relative;
  padding-left: 37px;
  font-size: 15px;
  line-height: 1.8;
  color: #222222;
  font-weight: 500;
}

.hakob-exp-block__points li + li {
  margin-top: 10px;
}

.hakob-exp-block__points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  background: url('../img/hakob/text_mark02.png') no-repeat;
  width: 27px;
  height: 24px;
  background-size: contain;
}

.hakob-exp-block__note {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 16px 28px;
  background: #393533;
  color: #ffffff;
  text-align: center;
  font-size: 15px;
  line-height: 1.8;
  font-weight: 500;
  border-radius: 5px;
  height: min-content;
}
.hakob-exp-block__note span {
  font-size: 17px;
}
.hakob-exp-block__visual {
  margin-top: 40px;
  background: #F8EDE9;
  padding: 40px 100px 40px;
  position: relative;
}

.hakob-exp-block__caption {
  margin: 0 0 15px;
  padding-left: 45px;
  font-size: 17px;
  line-height: 1.6;
  font-weight: 500;
  color: #B8522E;
  position: relative;
}
.hakob-exp-block__caption:before {
  content: "";
  position: absolute;
  left: 10px;
  top: 2px;
  background: url('../img/hakob/text_mark01.png') no-repeat;
  width: 24px;
  height: 24px;
  background-size: contain;
}
.hakob-exp-browser {
  background: transparent;
  padding: 0;
}

.hakob-exp-browser__window {
  padding: 0;
}

.hakob-exp-browser__bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid #ece7e3;
  background: #f8f7f6;
}

.hakob-exp-browser__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d5ccc7;
}

.hakob-exp-browser__screen img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-exp5__tabs {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin: 0 0 16px;
  position: absolute;
  right: 118px;
  top: 40px;
}

.hakob-exp5__tab {
  min-width: 134px;
  min-height: 39px;
  padding: 10px 20px;
  border: 1px solid #DEDEDE;
  background: #ffffff;
  color: #ACACAC;
  font-size: 15px!important;
  border-radius: 5px;
}

.hakob-exp5__tab.is-active {
  background: #B8522E;
  border-color: #B8522E;
  color: #ffffff;
}

.hakob-exp5__panel {
  display: none;
}

.hakob-exp5__panel.is-active {
  display: block;
}

.hakob-scene {
  background: #BE6140;
  padding-top: 110px;
  padding-bottom: 120px;
}

.hakob-scene__head {
  margin-bottom: 48px;
}

.hakob-scene__head .hakob-en {
  color: #ffffff;
  font-weight: 500;
  margin-bottom: 20px;
}

.hakob-scene__head h2 {
  font-size: 24px;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #ffffff;
}

.hakob-scene__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 46px 30px;
}

.hakob-scene__item {
  color: #ffffff;
}

.hakob-scene__thumb {
  margin: 0;
}

.hakob-scene__thumb img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-scene__body {
  padding-top: 16px;
  text-align: center;
}

.hakob-scene__body h3 {
  margin: 0;
  font-size: 21px;
  line-height: 1.6;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #ffffff;
}

.hakob-scene__body p {
  margin: 10px 0 0;
  font-size: 14px;
  line-height: 1.8;
  font-weight: 400;
  color: #ffffff;
}

.hakob-works {
  background: #f1eeeb;
  padding-top: 110px;
  padding-bottom: 120px;
}

.hakob-works__head {
  margin-bottom: 48px;
}

.hakob-works__head .hakob-en {
  color: #707070;
}

.hakob-works__head h2 {
  font-size: 24px;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #222222;
}

.hakob-works__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.hakob-works__item {
  color: #222222;
}

.hakob-works__thumb {
  margin: 0;
  background: #ffffff;
}

.hakob-works__thumb img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-works__body {
  padding-top: 12px;
}

.hakob-works__body h3 {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  font-weight: 500;
  color: #222222;
}

.hakob-works__body p {
  margin: 8px 0 0;
  font-size: 13px;
  line-height: 1.8;
  color: #222222;
}

.hakob-plan {
  background: #FFFFFF;
  padding-top: 130px;
  padding-bottom: 130px;
}

.hakob-plan__head {
  margin-bottom: 60px;
}

.hakob-plan__head .hakob-en {
  color: #707070;
  margin-bottom: 20px;
  font-weight: 500;
}

.hakob-plan__head h2 {
  font-size: 25px;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-plan__main {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  width: 930px;
  margin: 0 auto;
}

.hakob-plan__card {
  background: #F8EDE9;
}

.hakob-plan__cardInner {
  padding: 50px 45px 50px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: stretch;
}

.hakob-plan__name {
  margin: 0;
  font-size: 26px;
  line-height: 1.4;
  font-weight: 700;
  color: #222222;
}

.hakob-plan__sub {
  margin: 7px 0 0;
  font-size: 13px;
  line-height: 1.6;
  color: #B8522E;
  font-weight: 500;
}

.hakob-plan__priceRow {
  margin-top: 25px;
  display: flex;
  align-items: flex-end;
  gap: 3px;
}

.hakob-plan__price {
  font-size: 32px;
  line-height: 1.2;
  font-weight: 700;
  color: #222222;
}

.hakob-plan__unit {
  font-size: 15px;
  line-height: 1.4;
  color: #222222;
  padding-bottom: 6px;
  font-weight: 500;
}

.hakob-plan__desc {
  margin: 0;
  font-size: 13px;
  line-height: 1.7;
  color: #707070;
}

.hakob-plan__list {
  list-style: none;
  margin: 30px 0 0;
  padding: 0;
}

.hakob-plan__list li {
  position: relative;
  padding-left: 23px;
}

.hakob-plan__list li + li {
  margin-top: 17px;
}

.hakob-plan__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 5px;
  width: 16px;
  height: 16px;
  color: #222222;
  background: url('../img/hakob/plan_mark.png') no-repeat;
  background-size: contain;
}

.hakob-plan__itemTitle {
  font-size: 15px;
  line-height: 1.7;
  font-weight: 400;
  color: #222222;
}

.hakob-plan__itemText {
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.8;
  color: #707070;
}

.hakob-plan__note {
  margin: 25px 0 0;
  padding-top: 25px;
  border-top: 1px solid #DEDEDE;
  font-size: 13px;
  line-height: 1.7;
  color: #707070;
}

.hakob-plan__monthlyWrap {
  margin: 0 auto;
  margin-top: 40px;
  padding: 30px 40px;
  border: 1px solid #B8522E;
  background: transparent;
  width: 930px;
}

.hakob-plan__monthlyHead {
  margin: 0 0 18px;
  font-size: 16px;
  line-height: 1.6;
  font-weight: 500;
  color: #222222;
}

.hakob-plan__monthly {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 25px;
}

.hakob-plan__card--sub {
  border: 1px solid #DEDEDE;
  border-radius: 10px;
  background: #ffffff;
  height: auto;
}
.hakob-plan__card--sub .hakob-plan__cardInner {
  padding: 30px;
}
.hakob-plan__subName {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  font-weight: 500;
  color: #B8522E;
}

.hakob-plan__subPriceRow {
  margin-top: 10px;
  display: flex;
  align-items: flex-end;
  gap: 3px;
}

.hakob-plan__subPrice {
  font-size: 30px;
  line-height: 1.1;
  font-weight: 700;
  color: #222222;
}
.hakob-plan__subPrice span {
  font-size: 25px;
  font-weight: 700;
  font-family: ryo-gothic-plusn, sans-serif;
}
.hakob-plan__subUnit {
  font-size: 15px;
  line-height: 1.4;
  color: #222222;
  padding-bottom: 2px;
}

.hakob-plan__subDesc {
  margin: 7px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: #707070;
}

.hakob-plan__subList {
  list-style: none;
  margin: 20px 0 0;
  padding: 0;
}

.hakob-plan__subList li {
  position: relative;
  padding-left: 23px;
  font-size: 15px;
  line-height: 1.8;
  color: #222222;
}

.hakob-plan__subList li + li {
  margin-top: 8px;
}

.hakob-plan__subList li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 5px;
  width: 16px;
  height: 16px;
  color: #222222;
  background: url(../img/hakob/plan_mark.png) no-repeat;
  background-size: contain;
}

.hakob-contact-intro {
  background: #F8F5F2;
  padding-top: 110px;
  padding-bottom: 60px;
}

.hakob-contact-intro__container {
  max-width: 660rem;
}

.hakob-contact-intro__head {
  text-align: center;
  margin-bottom: 60px;
}

.hakob-contact-intro__head h2 {
  margin: 0;
  font-size: 45px;
  line-height: 1.7;
  font-weight: 500;
  color: #222222;
  letter-spacing: -0.02em;
}

.hakob-contact-intro__head p {
  margin: 18px 0 0;
  font-size: 16px;
  line-height: 2;
  color: #222222;
  letter-spacing: 0.02em;
  font-weight: 400;
}

.hakob-contact-intro__cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  max-width: 930px;
  margin: 0 auto;
}

.hakob-contact-intro__card {
  background: #ffffff;
  padding: 30px 40px 35px;
  text-align: center;
}

.hakob-contact-intro__icon {
  width: 55px;
  margin: 0 auto 20px;
  display: block;
}

.hakob-contact-intro__card h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.7;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.02em;
}

.hakob-contact-intro__card p {
  margin: 15px 0 30px;
  font-size: 13px;
  line-height: 1.8;
  color: #222222;
}

.hakob-contact-intro__card .hakob-btn {
  min-width: 365px;
  min-height: 60px;
  padding: 0 16px;
  font-size: 16px;
  letter-spacing: 0.04em;
}

.hakob-btn--outline {
  background: transparent;
  color: #1A3A5C!important;
  border: 1px solid #1A3A5C;
}

.hakob-contact {
  background: #F8F5F2;
  padding-top: 0;
  padding-bottom: 120px;
}

.hakob-contact__container {
  max-width: 930px;
}

.hakob-contact__box {
  background: #FFFFFF;
  padding: 60px;
}

.hakob-contact__head {
  text-align: center;
  margin-bottom: 60px;
}

.hakob-contact__head h2 {
  margin: 0;
  font-size: 18px;
  line-height: 1.7;
  font-weight: 500;
  color: #222222;
}

#hakobHubspotForm form {
  max-width: 100%;
}

#hakobHubspotForm .hs-form-field {
  display: flex;
  align-items: flex-start;
  gap: 28px;
  margin-bottom: 12px;
}

#hakobHubspotForm .hs-form-field > label {
  width: 104px;
  flex: 0 0 104px;
  margin: 0;
  padding-top: 10px;
  font-size: 12px;
  line-height: 1.6;
  color: #222222;
  font-weight: 500;
}

#hakobHubspotForm .input,
#hakobHubspotForm .hs-input,
#hakobHubspotForm .inputs-list,
#hakobHubspotForm .hs-fieldtype-text .input,
#hakobHubspotForm .hs-fieldtype-textarea .input {
  flex: 1 1 auto;
  width: 100%;
}

#hakobHubspotForm .hs-input,
#hakobHubspotForm input[type="text"],
#hakobHubspotForm input[type="email"],
#hakobHubspotForm input[type="tel"],
#hakobHubspotForm textarea,
#hakobHubspotForm select {
  width: 100%;
  min-height: 28px;
  padding: 6px 10px;
  border: 1px solid #D8D8D8;
  background: #ffffff;
  border-radius: 0;
  box-shadow: none;
  font-size: 13px;
  color: #222222;
}

#hakobHubspotForm textarea {
  min-height: 150px;
  resize: vertical;
}

#hakobHubspotForm .hs-error-msgs {
  margin: 6px 0 0;
  padding: 0;
  list-style: none;
  font-size: 12px;
  color: #c0392b;
}

#hakobHubspotForm .legal-consent-container,
#hakobHubspotForm .hs-richtext,
#hakobHubspotForm .hs_recaptcha {
  margin-top: 14px;
  font-size: 12px;
  line-height: 1.8;
  color: #222222;
}

#hakobHubspotForm .hs_submit {
  text-align: center;
  margin-top: 30px;
}

#hakobHubspotForm .hs-button,
#hakobHubspotForm input[type="submit"] {
  min-width: 146px;
  min-height: 38px;
  padding: 0 20px !important;
  border: 0 !important;
  background: #393533 !important;
  color: #ffffff !important;
  border-radius: 0 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

#hakobHubspotForm .submitted-message {
  text-align: center;
  font-size: 14px;
  line-height: 2;
  color: #222222;
}


.hakob-header__nav a::before {
    content: attr(data-text);
    position: absolute;
    left: 0;
    top: 100%;
    transform: translateY(0);
    transition: transform 1.2s cubic-bezier(0.14, 1, 0.34, 1);
    color: inherit;
}
.hakob-header__nav a span {
  transform: translateY(0);
  display: inline-block;
  transition: transform 1.2s cubic-bezier(0.14, 1, 0.34, 1);
}
.hakob-header__nav a:hover span {
  transform: translateY(-100%);
}
.hakob-header__nav a:hover::before {
    transform: translateY(-100%);
}


@media screen and (min-width: 835px) and (max-width: 1199px) {

.hakob-lp {
  --shadow-soft: 0 1.333vw 3.333vw rgba(0, 0, 0, 0.12);
  --shadow-card: 0 1vw 2.5vw rgba(0, 0, 0, 0.08);
  --container: 100vw;
  --mix: 0;
  color: var(--text-main);
  overflow: clip;
  position: relative;
}


.hakob-container {
  width: 100vw;
  margin-inline: auto;
}

.hakob-section {
  position: relative;
  padding: 10vw 0;
}

.hakob-only-pc {
  display: block!important;
}

.hakob-only-sp {
  display: none!important;
}

.hakob-en {
  display: inline-block;
  margin-bottom: 1.167vw;
  color: #b55c3c;
  color: #ffffff;
  font-size: 1.333vw;
  line-height: 1.4;
  letter-spacing: 0.04em;
  /* text-transform: uppercase; */
}

.hakob-sec-head {
  margin-bottom: 4.667vw;
  text-align: center;
}

.hakob-sec-head h2 {
  margin: 0;
  font-size: 3.5vw;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.03em;
}

.hakob-sec-head p {
  max-width: 63.333vw;
  margin: 1.5vw auto 0;
  font-size: 1.333vw;
  line-height: 2;
  color: var(--text-sub);
}

.hakob-btn {
  min-width: 13.333vw;
  min-height: 3.167vw;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.833vw;
  padding: 1vw 1.25vw;
  border: 1px solid transparent;
  font-size: 1.167vw;
  line-height: 1;
  transition:
    opacity 0.35s ease,
    transform 0.35s ease,
    background-color 0.35s ease,
    color 0.35s ease,
    border-color 0.35s ease;
  cursor: pointer;
  font-weight: 500;
}

.hakob-btn:hover {
  opacity: 0.82;
}

.hakob-btn--navy {
  background: var(--navy);
  color: #fff!important;
}

.hakob-btn--navy:hover {
  background: #ffffff;
  color: #1A3A5C!important;
  opacity: 1;
}
.hakob-btn.hakob-btn--outline:hover {
    background: #1A3A5C;
    color: #ffffff !important;
  opacity: 1;
}
.hakob-btn--line {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.8);
}

.hakob-btn--line:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.hakob-btn--light {
  background: #fff;
  color: #222;
  border-color: rgba(0, 0, 0, 0.12);
}

.hakob-btn--light:hover {
  background: #f6f6f6;
}

.hakob-btn--dark {
  background: #222;
  color: #fff;
}

/* ----------------------------------------
   Scroll reveal
---------------------------------------- */
.js-reveal {
  opacity: 0;
  transform: translateY(3.5vw);
  transition:
    opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform, opacity;
}

.js-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ----------------------------------------
   Floating header
---------------------------------------- */
.hakob-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 1000;
  background: #F8F5F2;
  backdrop-filter: blur(0.833vw);
  box-shadow: 0 0.5vw 1.667vw rgba(0, 0, 0, 0.05);
  transform: translateY(-110%);
  transition: transform 0.45s ease;
}

.hakob-header.is-visible {
  transform: translateY(0);
}
#header.deformation {
  display: none;
}
#header.is-visible {
  display: none;
}
.hakob-header__inner {
  width: min(calc(100% - 4vw), 103.333vw);
  min-height: 7.167vw;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 3.333vw;
}

.hakob-header__logo {
  flex: 0 0 auto;
  width: 11vw;
}

.hakob-header__logo img {
  display: block;
  width: 100%;
}

.hakob-header__nav {
  margin-left: auto;
}

.hakob-header__nav ul {
  display: flex;
  align-items: center;
  gap: 4vw;
  list-style: none;
  margin: 0;
  padding: 0;
}

.hakob-header__nav li {
  margin: 0;
  padding: 0;
}

.hakob-header__nav a {
  position: relative;
  display: inline-block;
  padding: 0;
  font-size: 1.25vw;
  line-height: 1.4;
  transition: opacity 0.3s ease;
  color: #222222!important;
  font-weight: 500;
  letter-spacing: 0.02em;
  overflow: hidden;
  transition: transform 1.2s cubic-bezier(0.14, 1, 0.34, 1);
}

.hakob-header__nav a::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -0.25vw;
  width: 100%;
  height: 0.083vw;
  background: currentColor;
  transform: translateX(-50%) scaleX(0);
  transform-origin: center center;
  transition: transform 0.35s ease;
}

.hakob-header__nav a:hover::after,
.hakob-header__nav a.is-active::after {
  transform: translateX(-50%) scaleX(1);
}

.hakob-header__cta {
  flex: 0 0 auto;
}

.hakob-header__spBtn {
  display: none;
}

/* ----------------------------------------
   SP drawer
---------------------------------------- */
.hakob-drawer {
  display: none;
}

/* ----------------------------------------
   Hero
---------------------------------------- */
.hakob-hero {
  position: relative;
  /* min-height: 67.5vw; */
  /* max-height: 67.5vw; */
  overflow: hidden;
  color: #ffffff;
}

.hakob-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hakob-hero__posterEnd {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}

.hakob-hero__posterEnd img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.hakob-hero__video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  /* max-height: 67.5vw; */
  display: block;
  object-fit: cover;
  transition: opacity 0.8s ease;
}

.hakob-hero__bg.is-video-ended .hakob-hero__video {
  opacity: 0;
  pointer-events: none;
}

.hakob-hero__inner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 0px), 103.333vw);
  /* min-height: 67.5vw; */
  /* max-height: 67.5vw; */
  min-height: calc(100svh - 105px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}

.hakob-hero__main {
  width: 100%;
  text-align: center;
  transform: translateY(0vw);
}

.hakob-hero__heading h2 {
  margin: 0;
  font-size: 5.167vw;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #ffffff;
}

.hakob-hero__heading p {
  margin: 2.833vw auto 0;
  font-size: 1.417vw;
  line-height: 2.1;
  font-weight: 700;
  color: #ffffff;
}

.hakob-hero__cta {
  margin-top: 0;
  margin-bottom: 6.667vw;
  display: flex;
  justify-content: center;
  gap: 1.667vw;
  flex-wrap: wrap;
}

.hakob-hero__cta .hakob-btn {
  min-width: 14.583vw;
  min-height: 3.333vw;
  padding: 0 1.667vw;
  font-size: 1.25vw;
  letter-spacing: 0.02em;
}

.hakob-btn--navy {
  background: #1A3A5C;
  color: #ffffff;
  border: 1px solid #1A3A5C;
}

.hakob-btn--line {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.8);
}

.hakob-hero__scroll {
  position: absolute;
  left: 50%;
  bottom: 2.917vw;
  transform: translateX(-50%);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 1.167vw;
  font-size: 1vw;
  line-height: 1.4;
  letter-spacing: 0.04em;
  color: #ffffff!important;
}

.hakob-hero__scroll.js-heroItem.is-show {
  transform: translateX(-50%) translateY(2.083vw);
}

.hakob-hero__scroll::before,
.hakob-hero__scroll::after {
  width: 0.917vw;
  height: 0.083vw;
  background: currentColor;
}

.js-heroItem {
  opacity: 0;
  transform: translateY(1.667vw);
  transition:
    opacity 0.9s cubic-bezier(.22,1,.36,1),
    transform 0.9s cubic-bezier(.22,1,.36,1);
}

.js-heroItem.is-show {
  opacity: 1;
  transform: translateY(0);
}

/* ----------------------------------------
   Worries
---------------------------------------- */
.hakob-worries {
  position: relative;
  padding: 0;
  background: linear-gradient(90deg, #6D6E70 0%, #272425 100%);
  color: #ffffff;
  overflow-y: visible;
  transition: opacity 0.3s ease, background-color 0.5s cubic-bezier(.4, .6, .23, 1);
  --worries-tone: 0;
}

.hakob-worries::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #F8F5F2;
  opacity: var(--worries-tone);
  z-index: 0;
  pointer-events: none;
}

.hakob-worries__sticky,
.hakob-worries__cards {
  position: relative;
  z-index: 1;
}

.hakob-worries__title,
.hakob-worries__title h2,
.hakob-worries__title .hakob-en {
  transition: none;
}

.hakob-worries__title {
  color: rgba(
    calc(255 - (255 - 34) * var(--worries-tone)),
    calc(255 - (255 - 27) * var(--worries-tone)),
    calc(255 - (255 - 25) * var(--worries-tone)),
    1
  );
}

.hakob-worries__title .hakob-en {
  color: rgba(
    calc(255 - (255 - 34) * var(--worries-tone)),
    calc(255 - (255 - 27) * var(--worries-tone)),
    calc(255 - (255 - 25) * var(--worries-tone)),
    calc(1.0 + 0.3 * var(--worries-tone))
  );
}
.hakob-worries__title {
  text-align: center;
  transition: color 0.4s ease;
}

.hakob-worries__title .hakob-en {
  transition: color 0.4s ease;
}

.hakob-lp.is-worries-after .hakob-worries {
  background: #f1e9e4;
  color: #221b19;
}

.hakob-lp.is-worries-after .hakob-worries .hakob-en,
.hakob-lp.is-worries-after .hakob-worries .hakob-worries__title,
.hakob-lp.is-worries-after .hakob-worries .hakob-worries__title h2 {
}


.hakob-worries__scroll {
  position: relative;
  z-index: 1;
  padding: 0 0 0;
}

.hakob-worries__sticky {
  position: sticky;
  top: 0;
  height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  pointer-events: none;
}

.hakob-worries__title {
  text-align: center;
  transition: color 0.4s ease;
}

.hakob-worries__title .hakob-en {
  margin-bottom: 1.667vw;
  font-weight: 500;
}

.hakob-worries__title h2 {
  margin: 0;
  font-size: 2.083vw;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.02em;
  font-feature-settings: "palt" 0;
}

.hakob-worries[data-tone="light"] .hakob-worries__title,
.hakob-worries[data-tone="light"] .hakob-worries__title .hakob-en {
  color: #221b19;
}

.hakob-worries__cards {
  position: relative;
  z-index: 3;
  width: 83.333vw;
  margin: 0vh auto 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.hakob-worries__bubble {
  width: 39.167vw;
}

.hakob-worries__bubble:nth-child(odd) {
  margin-right: auto;
}

.hakob-worries__bubble:nth-child(even) {
  margin-left: auto;
}

.hakob-worries__bubbleBox {
  position: relative;
  background: #ffffff;
  box-shadow: 2.083vw 2.5vw 1.25vw #0000004D;
}

.hakob-worries__bubbleBox::after {
  content: "";
  position: absolute;
  bottom: -1.833vw;
  width: 2.5vw;
  height: 2.5vw;
  /* background: #ffffff; */
  transform: rotate(180deg);
  border-left: 1.833vw solid #fff;
  border-top: 1.833vw solid transparent;
  border-bottom: 1.833vw solid transparent;
}

.hakob-worries__bubble:nth-child(odd) .hakob-worries__bubbleBox::after {
  left: 17.333vw;
}

.hakob-worries__bubble:nth-child(even) .hakob-worries__bubbleBox::after {
  left: 18.333vw;
  transform: rotate(0deg);
}

.hakob-worries__bubbleInner {
  padding: 5vw;
}

.hakob-worries__meta {
  margin-bottom: 1.583vw;
  text-align: center;
  font-size: 1.25vw;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #707070;
  font-weight: 500;
}

.hakob-worries__bubbleTitle {
  margin: 0;
  text-align: center;
  font-size: 1.833vw;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.01em;
}

.hakob-worries__bubbleText {
  margin: 1.667vw 0 0;
  text-align: center;
  font-size: 1.25vw;
  line-height: 1.8;
  color: #222222;
  font-weight: 400;
}

.hakob-worries__illust {
  margin: 0 auto;
  margin-top: 2.5vw;
  width: 25vw;
}

.hakob-worries__illust img {
  display: block;
  width: 100%;
  height: auto;
}

/* 個別位置調整 */
.hakob-worries__bubble--1 {
  transform: translateX(0);
}

.hakob-worries__bubble--2 {
  transform: translateX(0) translateY(-10vw);
}

.hakob-worries__bubble--3 {
  transform: translateX(0) translateY(-7.5vw);
}

.hakob-worries__bubble--4 {
  transform: translateX(0) translateY(-17.5vw);
}

.hakob-worries__bubble--5 {
  transform: translateX(0) translateY(-15vw);
}

.hakob-worries__bubble--6 {
  transform: translateX(0) translateY(-25vw);
}


.hakob-problems {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2vw;
}

.hakob-problems__item {
  padding: 5vw;
  background: #fff;
}

.hakob-problems__item img {
  display: block;
  width: 100%;
}

/* ----------------------------------------
   Value
---------------------------------------- */
.hakob-value {
  background: #fff;
}

.hakob-value__grid {
}

.hakob-value__item {
  background: #fff;
}

.hakob-value__item img {
  display: block;
  width: 100%;
}

/* ----------------------------------------
   Can do / scene
---------------------------------------- */


/* ----------------------------------------
   Experience
---------------------------------------- */
.hakob-experience {
  background: #fff;
}

.hakob-exp-block {
  padding-top: 3.333vw;
}

.hakob-exp-block + .hakob-exp-block {
  margin-top: 5.667vw;
}

.hakob-exp-block__head {
  margin-bottom: 2.917vw;
  text-align: center;
}

.hakob-exp-block__num {
  display: inline-block;
  margin-bottom: 1.5vw;
  padding: 0.667vw 1.5vw;
  background: #bf6d4d;
  color: #fff;
  font-size: 1.167vw;
  line-height: 1.4;
  letter-spacing: 0.12em;
}

.hakob-exp-block__head h3 {
  margin: 0;
  font-size: 2.833vw;
  line-height: 1.5;
  font-weight: 500;
}

.hakob-exp-block__head p {
}

.hakob-exp-browser {
}

.hakob-exp-browser__window {
}

.hakob-exp-browser__bar {
  display: flex;
  align-items: center;
  gap: 0.667vw;
  margin-bottom: 1.5vw;
}

.hakob-exp-browser__dot {
  width: 0.833vw;
  height: 0.833vw;
  border-radius: 50%;
  background: #e0d5d0;
}

.hakob-exp-browser__screen img {
  display: block;
  width: 100%;
}

.hakob-exp5 {
  position: relative;
}

.hakob-exp5__tabs {
  display: flex;
  justify-content: flex-end;
  gap: 0.833vw;
  margin-bottom: 1.667vw;
}

.hakob-exp5__tab {
  min-width: 10vw;
  min-height: 3.5vw;
  padding: 0.833vw 1.167vw;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #fff;
  color: #444;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease,
    opacity 0.3s ease;
  cursor: pointer;
  font-size: 1.25vw!important;
}

.hakob-exp5__tab:hover {
  opacity: 0.82;
}

.hakob-exp5__tab.is-active {
  background: #B8522E;
  color: #fff;
  border-color: #B8522E;
}

.hakob-exp5__panels {
  position: relative;
}

.hakob-exp5__panel {
  display: none;
}

.hakob-exp5__panel.is-active {
  display: block;
}

/* ----------------------------------------
   Plan
---------------------------------------- */


/* ----------------------------------------
   Works
---------------------------------------- */
.hakob-works {
  display: none;
}

/* ----------------------------------------
   Contact intro
---------------------------------------- */

/* ----------------------------------------
   Contact / HubSpot
---------------------------------------- */

#hakobHubspotForm .hs-form-field {
  margin-bottom: 1.833vw;
}

#hakobHubspotForm label {
  display: block;
  margin-bottom: 0.667vw;
  font-size: 1.25vw;
  line-height: 1.7;
}

#hakobHubspotForm .hs-input,
#hakobHubspotForm select,
#hakobHubspotForm textarea {
  width: 100%;
  min-height: 4.5vw;
  padding: 1vw 1.167vw;
  border: 1px solid #d8d2cd;
  background: #fff;
  box-shadow: none;
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
}

#hakobHubspotForm textarea {
  min-height: 15vw;
  resize: vertical;
}

#hakobHubspotForm .inputs-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

#hakobHubspotForm .inputs-list li {
  margin-bottom: 0.833vw;
}

#hakobHubspotForm .hs-richtext,
#hakobHubspotForm .legal-consent-container,
#hakobHubspotForm .hs_recaptcha {
  font-size: 1.083vw;
  line-height: 1.9;
  color: var(--text-sub);
}

#hakobHubspotForm .hs-button,
#hakobHubspotForm input[type="submit"] {
  min-width: 18.333vw;
  min-height: 4.667vw;
  padding: 1vw 2.667vw !important;
  border: 0 !important;
  background: #222 !important;
  color: #fff !important;
  border-radius: 0 !important;
  transition: opacity 0.3s ease;
}

#hakobHubspotForm .hs-button:hover,
#hakobHubspotForm input[type="submit"]:hover {
  opacity: 0.82;
}

#hakobHubspotForm .hs_submit {
  margin-top: 2.5vw;
  text-align: center;
}

#hakobHubspotForm .hs-error-msgs {
  list-style: none;
  margin: 0;
  padding: 0.5vw 0 0;
  font-size: 1.083vw;
  color: #c0392b;
}

#hakobHubspotForm .submitted-message {
  text-align: center;
  font-size: 1.25vw;
  line-height: 2;
}

.hakob-worries__after {
  padding-top: 6.667vw;
  padding-bottom: 5.833vw;
}

.hakob-problems__head {
  margin-bottom: 5vw;
}

.hakob-problems__head .hakob-en {
  color: #707070;
  margin-bottom: 1.667vw;
}

.hakob-problems__head h2 {
  font-size: 2.083vw;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-problems {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5vw;
}

.hakob-problems__item {
  background: #B8522E;
  color: #ffffff;
}

.hakob-problems__inner {
  position: relative;
  text-align: center;
}

.hakob-problems__label {
  margin-bottom: 1.5vw;
  font-size: 1.25vw;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-weight: 500;
}

.hakob-problems__title {
  margin: 0;
  font-size: 1.833vw;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.hakob-problems__text {
  margin: 1.667vw 0 0;
  font-size: 1.25vw;
  line-height: 1.7;
  font-weight: 400;
}

.hakob-problems__illust {
  margin-top: 2.5vw;
}

.hakob-problems__illust img {
  display: block;
  width: 100%;
  height: auto;
}

/* 真ん中カードの矢印風装飾を入れたい場合の余地 */
.hakob-problems__item.is-separate .hakob-problems__inner {
  overflow: hidden;
}



/* ----------------------------------------
   Bottom gap
---------------------------------------- */
.hakob-bottom-gap {
  height: 0;
}
#breadClumnb {
  display: none;
}

/* ----------------------------------------
   Reduced motion
---------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .js-reveal,
  .hakob-header,
  .hakob-header__nav a::after,
  .hakob-drawer__nav a::after,
  .hakob-btn,
  .hakob-worries__bubble,
  .hakob-exp5__tab,
  .hakob-header__spBtn span,
  .hakob-header__spBtn::before,
  .hakob-header__spBtn::after {
    transition: none !important;
  }
}


.hakob-why {
  background: #F8F5F2;
  padding-top: 6.667vw;
  padding-bottom: 5.833vw;
  overflow: hidden;
}

.hakob-why__head {
  text-align: center;
}

.hakob-why__eyebrow {
  margin: 0;
  font-size: 1.5vw;
  line-height: 1.4;
  font-weight: 700;
  color: #707070;
}

.hakob-why__title {
  margin: 0;
  font-size: 2.833vw;
  line-height: 2;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: #222222;
}

.hakob-why__divider {
  width: 0.083vw;
  height: 6.667vw;
  margin: 0.833vw auto 2.5vw;
  background: #707070;
}

.hakob-why__logo {
  width: 29.167vw;
  margin: 0 auto;
}

.hakob-why__logo img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-why__body {
  margin-top: 12.5vw;
  display: block;
  position: relative;
}

.hakob-why__visual {
  margin: 0;
}

.hakob-why__visual img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-why__desc {
  position: relative;
  padding-top: 0;
  position: absolute;
  width: 37.5vw;
  right: 0;
  top: 6.667vw;
}

.hakob-why__descLine {
  position: absolute;
  top: 1.5vw;
  left: -12.5vw;
  width: 10.833vw;
  height: 0.083vw;
  background: #d6a48f;
}

.hakob-why__descLine::before {
  content: "";
  position: absolute;
  left: -0.5vw;
  top: 50%;
  width: 0.667vw;
  height: 0.667vw;
  border: 1px solid #d6a48f;
  border-radius: 50%;
  transform: translateY(-50%);
  background: #f1eeeb;
}

.hakob-why__descLine::after {
  content: "";
  position: absolute;
  right: 1vw;
  top: 0;
  width: 0.083vw;
  height: 7.333vw;
  background: #d6a48f;
}

.hakob-why__descTexts {
  position: relative;
}

.hakob-why__descTexts::after {
}

.hakob-why__desc p {
  margin: 0;
  font-size: 1.25vw;
  line-height: 1.8;
  font-weight: 400;
  color: #222222;
}

.hakob-why__desc p + p {
  margin-top: 2.333vw;
}

.hakob-value {
  background: #F8F5F2;
  padding-top: 6.667vw;
  padding-bottom: 10.833vw;
}

.hakob-value__head {
  margin-bottom: 5vw;
}

.hakob-value__head .hakob-en {
  color: #707070;
  font-weight: 500;
  margin-bottom: 1.667vw;
}

.hakob-value__head h2 {
  font-size: 2.083vw;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-value__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5vw;
}

.hakob-value__item {
  background: #ffffff;
}

.hakob-value__inner {
  padding: 5vw 3.333vw;
}

.hakob-value__num {
  margin-bottom: 1.667vw;
  text-align: center;
  font-size: 1.25vw;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-weight: 500;
  color: #B8522E;
}

.hakob-value__image {
  width: 100%;
}

.hakob-value__image img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-value__title {
  margin: 2.5vw 0 0;
  text-align: center;
  font-size: 1.667vw;
  line-height: 1.55;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: #222222;
}

.hakob-value__text {
  margin: 1.667vw 1.667vw 0;
  font-size: 1.25vw;
  line-height: 2;
  font-weight: 400;
  color: #222222;
}


.hakob-experience {
  background: #FFFFFF;
  padding-top: 8.333vw;
  padding-bottom: 10.833vw;
}

.hakob-experience__intro {
  text-align: center;
}

.hakob-experience__catch {
  margin: 0;
  font-size: 3.75vw;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: -0.02em;
}
.hakob-experience__catch span {
  color: #B8522E;
  font-size: 7.5vw;
  line-height: 0.5;
  position: relative;
  top: 2.5vw;
  margin: 0 1.25vw;
}
.hakob-experience__intro h2 {
  margin: 1.333vw 0 0;
  font-size: 1.333vw;
  line-height: 1.6;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.02em;
}

.hakob-experience__anchors {
  margin-top: 3.333vw;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.833vw;
  background: #F6F6F6;
  padding: 2.5vw;
}

.hakob-experience__anchor {
  padding: 1.25vw;
  background: #FFFFFF;
  text-align: center;
  border-radius: 0.417vw;
}

.hakob-experience__anchor:last-child {
  border-right: 0;
}

.hakob-experience__anchorLabel {
  display: block;
  font-size: 1.333vw;
  line-height: 1.4;
  color: #B8522E;
  font-weight: 500;
}
.hakob-experience__anchorLabel span {
  font-size: 1.667vw;
}
.hakob-experience__anchorTitle {
  display: block;
  margin-top: 1.25vw;
  margin-bottom: 2.083vw;
  font-size: 1.333vw;
  line-height: 1.6;
  color: #222222;
  font-weight: 500;
  position: relative;
}
.hakob-experience__anchorTitle:after {
    content: "";
    position: absolute;
    bottom: -1.917vw;
    width: 0;
    height: 0;
    border-left: 0.583vw solid transparent;
    border-right: 0.583vw solid transparent;
    border-top: 0.833vw solid #DEDEDE;
    left: 50%;
    transform: translateX(-50%);
}
.hakob-exp-block {
  margin-top: 3.333vw;
}

.hakob-exp-block__head {
  text-align: center;
}

.hakob-exp-block__label {
  display: inline-block;
  padding: 0.833vw 1.25vw;
  background: #B8522E;
  color: #ffffff;
  font-size: 1.333vw;
  line-height: 1.4;
  font-weight: 400;
  position: relative;
}
.hakob-exp-block__label:after {
    content: "";
    position: absolute;
    bottom: -0.833vw;
    width: 0;
    height: 0;
    border-left: 0.417vw solid transparent;
    border-right: 0.417vw solid transparent;
    border-top: 0.833vw solid #B8522E;
    left: 50%;
    transform: translateX(-50%);
}
.hakob-exp-block__label span span {
  font-size: 1.667vw;
}
.hakob-exp-block__head h3 {
  margin: 2.083vw 0 0;
  font-size: 2.333vw;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.02em;
}

.hakob-exp-block__body {
  margin: 2.917vw auto 0;
  max-width: unset;
  font-size: 1.25vw;
  line-height: 1.8;
  color: #222222;
}

.hakob-exp-browser__screen img,
.hakob-exp-browser__screen video {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-exp-block__summary {
  margin: 2.917vw auto 0;
  max-width: 76.25vw;
  display: grid;
  grid-template-columns: 1fr 29.5vw;
  gap: 1.25vw;
  border: 1px solid #B8522E;
  border-radius: 0.833vw;
  padding: 2.5vw;
  align-items: center;
}

.hakob-exp-block__points {
  list-style: none;
  margin: 0;
  padding: 0;
}

.hakob-exp-block__points li {
  position: relative;
  padding-left: 3.083vw;
  font-size: 1.25vw;
  line-height: 1.8;
  color: #222222;
  font-weight: 500;
}

.hakob-exp-block__points li + li {
  margin-top: 0.833vw;
}

.hakob-exp-block__points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  background: url('../img/hakob/text_mark02.png') no-repeat;
  width: 2.25vw;
  height: 2vw;
  background-size: contain;
}

.hakob-exp-block__note {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.333vw 2.333vw;
  background: #393533;
  color: #ffffff;
  text-align: center;
  font-size: 1.25vw;
  line-height: 1.8;
  font-weight: 500;
  border-radius: 0.417vw;
  height: min-content;
}
.hakob-exp-block__note span {
  font-size: 1.417vw;
}
.hakob-exp-block__visual {
  margin-top: 3.333vw;
  background: #F8EDE9;
  padding: 3.333vw 8.333vw 3.333vw;
  position: relative;
}

.hakob-exp-block__caption {
  margin: 0 0 1.25vw;
  padding-left: 3.75vw;
  font-size: 1.417vw;
  line-height: 1.6;
  font-weight: 500;
  color: #B8522E;
  position: relative;
}
.hakob-exp-block__caption:before {
  content: "";
  position: absolute;
  left: 0.833vw;
  top: 0.167vw;
  background: url('../img/hakob/text_mark01.png') no-repeat;
  width: 2vw;
  height: 2vw;
  background-size: contain;
}
.hakob-exp-browser {
  background: transparent;
  padding: 0;
}

.hakob-exp-browser__window {
  padding: 0;
}

.hakob-exp-browser__bar {
  display: flex;
  align-items: center;
  gap: 0.667vw;
  padding: 1.167vw 1.333vw;
  border-bottom: 1px solid #ece7e3;
  background: #f8f7f6;
}

.hakob-exp-browser__dot {
  width: 0.667vw;
  height: 0.667vw;
  border-radius: 50%;
  background: #d5ccc7;
}

.hakob-exp-browser__screen img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-exp5__tabs {
  display: flex;
  justify-content: flex-end;
  gap: 0.833vw;
  margin: 0 0 1.333vw;
  position: absolute;
  right: 9.833vw;
  top: 3.333vw;
}

.hakob-exp5__tab {
  min-width: 11.167vw;
  min-height: 3.25vw;
  padding: 0.833vw 1.667vw;
  border: 1px solid #DEDEDE;
  background: #ffffff;
  color: #ACACAC;
  font-size: 1.25vw;
  border-radius: 0.417vw;
}

.hakob-exp5__tab.is-active {
  background: #B8522E;
  border-color: #B8522E;
  color: #ffffff;
}

.hakob-exp5__panel {
  display: none;
}

.hakob-exp5__panel.is-active {
  display: block;
}

.hakob-scene {
  background: #BE6140;
  padding-top: 9.167vw;
  padding-bottom: 10vw;
}

.hakob-scene__head {
  margin-bottom: 4vw;
}

.hakob-scene__head .hakob-en {
  color: #ffffff;
  font-weight: 500;
  margin-bottom: 1.667vw;
}

.hakob-scene__head h2 {
  font-size: 2vw;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #ffffff;
}

.hakob-scene__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.833vw 2.5vw;
}

.hakob-scene__item {
  color: #ffffff;
}

.hakob-scene__thumb {
  margin: 0;
}

.hakob-scene__thumb img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-scene__body {
  padding-top: 1.333vw;
  text-align: center;
}

.hakob-scene__body h3 {
  margin: 0;
  font-size: 1.75vw;
  line-height: 1.6;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #ffffff;
}

.hakob-scene__body p {
  margin: 0.833vw 0 0;
  font-size: 1.167vw;
  line-height: 1.8;
  font-weight: 400;
  color: #ffffff;
}

.hakob-works {
  background: #f1eeeb;
  padding-top: 9.167vw;
  padding-bottom: 10vw;
}

.hakob-works__head {
  margin-bottom: 4vw;
}

.hakob-works__head .hakob-en {
  color: #707070;
}

.hakob-works__head h2 {
  font-size: 2vw;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #222222;
}

.hakob-works__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.333vw;
}

.hakob-works__item {
  color: #222222;
}

.hakob-works__thumb {
  margin: 0;
  background: #ffffff;
}

.hakob-works__thumb img {
  display: block;
  width: 100%;
  height: auto;
}

.hakob-works__body {
  padding-top: 1vw;
}

.hakob-works__body h3 {
  margin: 0;
  font-size: 1.333vw;
  line-height: 1.6;
  font-weight: 700;
  color: #222222;
}

.hakob-works__body p {
  margin: 0.667vw 0 0;
  font-size: 1.083vw;
  line-height: 1.8;
  color: #222222;
}

.hakob-plan {
  background: #FFFFFF;
  padding-top: 10.833vw;
  padding-bottom: 10.833vw;
}

.hakob-plan__head {
  margin-bottom: 5vw;
}

.hakob-plan__head .hakob-en {
  color: #707070;
  margin-bottom: 1.667vw;
  font-weight: 500;
}

.hakob-plan__head h2 {
  font-size: 2.083vw;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-plan__main {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.333vw;
  width: 77.5vw;
  margin: 0 auto;
}

.hakob-plan__card {
  background: #F8EDE9;
}

.hakob-plan__cardInner {
  padding: 4.167vw 3.75vw 4.167vw;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: stretch;
}

.hakob-plan__name {
  margin: 0;
  font-size: 2.167vw;
  line-height: 1.4;
  font-weight: 700;
  color: #222222;
}

.hakob-plan__sub {
  margin: 0.583vw 0 0;
  font-size: 1.083vw;
  line-height: 1.6;
  color: #B8522E;
  font-weight: 500;
}

.hakob-plan__priceRow {
  margin-top: 2.083vw;
  display: flex;
  align-items: flex-end;
  gap: 0.25vw;
}

.hakob-plan__price {
  font-size: 2.667vw;
  line-height: 1.2;
  font-weight: 700;
  color: #222222;
}

.hakob-plan__unit {
  font-size: 1.25vw;
  line-height: 1.4;
  color: #222222;
  padding-bottom: 0.5vw;
  font-weight: 500;
}

.hakob-plan__desc {
  margin: 0;
  font-size: 1.083vw;
  line-height: 1.7;
  color: #707070;
}

.hakob-plan__list {
  list-style: none;
  margin: 2.5vw 0 0;
  padding: 0;
}

.hakob-plan__list li {
  position: relative;
  padding-left: 1.917vw;
}

.hakob-plan__list li + li {
  margin-top: 1.417vw;
}

.hakob-plan__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.417vw;
  width: 1.333vw;
  height: 1.333vw;
  color: #222222;
  background: url('../img/hakob/plan_mark.png') no-repeat;
  background-size: contain;
}

.hakob-plan__itemTitle {
  font-size: 1.25vw;
  line-height: 1.7;
  font-weight: 400;
  color: #222222;
}

.hakob-plan__itemText {
  margin-top: 0.417vw;
  font-size: 1.083vw;
  line-height: 1.8;
  color: #707070;
}

.hakob-plan__note {
  margin: 2.083vw 0 0;
  padding-top: 2.083vw;
  border-top: 1px solid #DEDEDE;
  font-size: 1.083vw;
  line-height: 1.7;
  color: #707070;
}

.hakob-plan__monthlyWrap {
  margin: 0 auto;
  margin-top: 3.333vw;
  padding: 2.5vw 3.333vw;
  border: 1px solid #B8522E;
  background: transparent;
  width: 77.5vw;
}

.hakob-plan__monthlyHead {
  margin: 0 0 1.5vw;
  font-size: 1.333vw;
  line-height: 1.6;
  font-weight: 500;
  color: #222222;
}

.hakob-plan__monthly {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.083vw;
}

.hakob-plan__card--sub {
  border: 1px solid #DEDEDE;
  border-radius: 0.833vw;
  background: #ffffff;
  height: auto;
}
.hakob-plan__card--sub .hakob-plan__cardInner {
  padding: 2.5vw;
}
.hakob-plan__subName {
  margin: 0;
  font-size: 1.25vw;
  line-height: 1.6;
  font-weight: 500;
  color: #B8522E;
}

.hakob-plan__subPriceRow {
  margin-top: 0.833vw;
  display: flex;
  align-items: flex-end;
  gap: 0.25vw;
}

.hakob-plan__subPrice {
  font-size: 2.5vw;
  line-height: 1.1;
  font-weight: 700;
  color: #222222;
}
.hakob-plan__subPrice span {
    font-size: 2.083vw;
}
.hakob-plan__subUnit {
  font-size: 1.25vw;
  line-height: 1.4;
  color: #222222;
  padding-bottom: 0.167vw;
}

.hakob-plan__subDesc {
  margin: 0.583vw 0 0;
  font-size: 1.083vw;
  line-height: 1.7;
  color: #707070;
}

.hakob-plan__subList {
  list-style: none;
  margin: 1.667vw 0 0;
  padding: 0;
}

.hakob-plan__subList li {
  position: relative;
  padding-left: 1.917vw;
  font-size: 1.25vw;
  line-height: 1.8;
  color: #222222;
}

.hakob-plan__subList li + li {
  margin-top: 0.667vw;
}

.hakob-plan__subList li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.417vw;
  width: 1.333vw;
  height: 1.333vw;
  color: #222222;
  background: url(../img/hakob/plan_mark.png) no-repeat;
  background-size: contain;
}

.hakob-contact-intro {
  background: #F8F5F2;
  padding-top: 9.167vw;
  padding-bottom: 5vw;
}

.hakob-contact-intro__container {
  max-width: 86.667vw;
}

.hakob-contact-intro__head {
  text-align: center;
  margin-bottom: 5vw;
}

.hakob-contact-intro__head h2 {
  margin: 0;
  font-size: 3.75vw;
  line-height: 1.7;
  font-weight: 500;
  color: #222222;
  letter-spacing: -0.02em;
}

.hakob-contact-intro__head p {
  margin: 1.5vw 0 0;
  font-size: 1.333vw;
  line-height: 2;
  color: #222222;
  letter-spacing: 0.02em;
  font-weight: 400;
}

.hakob-contact-intro__cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.333vw;
  max-width: 77.5vw;
  margin: 0 auto;
}

.hakob-contact-intro__card {
  background: #ffffff;
  padding: 2.5vw 3.333vw 2.917vw;
  text-align: center;
}

.hakob-contact-intro__icon {
  width: 4.583vw;
  margin: 0 auto 1.667vw;
  display: block;
}

.hakob-contact-intro__card h3 {
  margin: 0;
  font-size: 1.667vw;
  line-height: 1.7;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.02em;
}

.hakob-contact-intro__card p {
  margin: 1.25vw 0 2.5vw;
  font-size: 1.083vw;
  line-height: 1.8;
  color: #222222;
}

.hakob-contact-intro__card .hakob-btn {
  min-width: 30.417vw;
  min-height: 5vw;
  padding: 0 1.333vw;
  font-size: 1.333vw;
  letter-spacing: 0.04em;
}

.hakob-btn--outline {
  background: transparent;
  color: #1A3A5C!important;
  border: 1px solid #1A3A5C;
}

.hakob-contact {
  background: #F8F5F2;
  padding-top: 0;
  padding-bottom: 10vw;
}

.hakob-contact__container {
  max-width: 77.5vw;
}

.hakob-contact__box {
  background: #FFFFFF;
  padding: 5vw;
}

.hakob-contact__head {
  text-align: center;
  margin-bottom: 5vw;
}

.hakob-contact__head h2 {
  margin: 0;
  font-size: 1.5vw;
  line-height: 1.7;
  font-weight: 500;
  color: #222222;
}

#hakobHubspotForm form {
  max-width: 100%;
}

#hakobHubspotForm .hs-form-field {
  display: flex;
  align-items: flex-start;
  gap: 2.333vw;
  margin-bottom: 1vw;
}

#hakobHubspotForm .hs-form-field > label {
  width: 8.667vw;
  flex: 0 0 8.667vw;
  margin: 0;
  padding-top: 0.833vw;
  font-size: 1vw;
  line-height: 1.6;
  color: #222222;
  font-weight: 500;
}

#hakobHubspotForm .input,
#hakobHubspotForm .hs-input,
#hakobHubspotForm .inputs-list,
#hakobHubspotForm .hs-fieldtype-text .input,
#hakobHubspotForm .hs-fieldtype-textarea .input {
  flex: 1 1 auto;
  width: 100%;
}

#hakobHubspotForm .hs-input,
#hakobHubspotForm input[type="text"],
#hakobHubspotForm input[type="email"],
#hakobHubspotForm input[type="tel"],
#hakobHubspotForm textarea,
#hakobHubspotForm select {
  width: 100%;
  min-height: 2.333vw;
  padding: 0.5vw 0.833vw;
  border: 1px solid #D8D8D8;
  background: #ffffff;
  border-radius: 0;
  box-shadow: none;
  font-size: 1.083vw;
  color: #222222;
}

#hakobHubspotForm textarea {
  min-height: 12.5vw;
  resize: vertical;
}

#hakobHubspotForm .hs-error-msgs {
  margin: 0.5vw 0 0;
  padding: 0;
  list-style: none;
  font-size: 1vw;
  color: #c0392b;
}

#hakobHubspotForm .legal-consent-container,
#hakobHubspotForm .hs-richtext,
#hakobHubspotForm .hs_recaptcha {
  margin-top: 1.167vw;
  font-size: 1vw;
  line-height: 1.8;
  color: #222222;
}

#hakobHubspotForm .hs_submit {
  text-align: center;
  margin-top: 2.5vw;
}

#hakobHubspotForm .hs-button,
#hakobHubspotForm input[type="submit"] {
  min-width: 12.167vw;
  min-height: 3.167vw;
  padding: 0 1.667vw !important;
  border: 0 !important;
  background: #393533 !important;
  color: #ffffff !important;
  border-radius: 0 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

#hakobHubspotForm .submitted-message {
  text-align: center;
  font-size: 1.167vw;
  line-height: 2;
  color: #222222;
}

.hakob-header__nav a::before {
    content: attr(data-text);
    position: absolute;
    left: 0;
    top: 100%;
    transform: translateY(0);
    transition: transform 1.2s cubic-bezier(0.14, 1, 0.34, 1);
    color: inherit;
}
.hakob-header__nav a span {
  transform: translateY(0);
  display: inline-block;
  transition: transform 1.2s cubic-bezier(0.14, 1, 0.34, 1);
}
.hakob-header__nav a:hover span {
  transform: translateY(-100%);
}
.hakob-header__nav a:hover::before {
    transform: translateY(-100%);
}


}

@media screen and (min-width: 1040px) and (max-width: 1199px) {
.hakob-hero {
  position: relative;
  /* min-height: 58.5vw; */
  /* max-height: 58.5vw; */
  overflow: hidden;
  color: #ffffff;
}

.hakob-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hakob-hero__posterEnd {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}

.hakob-hero__posterEnd img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.hakob-hero__video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  /* max-height: 67.5vw; */
  display: block;
  object-fit: cover;
  transition: opacity 0.8s ease;
  background: #F8F5F2;
}

.hakob-hero__bg.is-video-ended .hakob-hero__video {
  opacity: 0;
  pointer-events: none;
}

.hakob-hero__inner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 0px), 1240px);
  /* min-height: 58.5vw; */
  /* max-height: 58.5vw; */
  min-height: calc(58.5vw - 105px);
  min-height: calc(100svh - 105px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}
}


@media screen and (max-width: 834px) {

html {
  font-size: calc(100vw / 750)!important;
}
    .term-hakob .inner {
        width: calc(100% - 150rem);
    }
.hakob-only-pc {
  display: none!important;
}

.hakob-only-sp {
  display: block!important;
}

.hakob-hero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  color: #ffffff;
  padding-top: 24vw;
  background: #F8F5F2;
}

.hakob-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background: #F8F5F2;
}

.hakob-hero__posterEnd {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}

.hakob-hero__posterEnd img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.hakob-en {
    display: inline-block;
    margin-bottom: 14px;
    color: #b55c3c;
    color: #ffffff;
    font-size: 26rem;
    line-height: 1.4;
    letter-spacing: 0.04em;
    /* text-transform: uppercase; */
}
.hakob-value__head .hakob-en {
    color: #707070;
    font-weight: 500;
    margin-bottom: 20rem;
}
.hakob-hero__video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: opacity 0.8s ease;
  padding-top: 24vw;
}
.hakob-scene__head .hakob-en {
    color: #ffffff;
    font-weight: 500;
    margin-bottom: 20rem;
}
.hakob-hero__bg.is-video-ended .hakob-hero__video {
  opacity: 0;
  pointer-events: none;
}
.hakob-plan__head .hakob-en {
    color: #707070;
    margin-bottom: 20rem;
    font-weight: 500;
}
.hakob-hero__inner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 80rem), 1240rem);
  min-height: calc(100svh - 105rem);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}
  .hakob-why {
    padding-top: 80rem;
    padding-bottom: 60rem;
  }

  .hakob-why__eyebrow {
    font-size: 16rem;
  }

  .hakob-why__title {
    margin-top: 0;
    font-size: 38rem;
    line-height: 1.9;
  }
.hakob-worries__after {
  padding-top: 120rem;
  padding-bottom: 70rem;
}

.hakob-problems__head {
  margin-bottom: 60rem;
}

.hakob-problems__head .hakob-en {
  color: #707070;
  margin-bottom: 20rem;
}

.hakob-problems__head h2 {
  font-size: 35rem;
  line-height: 1.7;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #222222;
}

.hakob-problems {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.hakob-problems__item {
  background: #B8522E;
  color: #ffffff;
}

.hakob-problems__inner {
  position: relative;
  text-align: center;
}

.hakob-problems__label {
  margin-bottom: 20rem;
  font-size: 22rem;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-weight: 500;
}

.hakob-problems__title {
  margin: 0;
  font-size: 32rem;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.hakob-problems__text {
  margin: 20rem 0 0;
  font-size: 26rem;
  line-height: 1.7;
  font-weight: 400;
}

.hakob-problems__illust {
  width: 350rem;
  margin: 0 auto;
  margin-top: 26rem;
}

.hakob-problems__illust img {
  display: block;
  width: 100%;
  height: auto;
}
  .hakob-why__divider {
    height: 100rem;
    margin: 26rem auto 50rem;
  }

  .hakob-why__logo {
    width: 400rem;
  }

  .hakob-why__body {
    margin-top: 150rem;
    display: block;
  }

  .hakob-why__visual {
    max-width: 100%;
  }

  .hakob-why__desc {
    margin-top: 0;
    padding-top: 0;
    width: 580rem;
    right: 55rem;
    top: 600rem;
  }

  .hakob-why__descLine {
    position: relative;
    top: auto;
    left: auto;
    width: 100rem;
    margin: 0 auto 26rem;
  }

  .hakob-why__descLine::before {
    left: -6rem;
    width: 8rem;
    height: 8rem;
  }

  .hakob-why__descLine::after {
    right: 10rem;
    height: 54rem;
  }

  .hakob-why__descTexts {
    padding-left: 0;
  }

  .hakob-why__descTexts::after {
    display: none;
  }

  .hakob-why__desc p {
    font-size: 26rem;
    line-height: 2;
  }

  .hakob-why__desc p + p {
    margin-top: 50rem;
  }

  .hakob-value {
    padding-top: 60rem;
    padding-bottom: 100rem;
  }

  .hakob-value__head {
    margin-bottom: 60rem;
  }

  .hakob-value__head h2 {
    font-size: 35rem;
    line-height: 1.7;
  }

  .hakob-value__grid {
    grid-template-columns: 1fr;
    gap: 30rem;
    width: 580rem;
    margin: 0 auto;
  }

  .hakob-value__inner {
    padding: 50rem 38rem 50rem;
  }

  .hakob-value__num {
    margin-bottom: 25rem;
    font-size: 24rem;
  }

  .hakob-value__title {
    margin-top: 40rem;
    font-size: 32rem;
    line-height: 1.6;
  }

  .hakob-value__text {
    margin: 0;
    margin-top: 30rem;
    font-size: 26rem;
    line-height: 1.9;
    letter-spacing: 0.01em;
  }

  .hakob-experience {
    padding-top: 85rem;
    padding-bottom: 120rem;
  }

  .hakob-experience__catch {
    font-size: 50rem;
    line-height: 1.6;
  }
.hakob-experience__catch span {
    color: #B8522E;
    font-size: 98rem;
    line-height: 0.5;
    position: relative;
    top: 28rem;
    margin: 0 10rem;
}
  .hakob-experience__intro h2 {
    margin-top: 23rem;
    font-size: 27rem;
    font-weight: 400;
  }

  .hakob-experience__anchors {
    grid-template-columns: 1fr;
    gap: 10rem;
    padding: 0;
    background: #F6F6F6;
    width: 640rem;
    margin: 0 auto;
    margin-top: 40rem;
    padding: 30rem;
  }

  .hakob-experience__anchor {
    min-height: auto;
    padding: 24rem 26rem;
    border-right: 0;
  }

  .hakob-experience__anchorLabel {
    font-size: 21rem;
    text-align: left;
  }
.hakob-experience__anchorLabel span {
    font-size: 25rem;
}
  .hakob-experience__anchorTitle {
    margin-top: 15rem;
    font-size: 25rem;
    text-align: left;
    margin-bottom: 0;
  }
.hakob-experience__anchorTitle:after {
    content: "";
    position: absolute;
    bottom: unset;
    top: 0;
    width: 0;
    height: 0;
    border-left: 9rem solid transparent;
    border-right: 9rem solid transparent;
    border-top: 12rem solid #DEDEDE;
    left: 98%;
    transform: translateX(-50%);
}
  .hakob-exp-block {
    margin: 0 auto;
    margin-top: 40rem;
    padding-top: 0;
    width: 640rem;
  }
.hakob-exp-block + .hakob-exp-block {
    margin-top: 100rem;
}
.hakob-exp-block__head {
    margin-bottom: 40rem;
    text-align: center;
}
  .hakob-exp-block__label {
    padding: 20rem 35rem 25rem;
    font-size: 26rem;
  }
    .hakob-exp-block__label span {
        font-size: 22rem;
    }
.hakob-exp-block__label span span {
    font-size: 26rem;
}
  .hakob-exp-block__head h3 {
    margin-top: 40rem;
    font-size: 36rem;
    line-height: 1.5;
  }

  .hakob-exp-block__body {
    margin-top: 40rem;
    font-size: 26rem;
    line-height: 1.9;
    text-align: left;
  }

  .hakob-exp-block__summary {
    margin-top: 20rem;
    grid-template-columns: 1fr;
    gap: 35rem;
    margin: 40rem auto 0;
    max-width: 915rem;
    border-radius: 10rem;
    padding: 35rem;
  }

  .hakob-exp-block__points {
    padding: 0;
  }

  .hakob-exp-block__points li {
    padding-left: 83rem;
    font-size: 26rem;
    line-height: 1.6;
    min-height: 83.2rem;
    align-content: center;
  }
.hakob-exp-block__points li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 10rem;
    width: 63rem;
    height: 55rem;
    background-size: contain;
}
  .hakob-exp-block__note {
    padding: 20rem 20rem;
    font-size: 26rem;
    border-radius: 5rem;
  }
.hakob-exp-block__note span {
    font-size: 26rem;
}
  .hakob-exp-block__visual {
    margin-top: 40rem;
    padding: 40rem 30rem 80rem;
  }

  .hakob-exp-block__caption {
    margin-bottom: 10rem;
    margin: 47rem 0 25rem;
    padding-left: 0;
    font-size: 26rem;
    text-align: center;
  }
.hakob-exp-browser__window {
    box-shadow: 17rem 30rem 10rem #0000001f;
    width: 550rem;
    margin: 0 auto;
}
.hakob-exp-browser__screen video {
  height: 550px;
  object-fit: cover;
  object-position: top;
  border-radius: 15rem;
}
.hakob-exp-block__caption:before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -50rem;
    width: 34rem;
    height: 34rem;
    background-size: contain;
}
  .hakob-exp5__tabs {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 8rem;
    position: relative;
    right: unset;
    top: unset;
    margin: 0 0 30rem;
  }

  .hakob-exp5__tab {
    min-width: calc(33.333% - 6rem);
    min-height: 38rem;
    font-size: 25rem!important;
    border-radius: 5rem;
    padding: 15rem;
    line-height: 1.2!important;
  }
  .hakob-scene {
    padding-top: 120rem;
    padding-bottom: 120rem;
  }

  .hakob-scene__head {
    margin-bottom: 60rem;
  }

  .hakob-scene__head h2 {
    font-size: 35rem;
    line-height: 1.7;
    font-weight: 500;
  }

  .hakob-scene__grid {
    grid-template-columns: 1fr;
    gap: 60rem;
    width: 640rem;
    margin: 0 auto;
  }
.hakob-scene__thumb {
    margin: 0 auto;
    width: 580rem;
}
  .hakob-scene__body {
    padding-top: 30rem;
  }

  .hakob-scene__body h3 {
    font-size: 32rem;
    line-height: 1.5;
  }

  .hakob-scene__body p {
    margin-top: 20rem;
    font-size: 26rem;
    line-height: 1.8;
  }

  .hakob-works {
    padding-top: 80rem;
    padding-bottom: 80rem;
    display: none;
  }

  .hakob-works__head {
    margin-bottom: 34rem;
  }

  .hakob-works__head h2 {
    font-size: 22rem;
    line-height: 1.7;
  }

  .hakob-works__grid {
    grid-template-columns: 1fr;
    gap: 22rem;
  }

  .hakob-works__body {
    padding-top: 10rem;
  }

  .hakob-works__body h3 {
    font-size: 20rem;
  }

  .hakob-works__body p {
    margin-top: 6rem;
    font-size: 13rem;
  }

  .hakob-plan {
    padding-top: 120rem;
    padding-bottom: 120rem;
  }

  .hakob-plan__head {
    margin-bottom: 0rem;
  }

  .hakob-plan__head h2 {
    font-size: 35rem;
    line-height: 1.7;
  }

  .hakob-plan__main,
  .hakob-plan__monthly {
    grid-template-columns: 1fr;
    gap: 30rem;
    width: 680rem;
  }
.hakob-plan__monthlyWrap .hakob-plan__monthly {
        grid-template-columns: 1fr;
        gap: 30rem;
        width: 578rem;
    }
  .hakob-plan__cardInner {
    padding: 50rem;
  }
.hakob-plan__card--sub {
  border-radius: 10rem;
}
  .hakob-plan__name {
    font-size: 39rem;
    text-align: center;
  }
.hakob-plan__card--sub .hakob-plan__cardInner {
    padding: 35rem;
}
  .hakob-plan__sub {
    margin-top: 15rem;
    font-size: 26rem;
    line-height: 1.7;
    text-align: center;
  }

  .hakob-plan__priceRow {
    margin-top: 20rem;
    text-align: center;
    justify-content: center;
  }

  .hakob-plan__price {
    font-size: 50rem;
  }

  .hakob-plan__unit {
    font-size: 26rem;
    padding-bottom: 6rem;
  }

  .hakob-plan__desc {
    margin-top: 10rem;
    font-size: 24rem;
    text-align: center;
    letter-spacing: 0.01em;
  }

  .hakob-plan__list {
    margin-top: 30rem;
  }
.hakob-plan__list li {
    position: relative;
    padding-left: 33rem;
}
.hakob-plan__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 5rem;
    width: 26rem;
    height: 26rem;
    color: #222222;
}
  .hakob-plan__list li + li {
    margin-top: 25rem;
  }

  .hakob-plan__itemTitle {
    font-size: 25rem;
  }

  .hakob-plan__itemText {
    font-size: 25rem;
    margin-top: 1rem;
    letter-spacing: 0.01em;
  }

  .hakob-plan__note {
    margin-top: 30rem;
    padding-top: 30rem;
    font-size: 24rem;
    letter-spacing: 0.01em;
  }

  .hakob-plan__monthlyWrap {
    margin-top: 30rem;
    padding: 50rem;
    width: 680rem;
  }

  .hakob-plan__monthlyHead {
    margin-bottom: 50rem;
    font-size: 36rem;
    letter-spacing: 0.01em;
    text-align: center;
  }

  .hakob-plan__subName {
    font-size: 26rem;
  }

  .hakob-plan__subPrice {
    font-size: 34rem;
  }

  .hakob-plan__subUnit {
    font-size: 13rem;
  }

  .hakob-plan__subDesc {
    font-size: 12rem;
  }

  .hakob-plan__subList {
    margin-top: 14rem;
  }

  .hakob-plan__subList li {
    font-size: 12rem;
  }
.hakob-plan__subPriceRow {
  margin-top: 19rem;
  display: flex;
  align-items: flex-end;
  gap: 3rem;
}

.hakob-plan__subPrice {
  font-size: 43rem;
  line-height: 1.1;
  font-weight: 700;
  color: #222222;
}

.hakob-plan__subUnit {
  font-size: 26rem;
  line-height: 1.4;
  color: #222222;
  padding-bottom: 2rem;
}

.hakob-plan__subDesc {
  margin: 3rem 0 0;
  font-size: 24rem;
  line-height: 1.7;
  color: #707070;
  letter-spacing: 0.01em;
}

.hakob-plan__subList {
  list-style: none;
  margin: 30rem 0 0;
  padding: 0;
}

.hakob-plan__subList li {
  position: relative;
  padding-left: 33rem;
  font-size: 25rem;
  line-height: 1.8;
  color: #222222;
}

.hakob-plan__subList li + li {
  margin-top: 8px;
}

.hakob-plan__subList li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7rem;
  width: 26rem;
  height: 26rem;
  color: #222222;
  background: url(../img/hakob/plan_mark.png) no-repeat;
  background-size: contain;
}
  .hakob-contact-intro {
    padding-top: 105rem;
    padding-bottom: 30rem;
  }

  .hakob-contact-intro__head {
    margin-bottom: 50rem;
  }

  .hakob-contact-intro__head h2 {
    font-size: 45rem;
    line-height: 1.7;
  }

  .hakob-contact-intro__head p {
    letter-spacing: 0.01em;
    margin-top: 25rem;
    font-size: 26rem;
    line-height: 2;
  }

  .hakob-contact-intro__cards {
    grid-template-columns: 1fr;
    gap: 30rem;
  }

  .hakob-contact-intro__card {
    padding: 40rem;
  }

  .hakob-contact-intro__icon {
    width: 85rem;
    margin-bottom: 30rem;
  }

  .hakob-contact-intro__card h3 {
    font-size: 32rem;
    letter-spacing: 0.01em;
  }

  .hakob-contact-intro__card p {
    margin: 30rem 0;
    font-size: 26rem;
  }

  .hakob-contact-intro__card .hakob-btn {
    width: 100%;
    min-width: 0;
    min-height: 90rem;
    font-size: 28rem;
  }

  .hakob-contact {
    padding-bottom: 120rem;
  }

  .hakob-contact__box {
    padding: 40rem;
  }
.hakob-contact__container {
    max-width: 660rem;
}
  .hakob-contact__head {
    margin-bottom: 30rem;
  }

  .hakob-contact__head h2 {
    font-size: 32rem;
    font-weight: 500;
  }

  #hakobHubspotForm .hs-form-field {
    display: block;
    margin-bottom: 14rem;
  }

  #hakobHubspotForm .hs-form-field > label {
    display: block;
    width: auto;
    padding-top: 0;
    margin-bottom: 6rem;
    font-size: 12rem;
  }

  #hakobHubspotForm .hs-input,
  #hakobHubspotForm input[type="text"],
  #hakobHubspotForm input[type="email"],
  #hakobHubspotForm input[type="tel"],
  #hakobHubspotForm textarea,
  #hakobHubspotForm select {
    min-height: 40rem;
    font-size: 16rem;
  }

  #hakobHubspotForm textarea {
    min-height: 140rem;
  }
.hakob-hero__cta {
  margin-top: 0;
  margin-bottom: 140rem;
  display: flex;
  justify-content: center;
  gap: 10rem;
  flex-wrap: wrap;
}

.hakob-hero__cta .hakob-btn {
  min-width: 460rem;
  min-height: 80rem;
  padding: 0 20rem;
  font-size: 28rem;
  letter-spacing: 0;
}
.hakob-hero__scroll {
  gap: 0;
  font-size: 20rem;
}
  .hakob-header {
    background: #F8F5F2;
    backdrop-filter: unset;
    box-shadow: unset;
  }

  .hakob-header__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 8rem;
    row-gap: 20rem;
    padding: 17rem 30rem 0;
    min-height: 151rem;
    width: 100%;
    background: #F8F5F2;
  }

  .hakob-header__logo {
    display: block;
    width: 100%;
    max-width: 180rem;
  }

  .hakob-header__logo img {
    display: block;
    width: 100%;
    height: auto;
  }

  .hakob-header__cta {
    justify-self: end;
    margin-left: auto;
    position: absolute;
    top: 17rem;
    right: 30rem;
  }

  .hakob-header__cta .hakob-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 265rem;
    height: 56rem;
    padding: 0 5rem;
    border-radius: 4rem;
    font-size: 25rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.04em;
    white-space: nowrap;
    min-height: 56rem;
  }

  .hakob-header__nav {
    grid-column: 1 / -1;
    margin: 0 60rem;
  }

  .hakob-header__nav ul {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    margin: 0;
    padding: 0;
    list-style: none;
    gap: 70rem;
  }

  .hakob-header__nav li {
    min-width: 0;
  }

  .hakob-header__nav a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 61rem;
    padding: 0;
    color: #222;
    text-align: center;
    text-decoration: none;
    -webkit-tap-highlight-color: transparent;
    overflow: visible;
  }

  .hakob-header__nav a span {
    position: relative;
    display: inline-block;
    font-size: 26rem;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.04em;
    white-space: nowrap;
  }
.hakob-header__nav a::before {
  display: none;
}
.hakob-header__nav a:hover span {
    transform: translateY(0);
}
  .hakob-header__nav a.is-active span::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -15rem;
    transform: translateX(-50%);
    width: 100%;
    min-width: 40rem;
    height: 5rem;
    border-radius: 999rem;
    background: #B8522E;
  }

  /* 今回の見た目ではSPハンバーガーは非表示 */
  .hakob-header__spBtn,
  .hakob-drawer {
    display: none;
  }

.hakob-worries {
  position: relative;
  padding: 0;
  background: linear-gradient(90deg, #6D6E70 0%, #272425 100%);
  color: #ffffff;
  overflow-y: visible;
  transition: opacity 0.3s ease, background-color 0.5s cubic-bezier(.4, .6, .23, 1);
  --worries-tone: 0;
  border-bottom: 2px solid #F8F5F2;
  padding-bottom: 180rem;
}
.hakob-worries:before {
  content: "";
  display: block;
  position: absolute;
  bottom: -1px;
  width: 100vw;
  height: 2px;
  background: #F8F5F2;
}
.hakob-worries::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #F8F5F2;
  opacity: var(--worries-tone);
  z-index: 0;
  pointer-events: none;
}

.hakob-worries__sticky,
.hakob-worries__cards {
  position: relative;
  z-index: 1;
}

.hakob-worries__title,
.hakob-worries__title h2,
.hakob-worries__title .hakob-en {
  transition: none;
}

.hakob-worries__title {
  color: rgba(
    calc(255 - (255 - 34) * var(--worries-tone)),
    calc(255 - (255 - 27) * var(--worries-tone)),
    calc(255 - (255 - 25) * var(--worries-tone)),
    1
  );
}

.hakob-worries__title .hakob-en {
  color: rgba(
    calc(255 - (255 - 34) * var(--worries-tone)),
    calc(255 - (255 - 27) * var(--worries-tone)),
    calc(255 - (255 - 25) * var(--worries-tone)),
    calc(1.0 + 0.3 * var(--worries-tone))
  );
}
.hakob-worries__title {
  text-align: center;
  transition: color 0.4s ease;
}

.hakob-worries__title .hakob-en {
  transition: color 0.4s ease;
}

.hakob-lp.is-worries-after .hakob-worries {
  background: #f1e9e4;
  color: #221b19;
}

.hakob-lp.is-worries-after .hakob-worries .hakob-en,
.hakob-lp.is-worries-after .hakob-worries .hakob-worries__title,
.hakob-lp.is-worries-after .hakob-worries .hakob-worries__title h2 {
}


.hakob-worries__scroll {
  position: relative;
  z-index: 1;
  padding: 0 0 0;
}

.hakob-worries__sticky {
  position: sticky;
  top: 0;
  height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  pointer-events: none;
}

.hakob-worries__title {
  text-align: center;
  transition: color 0.4s ease;
}

.hakob-worries__title .hakob-en {
  margin-bottom: 20rem;
  font-weight: 500;
  font-size: 26rem;
}

.hakob-worries__title h2 {
  margin: 0;
  font-size: 35rem;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.02em;
  font-feature-settings: "palt" 0;
}

.hakob-worries[data-tone="light"] .hakob-worries__title,
.hakob-worries[data-tone="light"] .hakob-worries__title .hakob-en {
  color: #221b19;
}

.hakob-worries__cards {
  position: relative;
  z-index: 3;
  width: 640rem;
  margin: 0vh auto 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.hakob-worries__bubble {
  width: 410rem;
  margin-bottom: 80rem;
}

.hakob-worries__bubble:nth-child(odd) {
  margin-right: auto;
}

.hakob-worries__bubble:nth-child(even) {
  margin-left: auto;
}

.hakob-worries__bubbleBox {
  position: relative;
  background: #ffffff;
  box-shadow: 25rem 30rem 15rem #0000004D;
}

.hakob-worries__bubbleBox::after {
  content: "";
  position: absolute;
  bottom: -22rem;
  width: 30rem;
  height: 30rem;
  /* background: #ffffff; */
  transform: rotate(180deg);
  border-left: 22rem solid #fff;
  border-top: 22rem solid transparent;
  border-bottom: 22rem solid transparent;
}

.hakob-worries__bubble:nth-child(odd) .hakob-worries__bubbleBox::after {
  left: 195rem;
}

.hakob-worries__bubble:nth-child(even) .hakob-worries__bubbleBox::after {
  left: 220rem;
  transform: rotate(0deg);
}

.hakob-worries__bubbleInner {
  padding: 40rem 30rem;
}

.hakob-worries__meta {
  margin-bottom: 19rem;
  text-align: center;
  font-size: 22rem;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #707070;
  font-weight: 500;
}

.hakob-worries__bubbleTitle {
  margin: 0;
  text-align: center;
  font-size: 32rem;
  line-height: 1.5;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0.01em;
}

.hakob-worries__bubbleText {
  margin: 25rem 0 0;
  text-align: center;
  font-size: 25rem;
  line-height: 1.8;
  color: #222222;
  font-weight: 400;
}

.hakob-worries__illust {
  margin: 0 auto;
  margin-top: 30rem;
  width: 350rem;
}

.hakob-worries__illust img {
  display: block;
  width: 100%;
  height: auto;
}

/* 個別位置調整 */
.hakob-worries__bubble--1 {
  transform: translateX(0);
}

.hakob-worries__bubble--2 {
  transform: unset;
}

.hakob-worries__bubble--3 {
  transform: unset;
}

.hakob-worries__bubble--4 {
  transform: unset;
}

.hakob-worries__bubble--5 {
  transform: unset;
}

.hakob-worries__bubble--6 {
  transform: unset;
}


.hakob-problems {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 30rem;
  width: 580rem;
  margin: 0 auto;
}

.hakob-problems__item {
  padding: 50rem 40rem;
  background: #B8522E;
}

.hakob-problems__item img {
  display: block;
  width: 100%;
}
.hakob-only-pc.line-text {
    display: none !important;
}
    .hakob-plan__subPrice span {
        font-size: 36rem;
    }

}

#floating-bnBox.floating-flex-bn {
  display: none!important;
}

.hakob-plan__card--sp {
  display: none;
}

@media screen and (max-width: 834px) {
  .hakob-plan__card--pc {
    display: none;
  }

  .hakob-plan__card--sp {
    display: block;
  }
}
@media screen and (min-width: 835px) {
  .hakob-plan__toggle {
    display: none;
  }

  .hakob-plan__panel {
    display: block !important;
  }
}

@media screen and (max-width: 834px) {
  .hakob-plan__cardInner {
    padding: 50rem;
  }

  .hakob-plan__head {
    display: flex;
    flex-direction: column;
  }

  .hakob-plan__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 30rem;
    width: 580rem;
    margin: 0 auto;
    margin-top: 50rem;
    padding: 0 0 30rem;
    border: 0;
    border-bottom: 2rem solid #DEDEDE;
    background: transparent;
    color: #222222;
    font-family: inherit;
    font-size: 26rem!important;
    line-height: 1!important;
    letter-spacing: 0.01em;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
  }

  .hakob-plan__toggleText {
    display: inline-block;
    color: #222222;
  }

  .hakob-plan__toggleIcon {
    position: relative;
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 13rem solid transparent;
    border-right: 13rem solid transparent;
    border-top: 17rem solid #707070;
    transform: rotate(0deg);
    transition: transform 0.25s ease;
    transform-origin: center;
  }

  .hakob-plan__card.is-open .hakob-plan__toggleIcon {
    transform: rotate(180deg);
  }

  .hakob-plan__panel {
    padding-top: 0;
    width: 580rem;
    margin: 0 auto;
  }

  .hakob-plan__list {
    margin-top: 30rem;
  }

  .hakob-plan__note {
    margin-top: 30rem;
  }
}


.hakob-hero__copyInner {margin-bottom: 180px;}
.hakob-hero__title {margin-bottom: 30px;font-size: 53px;line-height: 1.8;letter-spacing: 0;}
.hakob-hero__lead {font-size: 18px;}
.hakob-hero__lead span {font-weight: 700;}

@media screen and (min-width: 835px) and (max-width: 1199px) {
.hakob-hero__copyInner {margin-bottom: 15vw;}
.hakob-hero__title {margin-bottom: 2.5vw;font-size: 4.417vw;line-height: 1.8;letter-spacing: 0;}
.hakob-hero__lead {font-size: 1.5vw;}

}


@media screen and (max-width: 834px) {
.hakob-hero__copyInner {margin-bottom: 0;position: absolute;top: -65svh;transform: translateY(50%) translateX(20rem);}
.hakob-hero__title {margin-bottom: 53rem;font-size: 66rem;line-height: 1.8;letter-spacing: 0;}
.hakob-hero__lead {font-size: 27rem;}

}
#header {
  background: #F8F5F2!important;
}

/* ============================================================
   HAKOB MV — ローディング + ヒーローアニメーション
   (hakob-mv- prefix / 既存スタイルとの衝突回避)
   ============================================================ */

/* ─────────────────────────────────────────────────────────
   LOADER
   z-index: 1001  (#header:100, .hakob-header:1000 より前面)
   ───────────────────────────────────────────────────────── */
.hakob-mv-loader {
  position: fixed;
  inset: 0;
  z-index: 1001;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* スプリットパネル */
.hakob-mv-loader__panel {
  position: absolute;
  inset: 0;
  background: #ffffff;
  z-index: 1;
  transition: background 0.5s ease;
}
.hakob-mv-loader.draw-line .hakob-mv-loader__panel {
  background: #B8522E;
}

/* PC パネル: 35° 割れ線 */
.hakob-mv-loader__panel--tl {
  clip-path: polygon(0% 0%, 86.3% 0%, 16.3% 100%, 0% 100%);
}
.hakob-mv-loader__panel--br {
  clip-path: polygon(86.3% 0%, 100% 0%, 100% 100%, 16.3% 100%);
}

/* split: ローダー背景透明化 → 割れ線非表示 → パネル退場 */
.hakob-mv-loader.split {
  background: transparent;
}
.hakob-mv-loader.split .hakob-mv-loader__split-line {
  opacity: 0;
}
.hakob-mv-loader.split .hakob-mv-loader__panel--tl {
  animation: hakobMvSplitTL 0.65s cubic-bezier(0.77, 0, 0.175, 1) forwards;
}
.hakob-mv-loader.split .hakob-mv-loader__panel--br {
  animation: hakobMvSplitBR 0.65s cubic-bezier(0.77, 0, 0.175, 1) forwards;
}
@keyframes hakobMvSplitTL {
  to { transform: translate(-150vw, -110vh); }
}
@keyframes hakobMvSplitBR {
  to { transform: translate(150vw, 110vh); }
}

/* 割れ線 SVG */
.hakob-mv-loader__split-line {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}
.hakob-mv-loader__split-line svg {
  width: 100%;
  height: 100%;
}
.hakob-mv-loader__split-line--sp {
  display: none;
}
.hakob-mv-loader__split-line line {
  stroke-dasharray: 2200;
  stroke-dashoffset: 2200;
}
.hakob-mv-loader.draw-line .hakob-mv-loader__split-line line {
  animation: hakobMvDrawLine 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
@keyframes hakobMvDrawLine {
  to { stroke-dashoffset: 0; }
}

/* ロゴ + カウンター */
.hakob-mv-loader__center {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  pointer-events: none;
}
.hakob-mv-loader.draw-line .hakob-mv-loader__center {
  animation: hakobMvLoaderOut 0.35s ease forwards;
}
@keyframes hakobMvLoaderOut {
  to { opacity: 0; }
}
.hakob-mv-loader__logo-wrap {
  position: relative;
  width: 200px;
}
.hakob-mv-loader__logo-base {
  display: block;
  width: 100%;
  filter: brightness(0) invert(0.965);
}
.hakob-mv-loader__logo-fill-clip {
  position: absolute;
  inset: 0;
  clip-path: inset(100% 0 0 0);
}
.hakob-mv-loader__logo-fill {
  display: block;
  width: 100%;
}
.hakob-mv-loader__counter {
  font-size: 12px;
  font-weight: 300;
  letter-spacing: 0.15em;
  color: #1a1311;
  opacity: 0.4;
}

/* ─────────────────────────────────────────────────────────
   HERO 背景オーバーライド (#F8F5F2 → #F8EDE9)
   ───────────────────────────────────────────────────────── */
.hakob-hero,
.hakob-hero__bg {
  background: #F8EDE9;
}

/* ─────────────────────────────────────────────────────────
   GRADIENT OVERLAY
   delay: 1.2 + 3.0 = 4.2s
   ───────────────────────────────────────────────────────── */
.hakob-mv-gradient {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(to right, #C77559, #B8522E);
  opacity: 0;
  animation: hakobMvGradientIn 1.6s cubic-bezier(0.4, 0, 0.2, 1) 5.0s forwards;
}
@keyframes hakobMvGradientIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ─────────────────────────────────────────────────────────
   DIAGONAL LINE  PC: 35° / delay: 3.8s
   ───────────────────────────────────────────────────────── */
.hakob-mv-line {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
  transform-origin: center center;
}
.hakob-mv-line svg {
  width: 100%;
  height: 100%;
}
.hakob-mv-line--sp {
  display: none;
}
.hakob-mv-line--pc {
  animation: hakobMvLineFadePC 1.2s cubic-bezier(0.65, 0, 0.35, 1) 4.6s forwards;
}
@keyframes hakobMvLineFadePC {
  0%   { opacity: 1; transform: rotate(0deg); }
  100% { opacity: 0; transform: rotate(-35deg); }
}

/* ─────────────────────────────────────────────────────────
   SCENE SHIFT WRAPPER
   ヘッダー高さの半分だけ下にオフセット → コンテンツ領域の中央に配置
   PC: 105px / 2 = 52.5px  /  SP override: 12vw (24vw / 2)
   ───────────────────────────────────────────────────────── */
.hakob-mv-scene-shift {
  position: absolute;
  inset: 0;
  transform: translateY(52.5px);
}

/* ─────────────────────────────────────────────────────────
   MOCKUPS
   PC delay: 3.8s  /  同じく 52.5px 下にオフセット
   ───────────────────────────────────────────────────────── */
.hakob-mv-mockups {
  position: absolute;
  inset: 0;
  z-index: 3;
  transform: translateY(52.5px);
}
.hakob-mv-mockup {
  position: absolute;
  overflow: hidden;
  border-radius: 0;
  aspect-ratio: 600 / 337;
  box-shadow:
    0 16px 48px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.65);
}
.hakob-mv-mockup__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hakob-mv-mockup--left {
  left: 15.278vw;
  top: 14.568vh;
  width: 41.667vw;
  z-index: 1;
  animation: hakobMvShrinkLeft 1.8s cubic-bezier(0.65, 0, 0.35, 1) 4.6s both;
}
@keyframes hakobMvShrinkLeft {
  0%   { transform: translate(0, 0) scale(1); opacity: 1; }
  65%  { transform: translate(13.889vw, calc(35.432vh - 11.701vw)) scale(0.18); opacity: 0.4; }
  100% { transform: translate(13.889vw, calc(35.432vh - 11.701vw)) scale(0.08); opacity: 0; }
}
.hakob-mv-mockup--right {
  left: 43.056vw;
  top: 40.654vh;
  width: 41.667vw;
  z-index: 2;
  animation: hakobMvShrinkRight 1.8s cubic-bezier(0.65, 0, 0.35, 1) 4.6s both;
}
@keyframes hakobMvShrinkRight {
  0%   { transform: translate(0, 0) scale(1); opacity: 1; }
  65%  { transform: translate(-13.889vw, calc(9.346vh - 11.701vw)) scale(0.18); opacity: 0.4; }
  100% { transform: translate(-13.889vw, calc(9.346vh - 11.701vw)) scale(0.08); opacity: 0; }
}

/* ─────────────────────────────────────────────────────────
   HERO INNER レイアウト調整
   ───────────────────────────────────────────────────────── */
.hakob-hero__inner {
  justify-content: center;
}

/* ─────────────────────────────────────────────────────────
   CARD WRAP
   ───────────────────────────────────────────────────────── */
.hakob-mv-card-wrap {
  position: relative;
  width: 43.056vw;
  aspect-ratio: 620 / 365;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  overflow: visible;
  margin: 0 auto;
}

/* ─────────────────────────────────────────────────────────
   GLASS CARD  delay: 5.6s
   ───────────────────────────────────────────────────────── */
.hakob-mv-glass {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    155deg,
    rgba(255, 255, 255, 0.16) 0%,
    rgba(255, 255, 255, 0.04) 55%,
    rgba(255, 255, 255, 0.10) 100%
  );
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 3px;
  box-shadow:
    9px 9px 9px rgba(0, 0, 0, 0.3),
    inset 9px 9px 9px rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(10px) saturate(1.15);
  overflow: hidden;
  opacity: 0;
  animation: hakobMvCardIn 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) 6.4s both;
}
/* グリント: delay 8.0s */
.hakob-mv-glass::after {
  content: '';
  position: absolute;
  top: -50%;
  left: 0;
  width: 35%;
  height: 200%;
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(255, 255, 255, 0.08) 40%,
    rgba(255, 255, 255, 0.16) 50%,
    rgba(255, 255, 255, 0.08) 60%,
    transparent 100%
  );
  transform: skewX(-45deg) translateX(-250%);
  animation: hakobMvGlint 8.5s cubic-bezier(0.4, 0, 0.6, 1) 7.6s infinite;
  pointer-events: none;
}
@keyframes hakobMvGlint {
  0%    { transform: skewX(-45deg) translateX(-250%); }
  14.1% { transform: skewX(-45deg) translateX(500%); }
  100%  { transform: skewX(-45deg) translateX(500%); }
}
/* 上辺ハイライト */
.hakob-mv-glass::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent 8%,
    rgba(255, 255, 255, 0.85) 32%,
    rgba(255, 255, 255, 0.85) 68%,
    transparent 92%
  );
  border-radius: 3px 3px 0 0;
}
@keyframes hakobMvCardIn {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

/* ─────────────────────────────────────────────────────────
   COPY (タイトル / リード) オーバーライド
   ───────────────────────────────────────────────────────── */
.hakob-mv-card-wrap .hakob-hero__copy {
  position: relative;
  z-index: 2;
  width: 100vw;
  margin-bottom: 0;
}
.hakob-mv-card-wrap .hakob-hero__copyInner {
  position: static;
  transform: none;
  margin-bottom: 0;
  /* padding: 0 10%; */
  text-align: center;
}
.hakob-mv-card-wrap .hakob-hero__title {
  font-family: fot-tsukuaoldmin-pr6n, sans-serif;
  font-weight: 500;
  color: #ffffff;
  /* font-size: 3.681vw; */
  letter-spacing: 0.07em;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 0;
}
.hakob-mv-card-wrap .hakob-hero__lead {
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.90);
  /* font-size: 1.25vw; */
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: center;
  margin-top: 12px;
}

/* ─────────────────────────────────────────────────────────
   CTA オーバーライド
   ③ PC: margin-top を 1440px 時に 65px になる vw 値に設定
   ───────────────────────────────────────────────────────── */
.hakob-hero__cta.js-heroItem {
  margin-bottom: 0;
  margin-top: clamp(20px, 4.514vw, 65px); /* 4.514vw = 65px @ 1440px */
}

/* ─────────────────────────────────────────────────────────
   BUTTON / SCROLL フォント
   ───────────────────────────────────────────────────────── */
.hakob-hero .hakob-btn {
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 500;
}
.hakob-hero .hakob-hero__scroll {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
}

/* ─────────────────────────────────────────────────────────
   SP レスポンシブ (max-width: 834px)
   ───────────────────────────────────────────────────────── */
@media (max-width: 834px) {

  /* ── Loader SP ── */
  .hakob-mv-loader__logo-wrap { width: 160px; }
  .hakob-mv-loader__split-line--pc { display: none; }
  .hakob-mv-loader__split-line--sp { display: block; }
  .hakob-mv-loader__panel--tl {
    clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  }
  .hakob-mv-loader__panel--br {
    clip-path: polygon(100% 0%, 100% 100%, 0% 100%);
  }
  .hakob-mv-loader.split .hakob-mv-loader__panel--tl {
    animation: hakobMvSplitTLsp 0.65s cubic-bezier(0.77, 0, 0.175, 1) forwards;
  }
  .hakob-mv-loader.split .hakob-mv-loader__panel--br {
    animation: hakobMvSplitBRsp 0.65s cubic-bezier(0.77, 0, 0.175, 1) forwards;
  }
  @keyframes hakobMvSplitTLsp {
    to { transform: translate(-110vw, -110vh); }
  }
  @keyframes hakobMvSplitBRsp {
    to { transform: translate(110vw, 110vh); }
  }

  /* ── Diagonal line SP: 45° / delay 4.9s ── */
  .hakob-mv-line--pc { display: none; }
  .hakob-mv-line--sp {
    display: block;
    animation: hakobMvLineFadeSP 1.2s cubic-bezier(0.65, 0, 0.35, 1) 4.5s forwards;
  }
  @keyframes hakobMvLineFadeSP {
    0%   { opacity: 1; transform: rotate(0deg); }
    100% { opacity: 0; transform: rotate(-45deg); }
  }

  /* ── Mockups SP: delay 3.7s ── */
  .hakob-mv-mockup {
    aspect-ratio: 329 / 585;
  }
  .hakob-mv-mockup--left {
    left: 11.467vw;
    top: 11.394vh;
    width: 43.867vw;
    animation: hakobMvShrinkLeftSP 1.8s cubic-bezier(0.65, 0, 0.35, 1) 4.5s both;
  }
  .hakob-mv-mockup--right {
    left: 44.667vw;
    top: 38.381vh;
    width: 43.867vw;
    animation: hakobMvShrinkRightSP 1.8s cubic-bezier(0.65, 0, 0.35, 1) 4.5s both;
  }
  @keyframes hakobMvShrinkLeftSP {
    0%   { transform: translate(0, 0) scale(1); opacity: 1; }
    65%  { transform: translate(16.600vw,  calc(38.606vh - 39vw)) scale(0.18); opacity: 0.4; }
    100% { transform: translate(16.600vw,  calc(38.606vh - 39vw)) scale(0.08); opacity: 0; }
  }
  @keyframes hakobMvShrinkRightSP {
    0%   { transform: translate(0, 0) scale(1); opacity: 1; }
    65%  { transform: translate(-16.600vw, calc(11.619vh - 39vw)) scale(0.18); opacity: 0.4; }
    100% { transform: translate(-16.600vw, calc(11.619vh - 39vw)) scale(0.08); opacity: 0; }
  }

  /* ── ② SP シフト: ヘッダー(24vw)の半分 = 12vw 下にオフセット ── */
  .hakob-mv-scene-shift {
    transform: translateY(12vw);
  }
  .hakob-mv-mockups {
    transform: translateY(12vw);
  }

  /* ── Card wrap SP ── */
  .hakob-mv-card-wrap {
    width: 48.667vw;
    aspect-ratio: 365 / 625;
    gap: 16px;
  }
  .hakob-mv-card-wrap .hakob-hero__title {
    font-size: 8.8vw;
    white-space: normal;
    letter-spacing: 0.04em;
  }
  .hakob-mv-card-wrap .hakob-hero__lead {
    font-size: 3.6vw;
    line-height: 2;
    white-space: nowrap;
  }

  /* ── ④ SP: グラスカードをヘッダー〜CTAボタン間の高さセンターに配置 ── */
  /* CTA を inner 内絶対配置(bottom:70px) + padding-bottom:(70+130)=200px で
     justify-content:center がカード単体をヘッダー下〜CTA上端間の中央に置く */
  .hakob-hero__inner {
    padding-bottom: 200px;
  }
  .hakob-hero__cta.js-heroItem {
    position: absolute;
    bottom: calc(100vw / 750 * -265);
    left: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    margin-top: 0;
  }
  .hakob-hero .hakob-btn {
    width: 70vw;
  }
}