/* ============================================================
   SHARED CSS — The Travelers House
============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ================================================================
   DESIGN TOKENS
================================================================ */
:root {
  --color-bg:     #FDFFFD;
  --color-sub-bg: #E7EDE5;
  --color-dark:   #053602;
  --color-border: rgba(5,54,2,0.5);
  --color-white:  #FFFFFF;

  --font-latin:   'Poltawski Nowy', serif;
  --font-ja-bold: "MFW-HiraKakuProN-W6",'Noto Sans JP',sans-serif;
  --font-ja:      'MFW-HiraKakuProN-W3','Noto Sans JP',sans-serif;

  --fw-latin: 400;
  --fw-ja-h:  600;
  --fw-ja:    300;

  /* 欧文サイズ */
  --en-xxl-size: clamp(3.509rem, 6.234vw, 5.610rem);  --en-xxl-ls: 0.04em;
  --en-xl-size:  clamp(2.369rem, 1.974vw, 2.843rem);   --en-xl-ls:  0.04em;
  --en-l-size:   clamp(1.480rem, 1.481vw, 1.777rem);   --en-l-ls:   0.04em;
  --en-ml-size:  clamp(1.250rem, 1.211vw, 1.433rem);   --en-ml-ls:  0.04em;
  --en-m-size:   clamp(0.975rem, 0.933vw, 1.110rem);   --en-m-ls:   0.04em;
  --en-s-size:   clamp(0.825rem, 0.825vw, 0.950rem);   --en-s-ls:   0.04em;

  /* 和文サイズ */
  --ja-h-size:    1.1rem; --ja-h-ls:    0.04em; --ja-h-lh:    1.5;
  --ja-body-size: 0.975rem; --ja-body-ls: 0.04em;  --ja-body-lh: 1.8;
  --ja-sub-size:  0.875rem; --ja-sub-ls:  0.04em; --ja-sub-lh:  1.8;
  --ja-en-size:   0.875rem; --ja-en-ls:   0.04em; --ja-en-lh:   1.8;
  --ja-sm-size:   0.85rem;  --ja-sm-ls:   0.04em; --ja-sm-lh:   1.8;

  /* 矢印サイズ変数 */
  --arrow-size:   0.45em;
  --arrow-weight: 1.5px;

  /* SP ヘッダー高さ（ドロワーの padding-top に使用） */
  --header-height-sp: 8.5rem;
}

/* ── Typography Utilities ── */
.en-xxl { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-xxl-size); }
.en-xl  { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-xl-size); }
.en-l   { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-l-size);  }
.en-ml  { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-ml-size);  }
.en-m   { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-m-size); }
.en-s   { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-s-size);  }
.ja-h   { font-family: var(--font-ja-bold); font-weight: var(--fw-ja-h); font-size: var(--ja-h-size);    letter-spacing: var(--ja-h-ls);    line-height: var(--ja-h-lh); }
.ja-b   { font-family: var(--font-ja);      font-weight: var(--fw-ja);   font-size: var(--ja-body-size); letter-spacing: var(--ja-body-ls); line-height: var(--ja-body-lh); }
.ja-sub { font-family: var(--font-ja);      font-weight: var(--fw-ja);   font-size: var(--ja-sub-size);  letter-spacing: var(--ja-sub-ls);  line-height: var(--ja-sub-lh); }
.ja-en  { font-family: var(--font-ja);      font-weight: 400;            font-size: var(--ja-en-size);   letter-spacing: var(--ja-en-ls);   line-height: var(--ja-en-lh); }
.ja-sm  { font-family: var(--font-ja);      font-weight: var(--fw-ja);   font-size: var(--ja-sm-size);   letter-spacing: var(--ja-sm-ls);   line-height: var(--ja-sm-lh); }

