/*
Theme Name: 月城苑 WordPress Theme
Theme URI: https://getsujoen.jp/
Author: WEBEE LAB.
Description: 月城苑公式サイト用のオリジナルWordPressテーマ。お品書き管理、新着情報、オリーブ牛ページ対応。
Version: 1.2.5
Text Domain: getsujoen
*/


      :root {
        --ivory: #faf8f2;
        --ivory-warm: #f3ede2;
        --cream: #eae2d4;
        --white: #fffdf8;
        --gold: #b08840;
        --gold-light: #c9a050;
        --gold-pale: #dfc88e;
        --brown-deep: #3a2210;
        --brown: #5a3a28;
        --brown-medium: #785a48;
        --enji: #8b2500;
        --charcoal: #2e2218;
        --text-primary: #2a1a10;
        --text-secondary: #5a4838;
        --text-light: #887868;
        --text-on-dark: #faf8f2;
        --border-light: #dcd2c4;
        --border-gold: rgba(176, 136, 64, 0.24);
        --shadow-soft: 0 12px 40px rgba(58, 34, 16, 0.06);
        --font-display: "Zen Old Mincho", "Noto Serif JP", serif;
        --font-heading: "Shippori Mincho", "Noto Serif JP", serif;
        --font-body: "Noto Serif JP", serif;
        --section-pad: 100px 0;
        --max-w: 1140px;
      }

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

      html {
        scroll-behavior: smooth;
        font-size: 16px;
      }

      body {
        margin: 0;
        font-family: var(--font-body);
        color: var(--text-primary);
        background: var(--ivory);
        line-height: 1.95;
        -webkit-font-smoothing: antialiased;
        overflow-x: hidden;
      }

      img {
        max-width: 100%;
        display: block;
      }

      a {
        color: inherit;
        text-decoration: none;
      }

      .ctn {
        width: min(var(--max-w), calc(100% - 48px));
        margin: 0 auto;
      }

      .sl {
        font-family: var(--font-display);
        font-size: 0.72rem;
        letter-spacing: 0.34em;
        color: var(--gold);
        text-transform: uppercase;
        margin: 0 0 8px;
      }

      .sh {
        margin: 0 0 14px;
        font-family: var(--font-display);
        font-size: clamp(1.45rem, 2.4vw, 2.05rem);
        line-height: 1.45;
        letter-spacing: 0.08em;
        color: var(--brown-deep);
      }

      .sd {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 14px;
        margin: 0 0 28px;
      }

      .sd::before,
      .sd::after {
        content: "";
        width: 38px;
        height: 1px;
        background: var(--gold);
      }

      .sp {
        margin: 0 auto;
        max-width: 760px;
        font-size: 0.96rem;
        color: var(--text-secondary);
      }

      .fi {
        opacity: 0;
        transform: translateY(18px);
        transition:
          opacity 0.8s ease,
          transform 0.8s ease;
      }

      .fi.v,
      .fi.show {
        opacity: 1;
        transform: translateY(0);
      }

      .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        padding: 15px 34px;
        border: none;
        cursor: pointer;
        font-family: var(--font-heading);
        font-size: 0.88rem;
        letter-spacing: 0.1em;
        transition: all 0.3s ease;
      }

      .btn-g {
        background: var(--gold);
        color: var(--white);
      }

      .btn-g:hover {
        transform: translateY(-1px);
        background: var(--gold-light);
        box-shadow: 0 8px 24px rgba(176, 136, 64, 0.24);
      }

      .btn-o {
        background: transparent;
        color: var(--gold);
        border: 1px solid var(--gold);
      }

      .btn-o:hover {
        background: var(--gold);
        color: var(--white);
      }

      .btn-ol {
        background: transparent;
        color: var(--gold-pale);
        border: 1px solid var(--gold-pale);
      }

      .btn-ol:hover {
        background: rgba(223, 200, 142, 0.16);
      }

      .hd {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 1000;
        background: transparent;
        transition:
          background 0.35s ease,
          box-shadow 0.35s ease;
      }

      .hd.sc {
        background: rgba(250, 248, 242, 0.97);
        backdrop-filter: blur(12px);
        box-shadow: 0 1px 18px rgba(58, 34, 16, 0.08);
      }

      .hd-in {
        width: min(var(--max-w), calc(100% - 48px));
        margin: 0 auto;
        padding: 16px 0;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 18px;
        transition: padding 0.35s ease;
      }

      .hd.sc .hd-in {
        padding: 10px 0;
      }

      .logo {
        display: flex;
        flex-direction: column;
      }

      .logo-m {
        font-family: var(--font-display);
        font-size: 1.45rem;
        letter-spacing: 0.14em;
        color: var(--white);
        transition: color 0.35s ease;
      }

      .logo-s {
        margin-top: 2px;
        font-family: var(--font-heading);
        font-size: 0.6rem;
        letter-spacing: 0.18em;
        color: var(--gold-light);
      }

      .hd.sc .logo-m {
        color: var(--brown-deep);
      }

      .nd {
        display: flex;
        align-items: center;
        gap: 18px;
      }

      .nd a {
        position: relative;
        padding-bottom: 4px;
        font-family: var(--font-heading);
        font-size: 0.78rem;
        letter-spacing: 0.06em;
        color: var(--white);
        transition: color 0.35s ease;
      }

      .nd a::after {
        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        width: 0;
        height: 1px;
        background: var(--gold);
        transition: width 0.3s ease;
      }

      .nd a:hover::after {
        width: 100%;
      }

      .hd.sc .nd a {
        color: var(--text-secondary);
      }

      .hd-cta {
        display: flex;
        align-items: center;
        gap: 12px;
      }

      .hd-tel {
        font-family: var(--font-heading);
        font-size: 0.78rem;
        color: var(--gold-light);
      }

      .hd.sc .hd-tel {
        color: var(--gold);
      }

      .hd-rsv {
        padding: 9px 18px;
        border: 1px solid var(--gold);
        font-family: var(--font-heading);
        font-size: 0.78rem;
        letter-spacing: 0.08em;
        color: var(--gold-light);
      }

      .hd.sc .hd-rsv {
        color: var(--gold);
      }

      .hd-rsv:hover {
        background: var(--gold);
        color: var(--white);
      }

      .hb {
        display: none;
        flex-direction: column;
        gap: 5px;
        padding: 8px;
        background: none;
        border: none;
        cursor: pointer;
      }

      .hb span {
        width: 22px;
        height: 1.5px;
        background: var(--white);
        transition:
          transform 0.3s ease,
          opacity 0.3s ease,
          background 0.3s ease;
      }

      .hd.sc .hb span {
        background: var(--brown-deep);
      }

      .hb.act span:nth-child(1) {
        transform: rotate(45deg) translate(5px, 5px);
        background: var(--brown-deep);
      }

      .hb.act span:nth-child(2) {
        opacity: 0;
      }

      .hb.act span:nth-child(3) {
        transform: rotate(-45deg) translate(5px, -5px);
        background: var(--brown-deep);
      }

      .nm {
        position: fixed;
        inset: 0;
        display: none;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 24px;
        background: rgba(250, 248, 242, 0.98);
        backdrop-filter: blur(16px);
        z-index: 999;
      }

      .nm.open {
        display: flex;
      }

      .nm a {
        font-family: var(--font-display);
        font-size: 1.04rem;
        color: var(--brown-deep);
        letter-spacing: 0.12em;
      }

      .mc {
        display: flex;
        flex-direction: column;
        gap: 12px;
        margin-top: 12px;
        align-items: center;
      }

      .mc-t,
      .mc-r {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 240px;
        padding: 12px 28px;
        font-family: var(--font-heading);
        font-size: 0.95rem;
      }

      .mc-t {
        color: var(--gold);
        border: 1px solid var(--gold);
      }

      .mc-r {
        background: var(--gold);
        color: var(--white);
      }

      .hero {
        position: relative;
        min-height: 100vh;
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
      }

      .hero-bg {
        position: absolute;
        inset: 0;
        z-index: 0;
        background: url("./images/hero-poster.webp") center/cover no-repeat;
        filter: brightness(0.42);
        transform: scale(1.02);
      }

      .hero-video {
        position: absolute;
        inset: 0;
        z-index: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        filter: brightness(0.46);
        transform: scale(1.02);
      }

      .hero-ov {
        position: absolute;
        inset: 0;
        z-index: 1;
        background:
          linear-gradient(90deg, rgba(42, 26, 16, 0.72) 0%, rgba(42, 26, 16, 0.36) 48%, rgba(42, 26, 16, 0.12) 100%),
          linear-gradient(180deg, rgba(42, 26, 16, 0.16) 0%, rgba(42, 26, 16, 0.48) 60%, rgba(42, 26, 16, 0.76) 100%);
      }

      .hero-ct {
        position: relative;
        z-index: 2;
        max-width: 860px;
        padding: 0 24px;
        text-align: center;
      }

      .hero-kk,
      .hero h1,
      .hero-rl,
      .hero-c,
      .hero-s,
      .hero-cta,
      .hero-sc {
        opacity: 0;
        animation: fu 0.9s ease forwards;
      }

      .hero-kk {
        font-family: var(--font-heading);
        font-size: 0.74rem;
        letter-spacing: 0.34em;
        color: var(--gold-pale);
        margin: 0 0 20px;
        animation-delay: 0.25s;
      }

      .hero h1 {
        margin: 0;
        font-family: var(--font-display);
        font-size: clamp(2.35rem, 7vw, 4.6rem);
        line-height: 1.32;
        letter-spacing: 0.18em;
        color: var(--white);
        animation-delay: 0.45s;
      }

      .hero-rl {
        width: 72px;
        height: 1px;
        margin: 18px auto;
        background: linear-gradient(90deg, transparent, var(--gold), transparent);
        animation-delay: 0.62s;
      }

      .hero-c {
        margin: 0 auto 10px;
        max-width: 760px;
        font-family: var(--font-heading);
        font-size: clamp(1rem, 2vw, 1.14rem);
        line-height: 2;
        letter-spacing: 0.08em;
        color: var(--ivory-warm);
        animation-delay: 0.78s;
      }

      .hero-s {
        margin: 0 auto 34px;
        max-width: 700px;
        font-family: var(--font-heading);
        font-size: 0.84rem;
        line-height: 1.95;
        letter-spacing: 0.06em;
        color: var(--gold-pale);
        animation-delay: 0.92s;
      }

      .hero-cta {
        display: flex;
        justify-content: center;
        gap: 14px;
        flex-wrap: wrap;
        animation-delay: 1.08s;
      }

      .hero-sc {
        position: absolute;
        left: 50%;
        bottom: 28px;
        transform: translateX(-50%);
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 6px;
        z-index: 2;
        animation-delay: 1.24s;
      }

      .hero-sc span {
        font-family: var(--font-heading);
        font-size: 0.6rem;
        letter-spacing: 0.2em;
        color: var(--gold-pale);
      }

      .hero-sc-l {
        width: 1px;
        height: 36px;
        background: var(--gold-pale);
        animation: sp 2s ease infinite;
      }

      @keyframes fu {
        from {
          opacity: 0;
          transform: translateY(18px);
        }
        to {
          opacity: 1;
          transform: translateY(0);
        }
      }

      @keyframes sp {
        0%,
        100% {
          opacity: 0.3;
          transform: scaleY(0.6);
        }
        50% {
          opacity: 1;
          transform: scaleY(1);
        }
      }

      .about,
      .specialty,
      .recommend,
      .faq,
      .reserve,
      .access {
        padding: var(--section-pad);
      }

      .owner,
      .menu,
      .interior {
        padding: var(--section-pad);
        position: relative;
      }

      .about {
        background: var(--ivory);
      }

      .about-media {
        display: grid;
        grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
        gap: clamp(22px, 3.4vw, 42px);
        align-items: stretch;
        margin: -8px 0 50px;
      }

      .about-media-main,
      .about-media-sub {
        margin: 0;
        overflow: hidden;
        border: 1px solid var(--border-light);
        background: var(--cream);
      }

      .about-media-main {
        min-height: 520px;
        box-shadow: 0 24px 70px rgba(58, 34, 16, 0.11);
      }

      .about-media-main img,
      .about-media-sub img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 1.05s cubic-bezier(0.22, 0.8, 0.28, 1);
      }

      .about-media:hover img {
        transform: scale(1.045);
      }

      .about-media-panel {
        position: relative;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 22px;
        padding: clamp(28px, 4vw, 46px);
        background: rgba(255, 253, 248, 0.92);
        border: 1px solid var(--border-light);
        box-shadow: var(--shadow-soft);
      }

      .about-media-panel::before {
        content: "";
        position: absolute;
        inset: 14px;
        border: 1px solid rgba(176, 136, 64, 0.18);
        pointer-events: none;
      }

      .about-media-label {
        position: relative;
        z-index: 1;
        margin: 0;
        font-family: var(--font-display);
        font-size: 0.72rem;
        letter-spacing: 0.28em;
        color: var(--gold);
      }

      .about-media-panel h3 {
        position: relative;
        z-index: 1;
        margin: 0;
        font-family: var(--font-display);
        font-size: clamp(1.24rem, 2vw, 1.68rem);
        line-height: 1.58;
        letter-spacing: 0.08em;
        color: var(--brown-deep);
      }

      .about-media-panel p:not(.about-media-label) {
        position: relative;
        z-index: 1;
        margin: 0;
        color: var(--text-secondary);
        font-size: 0.94rem;
        line-height: 2.05;
      }

      .about-media-sub {
        position: relative;
        z-index: 1;
        aspect-ratio: 16 / 10;
        box-shadow: 0 14px 40px rgba(58, 34, 16, 0.08);
      }

      .about-hd,
      .specialty-hd,
      .scene-hd,
      .recommend-hd,
      .menu-hd,
      .interior-hd,
      .faq-hd,
      .reserve-hd,
      .access-hd {
        text-align: center;
        margin-bottom: 58px;
      }

      .about-g,
      .specialty-g {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 26px;
      }

      .about-c,
      .specialty-c {
        padding: 34px 30px;
        background: var(--white);
        border: 1px solid var(--border-light);
        box-shadow: 0 2px 10px rgba(58, 34, 16, 0.02);
        transition:
          transform 0.3s ease,
          box-shadow 0.3s ease;
      }

      .about-c:hover,
      .specialty-c:hover,
      .scene-c:hover,
      .recommend-c:hover,
      .menu-card:hover {
        transform: translateY(-3px);
        box-shadow: var(--shadow-soft);
      }

      .about-c-n,
      .specialty-c-n {
        margin: 0 0 12px;
        font-family: var(--font-display);
        font-size: 0.68rem;
        letter-spacing: 0.28em;
        color: var(--gold);
      }

      .about-c-l,
      .specialty-c-l {
        width: 36px;
        height: 1px;
        background: var(--gold);
        margin-bottom: 14px;
      }

      .about-c h3,
      .specialty-c h3 {
        margin: 0 0 12px;
        font-family: var(--font-display);
        font-size: 1.14rem;
        letter-spacing: 0.06em;
        color: var(--brown-deep);
      }

      .about-c p,
      .specialty-c p,
      .scene-c p,
      .recommend-c p,
      .owner-tx p,
      .reserve-box p,
      .access-copy p {
        margin: 0;
        font-size: 0.88rem;
        color: var(--text-secondary);
      }

      .specialty {
        background: var(--ivory-warm);
      }

      .specialty-parallax {
        position: relative;
        isolation: isolate;
        overflow: hidden;
        background:
          linear-gradient(180deg, rgba(58, 34, 16, 0.74), rgba(58, 34, 16, 0.86)),
          url("./images/yakiniku-01.webp") center / cover fixed no-repeat;
      }

      .specialty-parallax::before {
        content: "";
        position: absolute;
        inset: 0;
        z-index: -1;
        background:
          radial-gradient(circle at 18% 18%, rgba(176, 136, 64, 0.26), transparent 34%),
          radial-gradient(circle at 84% 78%, rgba(250, 248, 242, 0.1), transparent 30%);
        pointer-events: none;
      }

      .specialty-parallax::after {
        content: "";
        position: absolute;
        inset: 0;
        z-index: -1;
        background-image: linear-gradient(rgba(250, 248, 242, 0.045) 1px, transparent 1px), linear-gradient(90deg, rgba(250, 248, 242, 0.045) 1px, transparent 1px);
        background-size: 72px 72px;
        -webkit-mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
        mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
        pointer-events: none;
      }

      .specialty-parallax .specialty-hd {
        position: relative;
        z-index: 1;
      }

      .specialty-parallax .sl,
      .specialty-parallax .sh,
      .specialty-parallax .sp {
        color: var(--text-on-dark);
        text-shadow: 0 2px 18px rgba(0, 0, 0, 0.2);
      }

      .specialty-parallax .sl {
        color: var(--gold-pale);
      }

      .specialty-parallax .sd::before,
      .specialty-parallax .sd::after {
        background: var(--gold-pale);
      }

      .specialty-parallax .specialty-g {
        position: relative;
        z-index: 1;
      }

      .specialty-parallax .specialty-c {
        background: rgba(255, 253, 248, 0.9);
        border-color: rgba(223, 200, 142, 0.38);
        box-shadow: 0 18px 48px rgba(22, 12, 6, 0.18);
        -webkit-backdrop-filter: blur(8px);
        backdrop-filter: blur(8px);
      }

      .specialty-parallax .specialty-c:hover {
        border-color: rgba(223, 200, 142, 0.72);
        box-shadow: 0 24px 62px rgba(22, 12, 6, 0.24);
      }

      .owner {
        background: var(--ivory);
      }

      .owner::before,
      .menu::before,
      .interior::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: linear-gradient(90deg, transparent, var(--border-gold), transparent);
      }

      .owner-in {
        display: grid;
        grid-template-columns: 1fr 1.2fr;
        gap: 48px;
        align-items: center;
      }

      .owner-img {
        min-height: 540px;
        border: 1px solid var(--border-light);
        background: url("./images/owner.webp") center/cover no-repeat;
      }

      .owner-tx h2 {
        margin: 0 0 10px;
        font-family: var(--font-display);
        font-size: clamp(1.35rem, 2.3vw, 1.9rem);
        line-height: 1.5;
        letter-spacing: 0.06em;
        color: var(--brown-deep);
      }

      .ow-sub {
        margin: 0 0 24px;
        font-family: var(--font-heading);
        font-size: 0.8rem;
        letter-spacing: 0.14em;
        color: var(--gold);
      }

      .owner-tx p + p {
        margin-top: 14px;
      }

      .owner-sg {
        margin-top: 22px;
        font-family: var(--font-display);
        font-size: 1rem;
        letter-spacing: 0.12em;
        color: var(--brown-deep);
      }

      .scenes {
        padding: var(--section-pad);
        background: var(--ivory-warm);
      }

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

      .scene-c {
        background: var(--white);
        border: 1px solid var(--border-light);
        overflow: hidden;
        transition:
          transform 0.3s ease,
          box-shadow 0.3s ease;
      }

      .scene-img {
        height: 210px;
        background-position: center;
        background-size: cover;
      }

      .scene-b {
        padding: 26px 22px;
      }

      .scene-c h3 {
        margin: 0 0 10px;
        font-family: var(--font-display);
        font-size: 1.08rem;
        letter-spacing: 0.05em;
        color: var(--brown-deep);
      }

      .recommend {
        background: var(--ivory);
      }

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

      .recommend-c {
        background: var(--white);
        border: 1px solid var(--border-light);
        overflow: hidden;
        transition:
          transform 0.3s ease,
          box-shadow 0.3s ease;
      }

      .recommend-img {
        height: 220px;
        background-position: center;
        background-size: cover;
        position: relative;
      }

      .recommend-bdg {
        position: absolute;
        top: 14px;
        left: 14px;
        padding: 6px 12px;
        background: var(--gold);
        color: var(--white);
        font-family: var(--font-heading);
        font-size: 0.68rem;
        letter-spacing: 0.14em;
      }

      .recommend-b {
        padding: 26px 22px;
      }

      .recommend-c h3 {
        margin: 0 0 8px;
        font-family: var(--font-display);
        font-size: 1.16rem;
        letter-spacing: 0.05em;
        color: var(--brown-deep);
      }

      .recommend-price {
        margin: 0 0 14px;
        color: var(--enji);
        font-family: var(--font-heading);
        font-size: 0.96rem;
      }

      .recommend-line {
        width: 30px;
        height: 1px;
        background: var(--gold);
        margin-bottom: 14px;
      }

      .menu {
        background: var(--ivory-warm);
      }

      .mt {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 8px;
        margin-bottom: 40px;
      }

      .mt button {
        padding: 9px 20px;
        border: 1px solid var(--border-light);
        background: var(--white);
        color: var(--text-secondary);
        font-family: var(--font-heading);
        font-size: 0.8rem;
        letter-spacing: 0.05em;
        cursor: pointer;
        transition: all 0.3s ease;
      }

      .mt button.act,
      .mt button:hover {
        background: var(--brown-deep);
        border-color: var(--brown-deep);
        color: var(--white);
      }

      .mc-sec {
        display: none;
      }

      .mc-sec.act {
        display: block;
      }

      .mg {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(315px, 1fr));
        gap: 16px;
      }

      .menu-card {
        display: flex;
        justify-content: space-between;
        gap: 16px;
        padding: 18px 20px;
        background: var(--white);
        border: 1px solid var(--border-light);
        transition:
          transform 0.3s ease,
          box-shadow 0.3s ease;
      }

      .menu-info {
        flex: 1;
      }

      .menu-name {
        margin: 0 0 3px;
        font-family: var(--font-heading);
        font-size: 0.95rem;
        color: var(--brown-deep);
      }

      .menu-desc {
        margin: 0;
        font-size: 0.76rem;
        color: var(--text-light);
        line-height: 1.7;
      }

      .menu-price {
        white-space: nowrap;
        font-family: var(--font-heading);
        font-size: 0.92rem;
        color: var(--enji);
      }

      .m-note {
        margin: 24px 0 0;
        text-align: center;
        font-size: 0.78rem;
        color: var(--text-light);
      }

      .interior {
        background: var(--charcoal);
        color: var(--text-on-dark);
        overflow: hidden;
      }

      .interior .sl {
        color: var(--gold-pale);
      }

      .interior .sh {
        color: var(--ivory);
      }

      .interior .sp {
        color: rgba(250, 248, 242, 0.82);
      }

      .interior-g {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
      }

      .interior-c {
        position: relative;
        aspect-ratio: 4 / 3;
        overflow: hidden;
        border: 1px solid rgba(255, 255, 255, 0.08);
      }

      .interior-c img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.5s ease;
      }

      .interior-c:hover img {
        transform: scale(1.05);
      }

      .interior-ov {
        position: absolute;
        inset: auto 0 0 0;
        padding: 22px;
        background: linear-gradient(transparent, rgba(42, 26, 16, 0.8));
      }

      .interior-ov h3 {
        margin: 0 0 4px;
        font-family: var(--font-display);
        font-size: 1.06rem;
        letter-spacing: 0.08em;
      }

      .interior-ov p {
        margin: 0;
        font-size: 0.76rem;
        color: var(--gold-pale);
      }

      .faq {
        background: var(--ivory);
      }

      .faq-ls {
        max-width: 820px;
        margin: 0 auto;
      }

      .faq-it {
        border-bottom: 1px solid var(--border-light);
      }

      .faq-q {
        width: 100%;
        padding: 22px 0;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 16px;
        background: none;
        border: none;
        text-align: left;
        cursor: pointer;
        font-family: var(--font-heading);
        font-size: 0.95rem;
        color: var(--brown-deep);
      }

      .faq-q span {
        display: inline-flex;
        align-items: flex-start;
        gap: 12px;
      }

      .faq-q span::before {
        content: "Q.";
        font-family: var(--font-display);
        color: var(--gold);
        font-weight: 700;
      }

      .faq-q::after {
        content: "+";
        font-size: 1.2rem;
        color: var(--gold);
      }

      .faq-it.open .faq-q::after {
        content: "−";
      }

      .faq-a {
        max-height: 0;
        overflow: hidden;
        transition:
          max-height 0.4s ease,
          padding 0.4s ease;
        padding: 0 0 0 34px;
      }

      .faq-it.open .faq-a {
        max-height: 180px;
        padding-bottom: 20px;
      }

      .faq-a p {
        margin: 0;
        font-size: 0.86rem;
        color: var(--text-secondary);
      }

      .reserve {
        background: var(--ivory-warm);
      }

      .reserve-box {
        max-width: 860px;
        margin: 0 auto;
        padding: 42px 34px;
        background: var(--white);
        border: 1px solid var(--border-light);
        text-align: center;
        box-shadow: var(--shadow-soft);
      }

      .reserve-box h2 {
        margin: 0 0 14px;
        font-family: var(--font-display);
        font-size: clamp(1.5rem, 3vw, 2.2rem);
        letter-spacing: 0.08em;
        color: var(--brown-deep);
      }

      .reserve-box p + p {
        margin-top: 10px;
      }

      .rsv-bt {
        margin-top: 28px;
        display: flex;
        justify-content: center;
        gap: 14px;
        flex-wrap: wrap;
      }

      .access {
        background: var(--ivory);
      }

      .access-ct {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 32px;
        align-items: stretch;
      }

      .itbl {
        padding: 28px 26px;
        background: var(--white);
        border: 1px solid var(--border-light);
      }

      .itbl dl {
        margin: 0;
        display: grid;
        grid-template-columns: 120px 1fr;
        gap: 14px 18px;
      }

      .itbl dt {
        font-family: var(--font-heading);
        font-size: 0.84rem;
        color: var(--brown-deep);
      }

      .itbl dd {
        margin: 0;
        font-size: 0.86rem;
        color: var(--text-secondary);
      }

      .itbl a {
        color: var(--gold);
      }

      .access-map {
        min-height: 100%;
        border: 1px solid var(--border-light);
        background: var(--cream);
      }

      .access-map iframe {
        width: 100%;
        height: 100%;
        min-height: 380px;
        border: 0;
        display: block;
      }

      .access-copy {
        margin-top: 22px;
        text-align: center;
      }

      .ft {
        background: var(--brown-deep);
        color: var(--ivory);
        padding: 58px 0 26px;
      }

      .ft-in {
        display: grid;
        grid-template-columns: 1.2fr 1fr 1fr;
        gap: 28px;
      }

      .ft-brand .logo-m {
        color: var(--ivory);
      }

      .ft-brand p,
      .ft-nav a,
      .ft-info p {
        font-size: 0.84rem;
        color: rgba(250, 248, 242, 0.82);
      }

      .ft-nav,
      .ft-info {
        display: grid;
        gap: 10px;
        align-content: start;
      }

      .ft-nav h3,
      .ft-info h3 {
        margin: 0 0 10px;
        font-family: var(--font-heading);
        font-size: 0.9rem;
        letter-spacing: 0.08em;
        color: var(--gold-pale);
      }

      .ft-copy {
        margin-top: 34px;
        padding-top: 18px;
        border-top: 1px solid rgba(255, 255, 255, 0.08);
        text-align: center;
        font-size: 0.74rem;
        color: rgba(250, 248, 242, 0.55);
      }

      .fcta {
        display: none;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 998;
        grid-template-columns: 1fr 1fr;
        background: var(--white);
        border-top: 1px solid var(--border-light);
      }

      .fcta a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        padding: 13px 0;
        text-align: center;
        font-family: var(--font-heading);
        font-size: 0.84rem;
        letter-spacing: 0.06em;
      }

      .fcta .fc-t {
        background: var(--brown-deep);
        color: var(--white);
      }

      .fcta .fc-r {
        background: var(--gold);
        color: var(--white);
      }

      .olive {
        padding: var(--section-pad);
        background: linear-gradient(135deg, #fffdf8 0%, #f3ede2 100%);
        position: relative;
        overflow: hidden;
      }

      .olive::before {
        content: "OLIVE BEEF";
        position: absolute;
        right: -2vw;
        top: 30px;
        font-family: var(--font-display);
        font-size: clamp(3.2rem, 10vw, 9rem);
        letter-spacing: 0.08em;
        color: rgba(176, 136, 64, 0.08);
        pointer-events: none;
        white-space: nowrap;
      }

      .olive-in {
        position: relative;
        display: grid;
        grid-template-columns: 0.95fr 1.05fr;
        gap: 52px;
        align-items: center;
      }

      .olive-copy {
        background: rgba(255, 253, 248, 0.86);
        border: 1px solid var(--border-gold);
        padding: 44px 42px;
        box-shadow: var(--shadow-soft);
      }

      .olive-copy h2 {
        font-family: var(--font-heading);
        font-size: clamp(1.55rem, 2.6vw, 2.15rem);
        line-height: 1.45;
        color: var(--text-primary);
        margin-bottom: 22px;
      }

      .olive-copy p {
        color: var(--text-secondary);
        line-height: 2.15;
        font-size: 0.98rem;
        margin-top: 18px;
      }

      .olive-kws {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin-top: 26px;
      }

      .olive-kws span {
        display: inline-flex;
        align-items: center;
        border: 1px solid var(--border-gold);
        color: var(--brown);
        background: rgba(250, 248, 242, 0.86);
        padding: 8px 14px;
        font-size: 0.78rem;
        letter-spacing: 0.08em;
      }

      .olive-photo {
        min-height: 520px;
        background: url("./images/karubi.webp") center/cover no-repeat;
        box-shadow: 0 18px 54px rgba(58, 34, 16, 0.14);
        position: relative;
      }

      .olive-photo::after {
        content: "地元・香川の味を月城苑で";
        position: absolute;
        left: 24px;
        bottom: 24px;
        background: rgba(58, 34, 16, 0.86);
        color: var(--text-on-dark);
        padding: 12px 18px;
        font-size: 0.86rem;
        letter-spacing: 0.08em;
      }

      /* PC版ではH2の強制改行を外し、見出しサイズを少し抑える */
      .olive-link {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin-top: 26px;
        padding: 12px 20px;
        border: 1px solid var(--gold);
        color: var(--brown-deep);
        background: rgba(255, 253, 248, 0.72);
        font-size: 0.86rem;
        letter-spacing: 0.08em;
        transition: 0.28s ease;
      }

      .olive-link:hover {
        background: var(--gold);
        color: var(--white);
        transform: translateY(-2px);
      }

      .station-seo {
        position: relative;
        padding: var(--section-pad);
        background: linear-gradient(135deg, rgba(255, 253, 248, 0.96), rgba(243, 237, 226, 0.92));
      }

      .station-box {
        display: grid;
        grid-template-columns: 0.95fr 1.05fr;
        gap: 46px;
        align-items: center;
        border: 1px solid var(--border-gold);
        background: rgba(255, 253, 248, 0.84);
        box-shadow: var(--shadow-soft);
        padding: 44px;
      }

      .station-copy h2 {
        margin: 0 0 18px;
        font-family: var(--font-display);
        font-size: clamp(1.5rem, 2.3vw, 2.05rem);
        line-height: 1.5;
        letter-spacing: 0.06em;
        color: var(--brown-deep);
      }

      .station-copy p {
        margin: 0 0 16px;
        color: var(--text-secondary);
        line-height: 2.05;
      }

      .station-list {
        display: grid;
        gap: 14px;
      }

      .station-list li {
        list-style: none;
        padding: 16px 18px;
        border-left: 3px solid var(--gold);
        background: rgba(250, 248, 242, 0.88);
        color: var(--text-secondary);
        line-height: 1.8;
      }

      @media (min-width: 641px) {
        .sh br,
        .olive-copy h2 br,
        .owner-tx h2 br,
        .reserve-box h2 br {
          display: none;
        }
      }
      @media (min-width: 1025px) {
        .olive-copy h2 {
          font-size: clamp(1.45rem, 1.9vw, 1.88rem);
          letter-spacing: 0.04em;
          white-space: nowrap;
        }
      }

      @media (prefers-reduced-motion: reduce) {
        .specialty-parallax {
          background-attachment: scroll;
        }

        .about-media-main img,
        .about-media-sub img {
          transition: none;
        }

        .about-media:hover img {
          transform: none;
        }
      }

      @media (max-width: 1024px) {
        .nd,
        .hd-cta {
          display: none;
        }

        .hb {
          display: flex;
        }

        .about-g,
        .specialty-g,
        .owner-in,
        .olive-in,
        .station-box,
        .access-ct,
        .ft-in {
          grid-template-columns: 1fr;
        }

        .owner-img {
          min-height: 380px;
        }

        .about-media {
          grid-template-columns: 1fr;
          margin-bottom: 38px;
        }

        .about-media-main {
          min-height: 420px;
        }

        .specialty-parallax {
          background-attachment: scroll;
          background-position: center top;
        }

        .scenes-g,
        .interior-g,
        .recommend-g {
          grid-template-columns: 1fr 1fr;
        }
      }

      @media (max-width: 640px) {
        :root {
          --section-pad: 68px 0;
        }

        .ctn,
        .hd-in {
          width: min(var(--max-w), calc(100% - 32px));
        }

        .hero h1 {
          letter-spacing: 0.1em;
        }

        .hero-video {
          display: none;
        }

        .hero-cta,
        .rsv-bt {
          flex-direction: column;
          align-items: center;
        }

        .hero-cta .btn,
        .rsv-bt .btn {
          width: 100%;
          max-width: 280px;
        }

        .about-g,
        .specialty-g,
        .scenes-g,
        .recommend-g,
        .interior-g,
        .mg {
          grid-template-columns: 1fr;
        }

        .about-c,
        .specialty-c,
        .olive-copy,
        .station-box,
        .reserve-box,
        .itbl {
          padding: 28px 22px;
        }

        .about-media {
          gap: 18px;
          margin-top: -2px;
          margin-bottom: 34px;
        }

        .about-media-main {
          min-height: 300px;
        }

        .about-media-panel {
          padding: 26px 20px;
        }

        .about-media-panel::before {
          inset: 10px;
        }

        .about-media-sub {
          aspect-ratio: 4 / 3;
        }
        .olive-in {
          gap: 26px;
        }

        .olive-photo {
          min-height: 300px;
        }

        .olive-photo::after {
          left: 14px;
          right: 14px;
          bottom: 14px;
          text-align: center;
        }

        .olive-kws span {
          font-size: 0.72rem;
          padding: 7px 10px;
        }

        .mt button {
          font-size: 0.73rem;
          padding: 7px 12px;
        }

        .itbl dl {
          grid-template-columns: 96px 1fr;
        }

        .fcta {
          display: grid;
        }

        body {
          padding-bottom: 66px;
        }

        .ft {
          padding-bottom: 90px;
        }
      }

      /* =====================================
         WEBEE LAB: Mobile HERO / Navigation refinements
         - Keep HERO as video on smartphone
         - Left-align mobile copy for readability
         - Fix SCROLL centering by preserving translateX in animation
         - Make mobile hamburger menu scrollable on short screens
      ===================================== */
      .hero-sc {
        transform: translateX(-50%);
        animation-name: fu-sc;
      }

      @keyframes fu-sc {
        from {
          opacity: 0;
          transform: translateX(-50%) translateY(18px);
        }
        to {
          opacity: 1;
          transform: translateX(-50%) translateY(0);
        }
      }

      .nm {
        height: 100dvh;
        max-height: 100dvh;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-start;
        padding: clamp(88px, 12vh, 116px) 24px calc(28px + env(safe-area-inset-bottom));
      }

      @media (max-width: 640px) {
        .nm {
          gap: 15px;
          align-items: stretch;
          padding: 92px 24px calc(24px + env(safe-area-inset-bottom));
        }

        .nm a {
          font-size: 0.96rem;
          line-height: 1.55;
          padding: 1px 0;
          text-align: center;
        }

        .mc {
          width: 100%;
          gap: 10px;
          margin-top: 4px;
        }

        .mc-t,
        .mc-r {
          width: min(100%, 300px);
          min-width: 0;
          margin: 0 auto;
          padding: 11px 20px;
          font-size: 0.9rem;
        }

        .hero {
          min-height: 100svh;
          align-items: flex-start;
          justify-content: flex-start;
          padding: clamp(132px, 20svh, 164px) 0 132px;
        }

        .hero-bg {
          filter: brightness(0.38);
        }

        .hero-video {
          display: block !important;
          filter: brightness(0.42);
          object-position: center center;
        }

        .hero-ov {
          background:
            linear-gradient(90deg, rgba(42, 26, 16, 0.78) 0%, rgba(42, 26, 16, 0.54) 52%, rgba(42, 26, 16, 0.28) 100%),
            linear-gradient(180deg, rgba(42, 26, 16, 0.18) 0%, rgba(42, 26, 16, 0.48) 58%, rgba(42, 26, 16, 0.82) 100%);
        }

        .hero-ct {
          width: min(100% - 38px, 430px);
          max-width: 430px;
          margin: 0 auto;
          padding: 0;
          text-align: left;
        }

        .hero-kk {
          margin: 0 0 18px;
          font-size: 0.66rem;
          line-height: 1.6;
          letter-spacing: 0.22em;
          white-space: nowrap;
        }

        .hero h1 {
          font-size: clamp(1.84rem, 7.8vw, 2.3rem);
          line-height: 1.45;
          letter-spacing: 0.08em;
          text-wrap: balance;
        }

        .hero-rl {
          width: 58px;
          margin: 16px 0;
          background: linear-gradient(90deg, var(--gold), transparent);
        }

        .hero-c,
        .hero-s {
          max-width: 100%;
          margin-left: 0;
          margin-right: 0;
          text-align: left;
        }

        .hero-c {
          margin-bottom: 12px;
          font-size: 0.88rem;
          line-height: 1.9;
          letter-spacing: 0.04em;
        }

        .hero-s {
          margin-bottom: 28px;
          font-size: 0.78rem;
          line-height: 1.9;
          letter-spacing: 0.035em;
        }

        .hero-c br,
        .hero-s br {
          display: none;
        }

        .hero-cta {
          align-items: flex-start;
        }

        .hero-cta .btn {
          max-width: 320px;
        }

        .hero-sc {
          left: 50%;
          bottom: 84px;
          transform: translateX(-50%);
          width: max-content;
          text-align: center;
        }
      }

      /* =====================================
         WEBEE LAB: Mobile HERO fine tuning v2
         - Center HERO buttons while keeping text left-aligned
         - Prevent reservation button and SCROLL from overlapping
         - Brighten video/overlay so the movie is easier to see
      ===================================== */
      @media (max-width: 640px) {
        .hero {
          min-height: 100svh;
          flex-direction: column;
          align-items: center;
          justify-content: flex-start;
          padding: clamp(146px, 18svh, 176px) 0 calc(96px + env(safe-area-inset-bottom));
        }

        .hero-bg {
          filter: brightness(0.5);
          transform: scale(1.01);
        }

        .hero-video {
          display: block !important;
          filter: brightness(0.55) saturate(1.08);
          transform: scale(1.01);
          object-position: center 45%;
        }

        .hero-ov {
          background:
            linear-gradient(90deg, rgba(42, 26, 16, 0.66) 0%, rgba(42, 26, 16, 0.42) 54%, rgba(42, 26, 16, 0.18) 100%),
            linear-gradient(180deg, rgba(42, 26, 16, 0.1) 0%, rgba(42, 26, 16, 0.34) 58%, rgba(42, 26, 16, 0.62) 100%);
        }

        .hero-ct {
          width: min(100% - 38px, 430px);
          max-width: 430px;
          margin: 0 auto;
          padding: 0;
          text-align: left;
        }

        .hero-kk {
          margin-bottom: 14px;
          font-size: 0.64rem;
          line-height: 1.55;
          letter-spacing: 0.2em;
        }

        .hero h1 {
          font-size: clamp(1.72rem, 7.2vw, 2.16rem);
          line-height: 1.42;
          letter-spacing: 0.07em;
          text-shadow: 0 3px 18px rgba(0, 0, 0, 0.34);
        }

        .hero-rl {
          width: 54px;
          margin: 14px 0;
        }

        .hero-c {
          margin-bottom: 10px;
          font-size: 0.86rem;
          line-height: 1.82;
          letter-spacing: 0.035em;
          text-shadow: 0 2px 14px rgba(0, 0, 0, 0.28);
        }

        .hero-s {
          margin-bottom: 22px;
          font-size: 0.76rem;
          line-height: 1.82;
          letter-spacing: 0.03em;
          text-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
        }

        .hero-cta {
          width: 100%;
          align-items: center;
          justify-content: center;
          gap: 10px;
        }

        .hero-cta .btn {
          width: min(100%, 320px);
          max-width: 320px;
          min-height: 54px;
          padding: 13px 18px;
          margin-left: auto;
          margin-right: auto;
        }

        .hero-sc {
          position: relative;
          left: auto;
          bottom: auto;
          transform: none;
          width: max-content;
          margin: 30px auto 0;
          text-align: center;
          animation-name: fu;
        }
      }

      @media (max-width: 390px) {
        .hero {
          padding-top: 138px;
        }
        .hero-ct {
          width: min(100% - 34px, 430px);
        }
        .hero h1 {
          font-size: clamp(1.62rem, 7vw, 2rem);
        }
        .hero-c {
          font-size: 0.84rem;
        }
        .hero-s {
          font-size: 0.74rem;
        }
        .hero-sc {
          margin-top: 24px;
        }
      }
    

/* Olive beef page specific */
.has-photo {
        grid-template-columns: 1.08fr 0.92fr;
      }

      .station-photo {
        margin: 0;
        position: relative;
        overflow: hidden;
        border: 1px solid var(--border-gold);
        box-shadow: var(--shadow-soft);
        background: var(--ivory);
      }

      .station-photo img {
        display: block;
        width: 100%;
        aspect-ratio: 4 / 3;
        height: auto;
        object-fit: cover;
      }

      .station-photo figcaption {
        position: absolute;
        left: 12px;
        bottom: 12px;
        max-width: calc(100% - 24px);
        padding: 7px 10px;
        background: rgba(42, 26, 16, 0.72);
        color: rgba(255, 253, 248, 0.86);
        font-size: 0.68rem;
        line-height: 1.5;
        letter-spacing: 0.04em;
      }

      .station-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin-top: 20px;
      }

      @media (min-width: 641px) {
        .sh br,
        .olive-copy h2 br,
        .owner-tx h2 br,
        .reserve-box h2 br {
          display: none;
        }
      }

      @media (max-width: 1024px) {
        .nd,
        .hd-cta {
          display: none;
        }

        .hb {
          display: flex;
        }

        .about-g,
        .specialty-g,
        .owner-in,
        .station-box,
        .station-box.has-photo,
        .access-ct,
        .ft-in {
          grid-template-columns: 1fr;
        }

        .owner-img {
          min-height: 380px;
        }

        .scenes-g,
        .interior-g,
        .recommend-g {
          grid-template-columns: 1fr 1fr;
        }
      }

      @media (max-width: 640px) {
        :root {
          --section-pad: 68px 0;
        }

        .ctn,
        .hd-in {
          width: min(var(--max-w), calc(100% - 32px));
        }

        .hero h1 {
          letter-spacing: 0.1em;
        }

        .hero-cta,
        .rsv-bt {
          flex-direction: column;
          align-items: center;
        }

        .hero-cta .btn,
        .rsv-bt .btn {
          width: 100%;
          max-width: 280px;
        }

        .about-g,
        .specialty-g,
        .scenes-g,
        .recommend-g,
        .interior-g,
        .mg {
          grid-template-columns: 1fr;
        }

        .about-c,
        .specialty-c,
        .olive-copy,
        .station-box,
        .reserve-box,
        .itbl {
          padding: 28px 22px;
        }

        .mt button {
          font-size: 0.73rem;
          padding: 7px 12px;
        }

        .itbl dl {
          grid-template-columns: 96px 1fr;
        }

        .fcta {
          display: grid;
        }

        body {
          padding-bottom: 66px;
        }

        .ft {
          padding-bottom: 90px;
        }
      }

      .page-hero {
        position: relative;
        padding: 180px 0 110px;
        background:
          linear-gradient(135deg, rgba(46, 34, 24, 0.92), rgba(90, 58, 40, 0.72)),
          url("./images/karubi.webp") center/cover no-repeat;
        color: var(--text-on-dark);
        overflow: hidden;
      }
      .page-hero .ctn {
        position: relative;
        z-index: 2;
      }
      .page-hero h1 {
        max-width: 900px;
        margin: 0;
        font-family: var(--font-display);
        font-size: clamp(2rem, 4.2vw, 3.6rem);
        line-height: 1.35;
        letter-spacing: 0.08em;
      }
      .page-hero p {
        max-width: 760px;
        margin-top: 22px;
        line-height: 2;
        color: rgba(250, 248, 242, 0.9);
      }
      .article-section {
        padding: var(--section-pad);
        background: var(--ivory);
      }
      .article-grid {
        display: grid;
        grid-template-columns: 1.05fr 0.95fr;
        gap: 48px;
        align-items: start;
      }
      .article-card {
        background: var(--white);
        border: 1px solid var(--border-gold);
        padding: 42px;
        box-shadow: var(--shadow-soft);
      }
      .article-card h2 {
        margin: 0 0 18px;
        font-family: var(--font-display);
        font-size: clamp(1.45rem, 2.4vw, 2.05rem);
        line-height: 1.45;
        letter-spacing: 0.06em;
        color: var(--brown-deep);
      }
      .article-card h3 {
        margin: 28px 0 10px;
        font-family: var(--font-heading);
        color: var(--brown-deep);
        font-size: 1.08rem;
      }
      .article-card p {
        margin: 0 0 16px;
        color: var(--text-secondary);
        line-height: 2.05;
      }
      .article-card ul {
        margin: 18px 0 0;
        padding: 0;
        display: grid;
        gap: 12px;
      }
      .article-card li {
        list-style: none;
        padding: 14px 16px;
        background: rgba(250, 248, 242, 0.9);
        border-left: 3px solid var(--gold);
        line-height: 1.8;
        color: var(--text-secondary);
      }
      .article-side {
        position: sticky;
        top: 110px;
        display: grid;
        gap: 18px;
      }
      .side-photo {
        min-height: 360px;
        /* background: url("./images/yakiniku-01.webp") center/cover no-repeat; */
        background: url("./images/olive-beef.webp") center/cover no-repeat;
        border: 1px solid var(--border-light);
        box-shadow: var(--shadow-soft);
      }
      .side-note {
        background: var(--brown-deep);
        color: var(--text-on-dark);
        padding: 28px;
      }
      .side-note h2 {
        margin: 0 0 12px;
        font-size: 1.15rem;
        font-family: var(--font-heading);
      }
      .side-note p {
        margin: 0;
        color: rgba(250, 248, 242, 0.86);
        line-height: 1.9;
      }
      .breadcrumb {
        font-size: 0.78rem;
        letter-spacing: 0.06em;
        margin-bottom: 22px;
        color: rgba(250, 248, 242, 0.78);
      }
      .breadcrumb a {
        text-decoration: underline;
        text-underline-offset: 4px;
      }
      @media (max-width: 1024px) {
        .article-grid {
          grid-template-columns: 1fr;
        }
        .article-side {
          position: static;
        }
      }
      @media (max-width: 640px) {
        .page-hero {
          padding: 130px 0 78px;
        }
        .article-card {
          padding: 28px 22px;
        }
      }

      @media (min-width: 1025px) {
        .article-card h2,
        .station-copy h2 {
          font-size: clamp(1.4rem, 2vw, 1.9rem);
          letter-spacing: 0.04em;
        }
      }

      @media (max-width: 640px) {
        .page-hero h1 {
          font-size: clamp(1.72rem, 7vw, 2.3rem);
          line-height: 1.45;
          letter-spacing: 0.04em;
        }
        .page-hero p {
          line-height: 1.85;
        }
        .article-card p {
          line-height: 1.9;
        }
        .side-photo {
          min-height: 280px;
        }
      }


      /* =====================================
         WEBEE LAB: Mobile navigation refinement
         - Prevent hamburger menu items from being hidden on short screens
      ===================================== */
      .nm {
        height: 100dvh;
        max-height: 100dvh;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-start;
        padding: clamp(88px, 12vh, 116px) 24px calc(28px + env(safe-area-inset-bottom));
      }

      @media (max-width: 640px) {
        .nm {
          gap: 15px;
          align-items: stretch;
          padding: 92px 24px calc(24px + env(safe-area-inset-bottom));
        }

        .nm a {
          font-size: 0.96rem;
          line-height: 1.55;
          padding: 1px 0;
          text-align: center;
        }

        .mc {
          width: 100%;
          gap: 10px;
          margin-top: 4px;
        }

        .mc-t,
        .mc-r {
          width: min(100%, 300px);
          min-width: 0;
          margin: 0 auto;
          padding: 11px 20px;
          font-size: 0.9rem;
        }
      }

    