/* ================================================================
   BASE
================================================================ */
html { font-size: clamp(14px,1.111vw,16px);}
body { background: var(--color-bg); color: var(--color-dark); font-family: var(--font-ja); -webkit-font-smoothing: antialiased; }
img  { max-width: 100%; height: auto; }
a    { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

.skip-link { position: absolute; top: -3rem; left: 1rem; background: var(--color-dark); color: var(--color-white); padding: .5rem 1rem; font-family: var(--font-latin); font-size: var(--en-s-size); border-radius: 0 0 4px 4px; z-index: 999; transition: top .2s; }
.skip-link:focus { top: 0; }

.container { width: 100%; padding: 0 clamp(3rem, 5vw, 5rem); }

@media (max-width:768px) { .container { width: 90%; margin-inline: auto; padding-inline: 0; } }

@media (min-width: 769px) { .pc-none{display: none;}}

button:focus,
a:focus {
  outline: none;
}

@media screen and (min-width: 1025px) and (any-hover: hover) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

/* ================================================================
   CSS ARROWS
================================================================ */
.btn--primary::after,
.btn--outline::after {
  content: '';
  display: inline-block;
  flex-shrink: 0;
  width: var(--arrow-size);
  height: var(--arrow-size);
  border-right: var(--arrow-weight) solid currentColor;
  border-top: var(--arrow-weight) solid currentColor;
  transform: rotate(45deg);
}
.link--arrow::after {
  content: '';
  display: inline-block;
  flex-shrink: 0;
  width: 0.4em;
  height: 0.4em;
  border-right: 1.2px solid currentColor;
  border-top: 1.2px solid currentColor;
  transform: rotate(45deg);
}
.topics-item__arrow::after {
  content: '';
  display: inline-block;
  width: 0.38em;
  height: 0.38em;
  border-right: 1.2px solid currentColor;
  border-top: 1.2px solid currentColor;
  transform: rotate(45deg) translate(-0.06em, 0.06em);
  transition: transform .2s ease;
}
.topics-item:hover .topics-item__arrow::after { transform: rotate(45deg) translate(0.06em, 0.06em); }
.pagination__arrow::after {
  content: '';
  display: inline-block;
  width: 0.5em;
  height: 0.5em;
  border-right: var(--arrow-weight) solid currentColor;
  border-top: var(--arrow-weight) solid currentColor;
  transform: rotate(45deg);
}

/* ================================================================
   BUTTONS
================================================================ */
.btn--primary {
  display: inline-flex; align-items: center; gap: .5em;
  height: 3rem; padding-inline: 1.8em;
  background: var(--color-dark); color: var(--color-white);
  border-radius: 100px; font-family: var(--font-latin); font-weight: var(--fw-latin);
  font-size: var(--en-m-size); letter-spacing: var(--en-m-ls);
  transition: opacity .2s; white-space: nowrap; border: none; cursor: pointer;
}
.btn--primary:hover, .btn--primary:focus-visible { opacity: .75; }

.btn--outline {
  display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  padding: 1.5em 1.1em; text-align: center;
  background: transparent; color: var(--color-dark);
  border: 1px solid var(--color-border); border-radius: 100px;
  font-family: var(--font-latin); font-weight: var(--fw-latin);
  font-size: var(--en-s-size); letter-spacing: var(--ja-h-ls);
  transition: background-color .2s, color .2s; cursor: pointer; white-space: nowrap;
}
.btn--outline:hover, .btn--outline:focus-visible { background: var(--color-dark); color: var(--color-white); }

/* ================================================================
   HEADER
================================================================ */
.site-header { position: sticky; top: 0; z-index: 300; }
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 3rem 0 0.5rem 0;
}
.site-logo { display: flex; align-items: center; position: relative; z-index: 9999;}
.site-logo__img { width: clamp(190px,20vw,270px); height: auto; }

/* ================================================================
   統合ナビゲーション（.site-nav）
================================================================ */