/* =========================
   WordPress extensions: News + editable menu accordion
========================= */
.news {
  padding: var(--section-pad);
  background: var(--ivory);
  position: relative;
}
.news::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-gold), transparent);
}
.news-hd {
  text-align: center;
  margin-bottom: 44px;
}
.news-list {
  display: grid;
  gap: 16px;
  max-width: 920px;
  margin: 0 auto;
}
.news-card {
  display: grid;
  grid-template-columns: 130px 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 22px 24px;
  background: var(--white);
  border: 1px solid var(--border-light);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.news-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
  border-color: var(--border-gold);
}
.news-date {
  font-family: var(--font-heading);
  color: var(--gold);
  font-size: .82rem;
  letter-spacing: .08em;
}
.news-title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: .98rem;
  color: var(--brown-deep);
  letter-spacing: .04em;
}
.news-more {
  color: var(--gold);
  font-size: .82rem;
  letter-spacing: .08em;
  white-space: nowrap;
}
.news-empty {
  text-align: center;
  color: var(--text-light);
  background: var(--white);
  border: 1px solid var(--border-light);
  padding: 28px;
  max-width: 720px;
  margin: 0 auto;
}
.news-actions {
  margin-top: 30px;
  text-align: center;
}
.news-archive {
  padding: 170px 0 90px;
  background: var(--ivory);
}
.news-archive .news-list {
  margin-top: 34px;
}
.news-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 36px;
}
.news-pagination .page-numbers {
  min-width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-light);
  background: var(--white);
  color: var(--brown-deep);
}
.news-pagination .current {
  background: var(--brown-deep);
  color: var(--white);
  border-color: var(--brown-deep);
}
.single-news-body {
  max-width: 860px;
  margin: 0 auto;
  padding: 170px 0 90px;
}
.single-news-card {
  background: var(--white);
  border: 1px solid var(--border-light);
  padding: clamp(28px, 5vw, 54px);
  box-shadow: var(--shadow-soft);
}
.single-news-card h1 {
  margin: 0 0 12px;
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 3vw, 2.55rem);
  line-height: 1.45;
  color: var(--brown-deep);
}
.single-news-date {
  color: var(--gold);
  font-family: var(--font-heading);
  letter-spacing: .08em;
  margin-bottom: 28px;
}
.single-news-content {
  color: var(--text-secondary);
}
.single-news-content a { color: var(--gold); text-decoration: underline; }
.menu-accordion {
  display: grid;
  gap: 14px;
}
.menu-group {
  background: var(--white);
  border: 1px solid var(--border-light);
  box-shadow: 0 2px 10px rgba(58,34,16,.02);
  transition: box-shadow .3s ease, border-color .3s ease;
}
.menu-group[open] {
  box-shadow: var(--shadow-soft);
  border-color: var(--border-gold);
}
.menu-group > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 22px 24px;
  font-family: var(--font-heading);
  color: var(--brown-deep);
}
.menu-group > summary::-webkit-details-marker { display: none; }
.menu-cat-label {
  display: grid;
  gap: 2px;
}
.menu-cat-en {
  font-family: var(--font-display);
  color: var(--gold);
  letter-spacing: .26em;
  font-size: .65rem;
}
.menu-cat-name {
  font-size: 1.04rem;
  letter-spacing: .08em;
}
.menu-cat-action {
  border: 1px solid var(--gold);
  color: var(--gold);
  padding: 7px 12px;
  font-size: .75rem;
  letter-spacing: .08em;
  white-space: nowrap;
}
.menu-group[open] .menu-cat-action {
  background: var(--gold);
  color: var(--white);
}
.menu-group-body {
  padding: 0 22px 24px;
}
.menu-group-body .mg {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.menu-card.is-note {
  display: block;
  color: var(--text-light);
  font-size: .78rem;
}
.menu-admin-hint {
  margin-top: 24px;
  text-align: center;
  color: var(--text-light);
  font-size: .78rem;
}
@media (max-width: 640px) {
  .news-card {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 20px;
  }
  .news-more { display: none; }
  .menu-group > summary {
    padding: 19px 18px;
  }
  .menu-group-body {
    padding: 0 16px 20px;
  }
  .menu-cat-name {
    font-size: .98rem;
  }
  .menu-cat-action {
    font-size: .7rem;
    padding: 6px 9px;
  }
}

/* ===============================
   v2: Original tab/card menu + refined animations
   =============================== */
.menu-panels {
  position: relative;
}

.menu-panel-head {
  text-align: center;
  margin: 0 0 22px;
}

.menu-panel-en {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-size: .62rem;
  letter-spacing: .32em;
  color: var(--gold);
}

.menu-panel-head h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  letter-spacing: .12em;
  color: var(--brown-deep);
}

.mt {
  position: relative;
  padding: 8px;
  background: rgba(255,253,248,.72);
  border: 1px solid rgba(176,136,64,.18);
  box-shadow: 0 10px 28px rgba(58,34,16,.045);
}

.mt button {
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  transform: translateY(0);
}

.mt button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.32), transparent);
  transform: translateX(-120%);
  transition: transform .65s ease;
}

.mt button:hover::before,
.mt button.act::before {
  transform: translateX(120%);
}

.mt button:hover {
  transform: translateY(-1px);
}

.mc-sec {
  animation: none;
}

.mc-sec.act {
  display: block;
  animation: menuPanelIn .46s cubic-bezier(.22, .8, .28, 1) both;
}

.mc-sec.act .menu-card {
  animation: menuCardIn .48s cubic-bezier(.22, .8, .28, 1) both;
  animation-delay: calc(var(--card-i, 0) * 45ms);
}

.menu-card {
  position: relative;
  overflow: hidden;
  border-color: rgba(220,210,196,.9);
  box-shadow: 0 1px 0 rgba(255,255,255,.65) inset;
}

.menu-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--gold-light), var(--gold));
  opacity: 0;
  transform: scaleY(.2);
  transform-origin: top;
  transition: opacity .28s ease, transform .28s ease;
}