/* PC デフォルト: インライン横並び */
.site-nav {
  flex: 1;
  display: flex; align-items: center;
  justify-content: flex-end;
  gap: clamp(1rem, 2.6vw, 3rem);
}
.site-nav .site-nav__list {
  display: flex; align-items: center;
  gap: clamp(.5rem,1.2vw,1.25rem);
}
.site-nav .site-nav__list a {
  font-family: var(--font-latin); font-weight: var(--fw-latin);
  font-size: clamp(0.9rem,1.1vw,1.2rem); letter-spacing: var(--ja-h-ls);
  color: var(--color-dark); transition: opacity .2s;
}
.site-nav .site-nav__list a:hover { opacity: .5; }
.site-nav__cta-pc { font-size: clamp(.8125rem,.902vw,.9375rem) !important; }

/* PC: SP 専用要素を非表示 */
.site-nav__drawer-cta,
.site-nav__drawer-follow,
.site-nav__drawer-tel,
.site-nav .sub-link { display: none; }

/* SP コントロール（PC 非表示） */
.header-controls { display: none; align-items: center; gap: .5rem; flex-shrink: 0; }
.btn--sp-bridal { font-size: var(--en-s-size) !important; height: 3rem !important; padding-inline: 1.3em !important; }

/* sub-link 共通（footer でも使用） */
.sub-link {
  display: none;
  justify-content: flex-end;
  gap: 2em;
  font-family: var(--font-ja);
  font-size: var(--ja-sm-size);
}
footer .sub-link { display: flex; margin: 1em 0 -1.5em 0; }

.sub-link li a {
  display: inline-flex;
  align-items: center;
  gap: 0.8em;
  text-decoration: none;
  transition: opacity .2s;
}
.sub-link li a::after {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-top: 1px solid var(--color-dark);
  border-right: 1px solid var(--color-dark);
  transform: rotate(45deg);
  flex-shrink: 0;
}
.sub-link li a:hover {
  opacity: .55;
}

/* ================================================================
   ハンバーガー → ✕ アニメーション
================================================================ */
.nav-toggle {
  background: none; border: 1px solid var(--color-border); border-radius: 50%;
  width: 3rem; height: 3rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background-color .2s; flex-shrink: 0;
  z-index: 9999;
}

.hamburger { display: flex; flex-direction: column; gap: 4px; }
.icon-bar {
  display: block; width: 16px; height: 1.5px; background: var(--color-dark);
  transition: transform .35s cubic-bezier(0.4, 0, 0.2, 1), opacity .25s ease;
  transform-origin: center;
}
.nav-toggle[aria-expanded="true"] .icon-bar:nth-child(1) { transform: translateY(5.5px)  rotate(25deg);  }
.nav-toggle[aria-expanded="true"] .icon-bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle[aria-expanded="true"] .icon-bar:nth-child(3) { transform: translateY(-5.5px) rotate(-25deg); }