.menu-card:hover::before {
  opacity: 1;
  transform: scaleY(1);
}

.menu-card:hover .menu-name {
  color: var(--enji);
}

.menu-price {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 78px;
  font-variant-numeric: tabular-nums;
}

.menu-admin-hint {
  display: none;
}

.fi.v .sh,
.fi.show .sh {
  animation: titleLift .72s cubic-bezier(.22,.8,.28,1) both;
}

.fi.v .sd::before,
.fi.v .sd::after,
.fi.show .sd::before,
.fi.show .sd::after {
  animation: lineGrow .86s ease both;
}

.about-c,
.specialty-c,
.recommend-c,
.interior-c,
.news-card {
  transition: transform .32s ease, box-shadow .32s ease, border-color .32s ease;
}

.about-c:hover,
.specialty-c:hover,
.recommend-c:hover,
.news-card:hover {
  border-color: rgba(176,136,64,.36);
}

.hero-video,
.hero-bg {
  animation: heroBreath 18s ease-in-out infinite alternate;
}

@keyframes menuPanelIn {
  from { opacity: 0; transform: translateY(12px); filter: blur(4px); }
  to { opacity: 1; transform: translateY(0); filter: blur(0); }
}

@keyframes menuCardIn {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes titleLift {
  from { opacity: .55; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes lineGrow {
  from { transform: scaleX(.18); opacity: .25; }
  to { transform: scaleX(1); opacity: 1; }
}

@keyframes heroBreath {
  from { transform: scale(1.02); }
  to { transform: scale(1.075); }
}

@media (max-width: 760px) {
  .mt {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 8px;
  }
  .mt::-webkit-scrollbar { display: none; }
  .mt button {
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .menu-panel-head {
    margin-bottom: 16px;
  }
  .menu-card {
    padding: 17px 18px;
  }
  .menu-price {
    min-width: 68px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}


/* ===============================
   WEBEE LAB: Mobile menu category slider cue
   - Make horizontal category tabs clearly swipeable on smartphone
=============================== */
.menu-tabs-wrap {
  position: relative;
  margin-bottom: 40px;
}

.menu-tabs-wrap .mt {
  margin-bottom: 0;
}

.menu-scroll-cue {
  display: none;
}

@media (max-width: 760px) {
  .menu-tabs-wrap {
    margin: 0 -18px 34px;
    padding: 0 18px 26px;
  }

  .menu-tabs-wrap::before,
  .menu-tabs-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 26px;
    width: 34px;
    z-index: 3;
    pointer-events: none;
    opacity: 0;
    transition: opacity .22s ease;
  }

  .menu-tabs-wrap::before {
    left: 0;
    background: linear-gradient(90deg, var(--ivory-warm) 12%, rgba(243,237,226,0));
  }

  .menu-tabs-wrap::after {
    right: 0;
    background: linear-gradient(270deg, var(--ivory-warm) 12%, rgba(243,237,226,0));
  }

  .menu-tabs-wrap.is-scrollable:not(.is-at-start)::before,
  .menu-tabs-wrap.is-scrollable:not(.is-at-end)::after {
    opacity: 1;
  }

  .menu-tabs-wrap.is-scrollable:not(.has-interacted) .menu-scroll-cue {
    position: absolute;
    right: 22px;
    bottom: 0;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 10px;
    border: 1px solid rgba(176,136,64,.28);
    border-radius: 999px;
    background: rgba(255,253,248,.92);
    box-shadow: 0 8px 18px rgba(58,34,16,.08);
    color: var(--brown);
    font-family: var(--font-heading);
    font-size: .66rem;
    letter-spacing: .08em;
    white-space: nowrap;
    animation: menuSwipeCue 1.8s ease-in-out infinite;
  }

  .menu-tabs-wrap.is-scrollable:not(.has-interacted) .menu-scroll-cue::after {
    content: "›";
    display: inline-grid;
    place-items: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: var(--brown-deep);
    color: var(--white);
    font-size: 1rem;
    line-height: 1;
  }

  .mt {
    scroll-snap-type: x proximity;
    scroll-padding-inline: 18px;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
  }

  .mt button {
    scroll-snap-align: start;
  }
}

@keyframes menuSwipeCue {
  0%, 100% { transform: translateX(0); }
  48% { transform: translateX(-7px); }
}


/* =========================
   WEBEE LAB: Instagram links
   - Footer menu link
   - Mobile hamburger menu link
========================= */
.ft-instagram,
.nm-instagram {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.sns-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  flex: 0 0 auto;
  color: currentColor;
  line-height: 1;
  letter-spacing: 0;
}

.sns-svg {
  display: block;
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sns-dot {
  fill: currentColor;
  stroke: none;
}

.ft-nav a.ft-instagram {
  width: fit-content;
  margin-top: 4px;
  padding: 8px 13px;
  border: 1px solid rgba(223, 200, 142, 0.38);
  border-radius: 999px;
  color: var(--gold-pale);
  transition:
    color 0.25s ease,
    border-color 0.25s ease,
    background 0.25s ease,
    transform 0.25s ease;
}

.ft-nav a.ft-instagram:hover {
  color: var(--white);
  border-color: rgba(223, 200, 142, 0.72);
  background: rgba(176, 136, 64, 0.14);
  transform: translateY(-1px);
}

.nm a.nm-instagram {
  justify-content: center;
  width: min(100%, 300px);
  margin: 2px auto 0;
  padding: 11px 22px;
  border: 1px solid rgba(176, 136, 64, 0.42);
  border-radius: 999px;
  color: var(--brown-deep);
  background: rgba(255, 253, 248, 0.68);
  letter-spacing: 0.08em;
}

@media (max-width: 640px) {
  .nm a.nm-instagram {
    padding: 10px 20px;
    font-size: 0.92rem;
  }
}
/* =========================
   WEBEE LAB: Horizontal overflow guard v1.2.4
========================= */
html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

@supports (overflow: clip) {
  html,
  body {
    overflow-x: clip;
  }
}

body {
  position: relative;
}

@media (max-width: 760px) {
  .menu-tabs-wrap {
    width: 100%;
    max-width: 100%;
    margin: 0 0 34px;
    padding: 0 0 26px;
    overflow: hidden;
  }

  .menu-tabs-wrap .mt {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-x: contain;
  }

  .menu-tabs-wrap.is-scrollable:not(.has-interacted) .menu-scroll-cue {
    right: 6px;
    max-width: calc(100% - 12px);
  }
}

@media (max-width: 640px) {
  .ctn,
  .hd-in,
  .hero-ct {
    max-width: calc(100vw - 32px);
  }

  .hero-sc,
  .mc,
  .mc-t,
  .mc-r,
  .nm a.nm-instagram {
    max-width: calc(100vw - 32px);
  }
}

/* ===============================
   WEBEE LAB: Dedicated menu page
   - Uses existing menu CPT data and keeps the current visual language
=============================== */
.menu-page-hero {
  background:
    linear-gradient(135deg, rgba(42, 26, 16, 0.94), rgba(90, 58, 40, 0.66)),
    url("./images/yakiniku-01.webp") center / cover no-repeat;
}

.menu-page-intro {
  position: relative;
  padding: var(--section-pad);
  background: var(--ivory);
}

.menu-page-intro::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-gold), transparent);
}

.menu-page-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, 0.96fr);
  gap: clamp(26px, 4vw, 50px);
  align-items: stretch;
}

.menu-page-card {
  position: relative;
  padding: clamp(30px, 4.4vw, 50px);
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid var(--border-gold);
  box-shadow: var(--shadow-soft);
}

.menu-page-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(176, 136, 64, 0.18);
  pointer-events: none;
}

.menu-page-card > * {
  position: relative;
  z-index: 1;
}

.menu-page-card h2 {
  margin: 0 0 18px;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.6vw, 2.08rem);
  line-height: 1.52;
  letter-spacing: 0.06em;
  color: var(--brown-deep);
}

.menu-page-card p {
  margin: 0 0 16px;
  color: var(--text-secondary);
  line-height: 2.05;
}

.menu-page-points {
  display: grid;
  gap: 12px;
  margin: 24px 0 0;
  padding: 0;
}

.menu-page-points li {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 13px;
  align-items: start;
  list-style: none;
  padding: 15px 16px;
  background: rgba(250, 248, 242, 0.94);
  border-left: 3px solid var(--gold);
  color: var(--text-secondary);
  line-height: 1.78;
}

.menu-page-points span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--brown-deep);
  color: var(--gold-pale);
  font-family: var(--font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
}

.menu-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.menu-photo-panel {
  display: grid;
  grid-template-rows: minmax(360px, 1fr) auto;
  gap: 18px;
}