@media (max-width:768px) {
  /* ヘッダー側: SP コントロールを表示 */
  .header-controls { display: flex; }
  .btn--sp-bridal::after { display: none; }

  .site-nav {
    display: flex;
    position: fixed; inset: 0; z-index: 200;
    background: var(--color-bg); overflow-y: auto;
    padding: var(--header-height-sp) 5% 1.5rem 5%;
    flex-direction: column; align-items: stretch;
    justify-content: flex-start; gap: 1.8rem;
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity .5s cubic-bezier(0.16,1,0.3,1), visibility .5s cubic-bezier(0.16,1,0.3,1);
    font-family: var(--font-latin);
  }
  .site-nav.is-open { opacity: 1; visibility: visible; pointer-events: auto; }

  /* フェードイン（子要素数: 6 / 4番目の .site-nav__cta-pc は SP で非表示） */
  .site-nav > * { opacity: 0; transform: translateY(-14px); transition: opacity .4s ease, transform .4s ease; }
  .site-nav.is-open > *:nth-child(1) { opacity:1; transform:none; transition-delay:.07s; }
  .site-nav.is-open > *:nth-child(2) { opacity:1; transform:none; transition-delay:.14s; }
  .site-nav.is-open > *:nth-child(3) { opacity:1; transform:none; transition-delay:.21s; }
  .site-nav.is-open > *:nth-child(5) { opacity:1; transform:none; transition-delay:.28s; }
  .site-nav.is-open > *:nth-child(6) { opacity:1; transform:none; transition-delay:.35s; }

  /* SP: SP 専用要素を表示 */
  .site-nav__drawer-cta { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
  .site-nav__drawer-cta .btn--primary {
    justify-content: center; height: 3.5rem !important; padding-inline: 1.25em !important;
    font-family: var(--font-ja); letter-spacing: var(--ja-h-ls); font-size: var(--ja-sm-size);
  }

  /* SP: PC 専用 CTA を非表示 */
  .site-nav__cta-pc { display: none !important; }

  /* ナビリスト（SP レイアウト） */
  .site-nav .site-nav__list { display: grid; grid-template-columns: 1fr 1fr; gap: 0 2em; }
  .site-nav .site-nav__list li { padding: 1rem 0; }
  .site-nav .site-nav__list a { font-size: var(--en-m-size) !important; letter-spacing: var(--en-m-ls) !important; }

  /* sub-link */
  .site-nav .sub-link { display: flex; margin-top: -1em; font-size: var(--ja-body-size); position: relative; top: 20px;}
  footer .sub-link { margin: 3em 0; justify-content: center;order: 3;}

  /* follow */
  .site-nav__drawer-follow { display: flex; align-items: center; gap: .75rem; position: relative; top: -27px; width: fit-content;}
  .site-nav__follow-label { font-family: var(--font-latin); font-size: var(--en-s-size); letter-spacing: var(--en-s-ls); color: var(--color-border); }

  /* tel */
  .site-nav__drawer-tel { display: flex; flex-direction: column; gap: .5rem; }
  .site-nav__tel-btn { width: 100%; text-align: center; font-family: var(--font-latin) !important; font-size: var(--en-m-size) !important; letter-spacing: var(--en-m-ls) !important; }
  .site-nav__tel-hours p { font-family: var(--font-ja); font-weight: var(--fw-ja); font-size: var(--ja-sm-size); letter-spacing: var(--ja-sm-ls); line-height: var(--ja-sm-lh); text-align: center; }
}

/* ================================================================
   PAGE INTRO
================================================================ */
.page-intro { padding-block: clamp(3rem,5vw,4.5rem); }
.page-intro__title { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-xl-size);  line-height: 1.15; margin-bottom: .4rem; }
.page-intro__subtitle { font-family: var(--font-ja); font-weight: var(--fw-ja); font-size: var(--ja-body-size); }

/* ================================================================
   GALLERY STRIP
================================================================ */
.gallery-strip {
  overflow-x: clip;     
  overflow-y: visible; 
}
.gallery-strip__track {
  display: flex;
  align-items: flex-end;
  width: max-content;
  padding: 5em 0;  
  animation: gallery-scroll 100s linear infinite;
  will-change: transform;
}
@keyframes gallery-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.gallery-strip__item { flex-shrink: 0; overflow: hidden; background: var(--color-sub-bg); margin-right: 4em; }
.gallery-strip__item--a { width: 19vw; aspect-ratio: 3/2; align-self: center;}
.gallery-strip__item--b { width: 14vw; aspect-ratio: 3/2; align-self: flex-end;}
.gallery-strip__item--c { width: 9vw; aspect-ratio: 3/4; align-self: flex-start;}
.gallery-strip__item--d { width: 22vw; aspect-ratio: 3/2; align-self: flex-end;  position: relative;  bottom: -4em;}
.gallery-strip__item--c:nth-child(4n) {position: relative; top: 5.3em;}
.gallery-strip__item--d:nth-child(4n) {position: relative; bottom: -1.3em;}
.gallery-strip__img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width:768px) {
  .gallery-strip__item--a { width: 150px; }
  .gallery-strip__item--b { width: 200px;}
  .gallery-strip__item--c { width: 120px; }
  .gallery-strip__item--d { width: 200px;}
}