.menu-photo-panel figure {
  position: relative;
  min-height: 360px;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--border-light);
  background: var(--cream);
  box-shadow: var(--shadow-soft);
}

.menu-photo-panel img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.05s cubic-bezier(0.22, 0.8, 0.28, 1);
}

.menu-photo-panel:hover img {
  transform: scale(1.045);
}

.menu-photo-panel figcaption {
  position: absolute;
  left: 14px;
  bottom: 14px;
  max-width: calc(100% - 28px);
  padding: 8px 11px;
  background: rgba(42, 26, 16, 0.72);
  color: rgba(255, 253, 248, 0.9);
  font-size: 0.72rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
}

.menu-photo-note {
  padding: 28px;
  background: var(--brown-deep);
  color: var(--text-on-dark);
}

.menu-photo-note h2 {
  margin: 0 0 12px;
  font-family: var(--font-heading);
  font-size: 1.13rem;
  letter-spacing: 0.06em;
}

.menu-photo-note p {
  margin: 0;
  color: rgba(250, 248, 242, 0.86);
  line-height: 1.9;
}

.menu-usage .station-list {
  margin-top: 20px;
  padding: 0;
}

@media (max-width: 1024px) {
  .menu-page-grid {
    grid-template-columns: 1fr;
  }

  .menu-photo-panel {
    grid-template-rows: auto;
  }

  .menu-photo-panel figure {
    min-height: auto;
  }

  .menu-photo-panel img {
    aspect-ratio: 16 / 10;
    height: auto;
  }
}