/* ================================================================
   FOOTER
================================================================ */
.site-footer { background: var(--color-bg);  padding-block: clamp(3.5rem, 10vw, 8rem); }
.site-footer__inner { display: flex; align-items: flex-start; gap: clamp(2rem,10vw,6rem); justify-content: space-between; align-items: flex-end;}
.site-footer__brand { display: flex; flex-direction: column; gap: 1.5rem; }
.site-footer__logo-img { width: clamp(100px,36vw,350px); height: auto; }
.site-footer__cta-list { display: flex; gap: .5rem; margin-top: 0.5em;}
.site-footer__cta-list .btn--outline { padding: 0.8em 1em; font-family: var(--font-ja);}
.site-footer__nav-list { display: flex; flex-wrap: wrap; gap: .5rem 1.5rem; margin-bottom: 1.5rem; }
.site-footer__nav-list a { font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--en-m-size); letter-spacing: var(--en-m-ls); transition: opacity .2s; }
.site-footer__nav-list a::after { display: none; }
.site-footer__nav-list a:hover { opacity: .55; }
.site-footer__follow { display: flex; align-items: center; gap: .625rem; margin-bottom:2.5rem; }
.site-footer__follow-label { font-family: var(--font-latin); font-size: var(--en-s-size); letter-spacing: var(--en-s-ls); color: var(--color-border);}
.site-footer__follow-link { display: flex; align-items: center; gap: .375rem; font-family: var(--font-latin); font-size: var(--ja-en-size); letter-spacing: var(--ja-en-ls);  }
.site-footer__follow-link::after { display: none; }
.site-footer__copyright { color:#666; font-size: var(--en-s-size);  letter-spacing: var(--ja-h-ls);}

@media (max-width:768px) {
  .site-footer { padding-block: 2.5rem 3rem; }
  .site-footer__inner { flex-direction: column; align-items: stretch; gap: 0; }
  .site-footer__brand { gap: 1.75rem; padding:5rem 0 2rem 0; }
  .site-footer__logo-img { width: clamp(180px,60vw,280px); margin:0 auto;}
  .site-footer__cta-list { flex-direction: row; flex-wrap: nowrap; gap: .5rem; }
  .site-footer__cta-list .btn--outline { flex: 1; min-width: 0; justify-content: center; gap: .3em; font-size: var(--en-s-size); letter-spacing: 0.06em; padding-inline: .6em; }
  .site-footer__nav {padding:0 1.5rem;  display: flex;  flex-direction: column;}
  .site-footer__nav-list { display: grid; grid-template-columns: repeat(3, auto); grid-auto-flow: column; grid-template-rows: repeat(4, auto); column-gap: clamp(1.5rem,6vw,3rem); row-gap: 0; margin-bottom: 0; }
  .site-footer__nav-list li { padding-block:1rem; }
  .site-footer__follow { margin-top: 2.5rem; margin-bottom: 0; order: 2;}
  .site-footer__follow-label { font-size: var(--en-s-size); opacity: .6; }
  .site-footer__follow-link { font-size: var(--en-m-size); }
  .site-footer__copyright { margin-top: 5rem; text-align: center; display: block; order: 3;}
  .site-footer__follow-insta{ text-decoration: underline; text-underline-offset: 2px;}
}
@media (min-width:769px) {
.site-footer__follow-insta{display: none;}
}
/* ================================================================
   ANIMATIONS — Wedding Scroll Reveal
================================================================ */

/* ── キーフレーム ── */
@keyframes fade-up-in {
  from { opacity: 0; transform: translateY(28px); filter: blur(15px); }
  to   { opacity: 1; transform: translateY(0); filter: blur(0); }
}

/* ── ページロード: page-intro（above the fold のため JS 不要） ── */
.page-intro__title {
  animation: fade-up-in 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation-delay: 0.05s;
}
.page-intro__subtitle {
  animation: fade-up-in 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation-delay: 0.25s;
}

/* ── スクロールリビール基底（JS が .is-visible を付与） ── */
/* .anim-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity  0.75s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 0.75s cubic-bezier(0.25, 0.46, 0.45, 0.94);
} */
.anim-reveal {
  opacity: 0;
  transform: none;
  transition: opacity 0.75s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.anim-reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* フェードのみ（ヒーロー画像など） */
.anim-fade {
  opacity: 0;
  transition: opacity 1.1s ease;
}
.anim-fade.is-visible {
  opacity: 1;
}

/* スタッガー遅延 — グリッドカード・リストアイテム等 */
.anim-reveal[data-delay="1"] { transition-delay: 0.08s; }
.anim-reveal[data-delay="2"] { transition-delay: 0.18s; }
.anim-reveal[data-delay="3"] { transition-delay: 0.28s; }
.anim-reveal[data-delay="4"] { transition-delay: 0.38s; }

/* ギャラリーストリップ: ページロード時にふんわり出現 */
.gallery-strip {
  animation: fade-up-in 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation-delay: 0.4s;
}

/* モーション軽減環境では全アニメーション無効 */
@media (prefers-reduced-motion: reduce) {
  .page-intro__title,
  .page-intro__subtitle,
  .gallery-strip         { animation: none; }
  .anim-reveal           { opacity: 1; transform: none; transition: none; }
  .anim-fade             { opacity: 1; transition: none; }
}

/* ================================================================
   WED-ANIM — Top ページ スクロールリビール（JS が .wed-is-visible を付与）
================================================================ */
.wed-anim {
  opacity: 0;
  transform: translateY(22px);
  filter: blur(15px);
  transition:
    opacity  0.85s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 0.85s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    filter 0.85s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: opacity, transform;
}
.wed-anim-img {
  opacity: 0;
  filter: blur(15px);
  transform: scale(0.95);
  transition:
    opacity   1.2s cubic-bezier(0.4, 0, 0.2, 1),
    filter    1.2s cubic-bezier(0.4, 0, 0.2, 1),
    transform 1.2s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity, filter, transform;
}
.wed-is-visible { opacity: 1 !important; filter: blur(0) !important; transform: none !important; }

[data-wd="1"] { transition-delay: 0.10s !important; }
[data-wd="2"] { transition-delay: 0.22s !important; }
[data-wd="3"] { transition-delay: 0.34s !important; }

@media (prefers-reduced-motion: reduce) {
  .wed-anim,
  .wed-anim-img { opacity: 1 !important; filter: blur(0) !important; transform: none !important; transition: none !important; }
}

/* ================================================================
   OD-ANIM — About ページ One Day スクロールリビール（JS が .od-is-visible を付与）
================================================================ */
.od-anim {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity  0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: opacity, transform;
}
.od-anim-img {
  opacity: 0;
  transform: scale(1.05);
  transition:
    opacity  1.1s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 1.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: opacity, transform;
}
.od-is-visible { opacity: 1 !important; transform: none !important; }

[data-od-d="1"] { transition-delay: 0.10s !important; }
[data-od-d="2"] { transition-delay: 0.22s !important; }
[data-od-d="3"] { transition-delay: 0.34s !important; }
[data-od-d="4"] { transition-delay: 0.46s !important; }
[data-od-d="5"] { transition-delay: 0.58s !important; }

@media (prefers-reduced-motion: reduce) {
  .od-anim,
  .od-anim-img { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ================================================================
   PAGINATION
================================================================ */
.pagination { display: flex; align-items: center; justify-content: center; padding-block: clamp(2rem,3vw,3rem); }
.pagination ol { display: flex; align-items: center; gap: .25rem; }
.pagination__item { display: inline-flex; align-items: center; justify-content: center; width: 2rem; height: 2rem; font-family: var(--font-latin); font-weight: var(--fw-latin); font-size: var(--ja-en-size); letter-spacing: var(--ja-en-ls); border-radius: 2px; transition: background-color .15s; }
.pagination__item:hover { background: var(--color-sub-bg); }
.pagination__item[aria-current="page"] { font-weight: 700; border-bottom: 1.5px solid var(--color-dark); }
.pagination__arrow { display: inline-flex; align-items: center; justify-content: center; width: 2rem; height: 2rem; transition: opacity .2s; }
.pagination__arrow:hover { opacity: .5; }
pagination__arrow:hover { opacity: .5; }