@media (max-width: 640px) {
  .menu-page-card {
    padding: 28px 22px;
  }

  .menu-page-card h2 {
    font-size: clamp(1.34rem, 6vw, 1.78rem);
    letter-spacing: 0.04em;
  }

  .menu-page-card p {
    line-height: 1.9;
  }

  .menu-page-points li {
    grid-template-columns: 38px 1fr;
    padding: 14px 14px;
  }

  .menu-page-points span {
    width: 30px;
    height: 30px;
    font-size: 0.66rem;
  }

  .menu-page-actions .olive-link,
  .station-actions .olive-link {
    width: 100%;
    justify-content: center;
  }

  .menu-photo-note {
    padding: 24px 22px;
  }
}


/* =========================
  TOP menu-page CTA refinement
  - TOPの全メニュー掲載を避け、専用メニューページへ誘導
========================= */
.olive-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.olive-actions .olive-link {
  margin-top: 0;
}

.olive-link-menu {
  background: var(--brown-deep);
  border-color: var(--brown-deep);
  color: var(--white);
}

.olive-link-menu:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--white);
}

.recommend-cta {
  margin: 34px auto 0;
  padding: 24px 28px;
  max-width: 860px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  border: 1px solid var(--border-gold);
  background: rgba(255, 253, 248, 0.86);
  box-shadow: var(--shadow-soft);
}

.recommend-cta p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.9;
  font-size: 0.95rem;
}

.recommend-cta .olive-link {
  margin-top: 0;
  flex: 0 0 auto;
}

@media (max-width: 640px) {
  .olive-actions,
  .recommend-cta {
    align-items: stretch;
    flex-direction: column;
  }

  .olive-actions .olive-link,
  .recommend-cta .olive-link {
    width: 100%;
  }

  .recommend-cta {
    padding: 22px 18px;
    text-align: left;
  }
}

/* =====================================
   WEBEE LAB: Mobile hamburger navigation polish v1.2.4
   - Wider touch area for hamburger and drawer links
   - Adds comfortable top spacing before first link
   - Adds premium fade/slide animations with reduced-motion support
===================================== */
@media (max-width: 1024px) {
  .hb {
    width: 48px;
    height: 48px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border: 1px solid rgba(255, 253, 248, 0.34);
    border-radius: 999px;
    background: rgba(58, 34, 16, 0.12);
    transition:
      background 0.28s ease,
      border-color 0.28s ease,
      box-shadow 0.28s ease,
      transform 0.28s ease;
  }

  .hb:hover,
  .hb:focus-visible {
    background: rgba(176, 136, 64, 0.16);
    border-color: rgba(223, 200, 142, 0.62);
  }

  .hd.sc .hb {
    background: rgba(255, 253, 248, 0.8);
    border-color: rgba(58, 34, 16, 0.16);
  }

  .hb span {
    width: 24px;
    height: 1.6px;
    border-radius: 999px;
    transform-origin: center;
  }

  .hb.act {
    background: rgba(255, 253, 248, 0.94);
    border-color: rgba(176, 136, 64, 0.42);
    box-shadow: 0 14px 34px rgba(58, 34, 16, 0.14);
  }

  .hb.act span:nth-child(1) {
    transform: translateY(7.6px) rotate(45deg);
  }

  .hb.act span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0.35);
  }

  .hb.act span:nth-child(3) {
    transform: translateY(-7.6px) rotate(-45deg);
  }

  .nm {
    display: flex;
    height: 100dvh;
    max-height: 100dvh;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    align-items: center;
    justify-content: flex-start;
    gap: 13px;
    padding: clamp(112px, 15svh, 138px) 24px calc(30px + env(safe-area-inset-bottom));
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-12px);
    transition:
      opacity 0.34s ease,
      transform 0.34s ease,
      visibility 0.34s ease;
  }

  .nm.open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    animation: nmBackdropIn 0.42s cubic-bezier(0.22, 0.8, 0.28, 1) both;
  }

  .nm a {
    width: min(100%, 350px);
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 22px;
    border: 1px solid rgba(176, 136, 64, 0.18);
    border-radius: 999px;
    background: rgba(255, 253, 248, 0.58);
    font-size: 1rem;
    line-height: 1.45;
    letter-spacing: 0.1em;
    text-align: center;
    box-shadow: 0 10px 24px rgba(58, 34, 16, 0.045);
    opacity: 0;
    transform: translateY(10px);
    transition:
      background 0.25s ease,
      border-color 0.25s ease,
      color 0.25s ease,
      transform 0.25s ease;
  }

  .nm a:hover,
  .nm a:focus-visible {
    background: rgba(176, 136, 64, 0.12);
    border-color: rgba(176, 136, 64, 0.36);
    transform: translateY(-1px);
  }

  .nm.open a {
    animation: nmLinkIn 0.46s cubic-bezier(0.22, 0.8, 0.28, 1) forwards;
  }

  .nm.open a:nth-child(1) { animation-delay: 0.04s; }
  .nm.open a:nth-child(2) { animation-delay: 0.08s; }
  .nm.open a:nth-child(3) { animation-delay: 0.12s; }
  .nm.open a:nth-child(4) { animation-delay: 0.16s; }
  .nm.open a:nth-child(5) { animation-delay: 0.20s; }
  .nm.open a:nth-child(6) { animation-delay: 0.24s; }
  .nm.open a:nth-child(7) { animation-delay: 0.28s; }
  .nm.open a:nth-child(8) { animation-delay: 0.32s; }

  .mc {
    width: min(100%, 350px);
    gap: 11px;
    margin-top: 8px;
    opacity: 0;
    transform: translateY(10px);
  }

  .nm.open .mc {
    animation: nmLinkIn 0.46s cubic-bezier(0.22, 0.8, 0.28, 1) 0.36s forwards;
  }

  .mc-t,
  .mc-r {
    width: 100%;
    min-height: 50px;
    padding: 13px 20px;
  }
}

@media (max-width: 640px) {
  .nm {
    gap: 12px;
    padding: clamp(118px, 16svh, 146px) 22px calc(28px + env(safe-area-inset-bottom));
  }

  .nm a {
    min-height: 50px;
    padding: 13px 18px;
    font-size: 0.96rem;
    line-height: 1.5;
  }

  .nm a:first-child {
    margin-top: 4px;
  }

  .mc-t,
  .mc-r {
    min-height: 52px;
  }
}

@keyframes nmBackdropIn {
  from {
    opacity: 0;
    transform: translateY(-12px) scale(1.01);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes nmLinkIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .hb,
  .hb span,
  .nm,
  .nm a,
  .mc {
    transition: none !important;
    animation: none !important;
  }

  .nm.open a,
  .nm.open .mc,
  .nm a,
  .mc {
    opacity: 1;
    transform: none;
  }
}



/* =====================================
   WEBEE LAB: Hamburger visibility repair v1.2.5
   - Prevent later mobile polish rules from hiding the button
   - Keep the button above the mobile drawer for reliable tapping
===================================== */
@media (max-width: 1024px) {
  .hd .hb {
    display: flex !important;
    position: relative;
    z-index: 1102;
    align-items: center;
    justify-content: center;
    flex-direction: column;
  }

  .hd .hb span {
    display: block;
    flex: 0 0 auto;
  }
}
