/*
Theme Name: 船場センタービル
Author: ダイトー光芸株式会社
Description: 船場センタービル公式サイト カスタムテーマ
Version: 1.0.7
Text Domain: semba
*/

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Noto Sans JP', 'Helvetica Neue', Arial, sans-serif; font-size: 14px; color: #3a3530; background: #f7f5f2; line-height: 1.7; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ============================================================
   LAYOUT
   ============================================================ */
.container { max-width: 1160px; margin: 0 auto; padding: 0 40px; }

/* ============================================================
   HEADER
   ============================================================ */
.header { background: #fff; border-bottom: 1px solid #e8e4de; height: 64px; display: flex; align-items: center; position: sticky; top: 0; z-index: 100; }
.header > .container { width: 100%; max-width: none; padding: 0 28px; }
.header__inner { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.header__logo { width: 180px; height: 40px; flex-shrink: 0; display: flex; align-items: center; }
.header__logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.header__utils { display: flex; align-items: center; }
.header__util-link { font-size: 11px; color: #666; text-decoration: none; padding: 0 14px; white-space: nowrap; letter-spacing: 0.06em; }
.header__sep { color: #e0dbd5; font-size: 14px; line-height: 1; }
.header__search-btn { padding: 0 14px; background: none; border: none; font-size: 15px; cursor: pointer; color: #777; line-height: 1; }
.header__lang { font-size: 11px; padding: 0 14px; color: #666; cursor: pointer; white-space: nowrap; letter-spacing: 0.1em; background: none; border: none; font-family: inherit; outline: none; }
.header__tenant-btn { background: #2c2c2c; color: #fff; font-size: 11px; padding: 9px 18px; border-radius: 2px; text-decoration: none; white-space: nowrap; margin-left: 8px; letter-spacing: 0.08em; }
.header__hamburger { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; cursor: pointer; background: #2c2c2c; width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0; margin-left: 16px; }
.header__hamburger i { display: block; width: 18px; height: 2px; background: #fff; font-style: normal; }
.header__hamburger-label { display: none; }
.header__sp-icon { display: none; }
.header__sp-sep { display: none; }

/* ============================================================
   HAMBURGER OVERLAY
   ============================================================ */
.hmenu-overlay { display: none; position: fixed; top: 0; right: 0; bottom: 0; width: 360px; background: #fff; z-index: 200; overflow-y: auto; box-shadow: -4px 0 24px rgba(0,0,0,0.12); }
.hmenu-overlay.is-open { display: block; }
.hmenu__top { display: flex; align-items: center; justify-content: flex-end; padding: 12px 20px; border-bottom: 1px solid #f0ece6; }
.hmenu__close { width: 44px; height: 44px; background: #2c2c2c; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 16px; cursor: pointer; }
.hmenu__search { display: flex; align-items: center; margin: 16px 20px; border: 1px solid #ddd; border-radius: 4px; padding: 10px 16px; gap: 8px; }
.hmenu__search input { flex: 1; border: none; outline: none; font-size: 13px; color: #555; font-family: inherit; }
.hmenu__search-icon { font-size: 14px; color: #b5935a; }
.hmenu__nav-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid #f0ece6; border-left: 1px solid #f0ece6; }
.hmenu__nav-item { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 20px 8px; border-right: 1px solid #f0ece6; border-bottom: 1px solid #f0ece6; font-size: 11px; color: #444; text-align: center; text-decoration: none; letter-spacing: 0.04em; white-space: nowrap; }
.hmenu__nav-icon { height: 34px; width: auto; }
.hmenu__link-btns { margin: 16px 20px; display: flex; flex-direction: column; gap: 10px; }
.hmenu__link-btn { display: block; padding: 14px 20px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; color: #2c2c2c; text-decoration: none; letter-spacing: 0.06em; text-align: center; transition: background 0.15s; }
.hmenu__link-btn:hover { background: #f7f5f2; }
.hmenu__sns-title { text-align: center; font-size: 15px; font-weight: 700; color: #2c2c2c; letter-spacing: 0.12em; margin: 24px 20px 16px; }
.hmenu__sns { display: flex; justify-content: center; gap: 20px; margin: 0 20px 20px; }
.hmenu__sns-icon { display: flex; align-items: center; justify-content: center; font-size: 40px; text-decoration: none; transition: opacity 0.18s; }
.hmenu__sns-icon:hover { opacity: 0.7; }
.hmenu__sns-icon--ig { color: #E1306C; }
.hmenu__sns-icon--fb { color: #1877F2; }
.hmenu__sns-icon--line { color: #00B900; }
.hmenu__external { margin: 0 20px 16px; }
.hmenu__external-item { display: block; }
.hmenu__external-item img { width: 100%; height: auto; display: block; }
.hmenu__footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 4px 16px; padding: 12px 20px 28px; border-top: 1px solid #f0ece6; }
.hmenu__footer-link { font-size: 11px; color: #aaa; }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb { background: #fff; border-bottom: 1px solid #ede9e3; padding: 12px 0; }
.breadcrumb__list { display: flex; align-items: center; gap: 6px; list-style: none; font-size: 11px; color: #b5a898; }
.breadcrumb__sep { color: #d5cfc8; font-size: 10px; }
.breadcrumb__item--current { color: #3a3530; }

/* ============================================================
   PAGE HERO
   ============================================================ */
.page-hero { background: #f5f2ec url('img/sub_hero_bg.png') repeat top left; background-size: 500px 200px; padding: 72px 0 64px; border-bottom: 1px solid #e8e4de; text-align: center; position: relative; }
.page-hero::before { content: ''; position: absolute; inset: 0; background: rgba(253, 248, 243, 0.62); }
.page-hero > .container { position: relative; z-index: 1; }
.page-hero__en { font-family: 'Shippori Mincho', serif; font-size: 46px; font-weight: 600; letter-spacing: 0.06em; color: #2c2c2c; line-height: 1.2; margin-bottom: 0; }
.page-hero__en::after { content: ''; display: block; width: 36px; height: 2px; background: #b5935a; margin: 18px auto; }
.page-hero__ja { font-size: 11px; color: #b5935a; letter-spacing: 0.22em; font-weight: 500; }

/* ============================================================
   SECTION COMMONS
   ============================================================ */
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.section-title { font-size: 20px; font-weight: 700; letter-spacing: 0.1em; color: #222; border-left: 4px solid #C8A96E; padding-left: 12px; margin-bottom: 24px; }
.accent { color: #b5935a; }
.section-more { font-size: 11px; color: #C8A96E; border: 1px solid #e0d8ce; padding: 6px 18px; letter-spacing: 0.08em; transition: all 0.2s; }
.section-more:hover { background: #fdf8f3; }
.section-annotation { font-size: 10px; color: #c0b8b0; text-align: right; margin-top: 8px; letter-spacing: 0.08em; }

/* ============================================================
   SEARCH PANEL（検索ページ共通）
   ============================================================ */
.search-panel { background: #fafafa; padding: 40px 0 60px; border-bottom: 1px solid #e8e4de; }
.search-tabs { display: flex; gap: 6px; border-bottom: 2px solid #b5935a; margin-bottom: 52px; }
.search-tab { flex: 1; padding: 16px 8px; font-size: 13px; font-weight: 500; color: #b5935a; background: #fff; border: 1px solid #b5935a; border-bottom: none; border-radius: 6px 6px 0 0; cursor: pointer; letter-spacing: 0.1em; transition: background 0.18s, color 0.18s; text-decoration: none; text-align: center; display: flex; align-items: center; justify-content: center; gap: 7px; }
.search-tab.is-active { background: #b5935a; color: #fff; margin-top: -10px; padding-top: 26px; }
.search-tab:not(.is-active):hover { background: #fdf6ee; }
.popular-section { padding: 0 0 44px; text-align: center; }
.popular-section__title { font-size: 10px; font-weight: 700; color: #b5935a; letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 16px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.popular-section__title::before,
.popular-section__title::after { content: ''; display: block; width: 32px; height: 1px; background: #d4b896; }
.popular-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.popular-tag { font-size: 13px; border: 1px solid #e0d8ce; border-radius: 20px; padding: 8px 22px; color: #665a50; background: #fff; cursor: pointer; transition: all 0.2s; letter-spacing: 0.04em; }
.popular-tag:hover { border-color: #b5935a; color: #b5935a; background: #fdf8f3; }
.search-bar-wrap { display: flex; justify-content: center; margin-bottom: 52px; }
.search-bar { display: flex; align-items: stretch; background: #fff; border: 1.5px solid #ddd; border-radius: 4px; width: 100%; max-width: 600px; overflow: hidden; transition: border-color 0.2s; box-shadow: 0 2px 8px rgba(0,0,0,0.04); }
.search-bar:focus-within { border-color: #b5935a; box-shadow: 0 2px 12px rgba(181,147,90,0.12); }
.search-bar__input { flex: 1; padding: 16px 18px; font-size: 15px; border: none; outline: none; background: transparent; color: #3a3530; letter-spacing: 0.04em; font-family: inherit; }
.search-bar__input::placeholder { color: #c0b8b0; }
.search-bar__btn { background: #b5935a; border: none; color: #fff; cursor: pointer; padding: 0 28px; display: flex; align-items: center; justify-content: center; gap: 8px; flex-shrink: 0; transition: background 0.18s; font-family: inherit; font-size: 14px; }
.search-bar__btn:hover { background: #9e7d47; }
.filter-row { display: flex; gap: 0; align-items: flex-start; margin-bottom: 36px; }
.filter-row .filter-section { margin-bottom: 0; width: 50%; }
.filter-section { margin-bottom: 36px; }
.filter-section__label { font-size: 14px; color: #b5935a; letter-spacing: 0.16em; font-weight: 700; margin-bottom: 16px; text-transform: uppercase; display: flex; align-items: center; gap: 10px; }
.filter-section__label::before { content: ''; display: block; width: 3px; height: 14px; background: #b5935a; border-radius: 2px; flex-shrink: 0; }
.filter-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.filter-tag { font-size: 13px; border: 1px solid #e0d8ce; border-radius: 20px; padding: 8px 22px; color: #665a50; background: #fff; letter-spacing: 0.04em; transition: all 0.18s; cursor: pointer; }
.filter-tag:hover { border-color: #b5935a; color: #b5935a; }
.filter-tag.is-active { background: #b5935a; color: #fff; border-color: #b5935a; }
.filter-selects { display: flex; gap: 16px; flex-wrap: wrap; }
.filter-select-wrap { display: flex; flex-direction: column; gap: 8px; }
.filter-select { font-size: 13px; border: 1px solid #e0d8ce; border-radius: 4px; padding: 11px 40px 11px 16px; color: #555; background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23b5935a'/%3E%3C/svg%3E") no-repeat right 14px center; appearance: none; min-width: 180px; letter-spacing: 0.04em; font-family: inherit; transition: border-color 0.18s; }
.filter-select:focus { outline: none; border-color: #b5935a; }
.accordion { border-top: 1px solid #ede9e3; }
.accordion-item { border-bottom: 1px solid #ede9e3; }
.accordion-trigger { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 20px 0; background: none; border: none; text-align: left; font-size: 14px; color: #3a3530; letter-spacing: 0.08em; font-weight: 500; font-family: inherit; cursor: pointer; }
.accordion-trigger__icon { width: 28px; height: 28px; border: 1px solid #e0d8ce; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; color: #b5935a; flex-shrink: 0; transition: transform 0.25s; }
.accordion-trigger.is-open .accordion-trigger__icon { transform: rotate(45deg); }
.accordion-body { display: none; padding: 4px 0 28px; }
.accordion-body.is-open { display: block; }
.kana-grid { display: grid; grid-template-columns: repeat(10, 1fr); gap: 6px; }
.kana-btn { font-size: 13px; border: 1px solid #e0d8ce; border-radius: 4px; padding: 10px 4px; text-align: center; background: #fff; color: #665a50; cursor: pointer; transition: all 0.15s; letter-spacing: 0.04em; }
.kana-btn:hover { border-color: #2c2c2c; color: #2c2c2c; }
.kana-btn.is-active { background: #2c2c2c; color: #fff; border-color: #2c2c2c; }
.kana-btn:disabled { color: #ccc; border-color: #eee; cursor: default; }
.alpha-grid { display: flex; gap: 6px; flex-wrap: wrap; }
.alpha-btn { font-size: 12px; border: 1px solid #e0d8ce; border-radius: 4px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: #fff; color: #665a50; cursor: pointer; letter-spacing: 0.04em; transition: all 0.15s; }
.alpha-btn:hover { border-color: #2c2c2c; color: #2c2c2c; }
.search-actions { display: flex; align-items: center; justify-content: center; gap: 14px; margin-top: 40px; padding-top: 36px; border-top: 1px solid #ede9e3; }
.btn-search { background: #2c2c2c; color: #fff; font-size: 13px; padding: 16px 52px; letter-spacing: 0.14em; border: none; font-family: inherit; font-weight: 500; transition: background 0.18s; cursor: pointer; display: flex; align-items: center; gap: 10px; }
.btn-search:hover { background: #484440; }
.btn-reset { font-size: 13px; color: #665a50; letter-spacing: 0.08em; background: #fff; border: 1px solid #d4ccc4; padding: 16px 32px; font-family: inherit; transition: all 0.18s; display: flex; align-items: center; gap: 8px; }
.btn-reset:hover { border-color: #b5a898; color: #3a3530; }
.search-result-count { font-size: 12px; color: #b0a898; letter-spacing: 0.04em; text-align: right; margin-top: 16px; width: 100%; }
.search-result-count strong { color: #2c2c2c; font-size: 22px; font-weight: 300; margin: 0 4px; }

/* ============================================================
   RESULTS & SORT BAR
   ============================================================ */
.results-section { background: #f7f5f2; padding: 52px 0 64px; }
.sort-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 36px; padding-bottom: 20px; border-bottom: 1px solid #ede9e3; }
.sort-bar__count { font-size: 13px; color: #b0a898; }
.sort-bar__count strong { color: #2c2c2c; font-size: 22px; font-weight: 300; margin: 0 3px; }
.sort-bar__right { display: flex; align-items: center; gap: 6px; }
.sort-label { font-size: 11px; color: #c0b8b0; margin-right: 8px; letter-spacing: 0.08em; }
.sort-btn { font-size: 11px; border: 1px solid #e0d8ce; padding: 7px 16px; background: #fff; color: #888; letter-spacing: 0.06em; border-radius: 2px; transition: all 0.15s; cursor: pointer; font-family: inherit; }
.sort-btn.is-active { background: #2c2c2c; color: #fff; border-color: #2c2c2c; }
.sort-btn:hover:not(.is-active) { border-color: #b5a898; color: #555; }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination { display: flex; justify-content: center; align-items: center; gap: 5px; margin-top: 64px; }
.page-btn { width: 42px; height: 42px; border: 1px solid #e0d8ce; display: flex; align-items: center; justify-content: center; font-size: 12px; background: #fff; color: #888; border-radius: 2px; transition: all 0.15s; cursor: pointer; font-family: inherit; }
.page-btn.is-active { background: #2c2c2c; color: #fff; border-color: #2c2c2c; }
.page-btn--arrow { color: #c0b8b0; font-size: 13px; }
.page-btn:hover:not(.is-active) { border-color: #b5a898; color: #3a3530; }

/* ============================================================
   BANNER AREA
   ============================================================ */
.banner-area { background: #fff; border-top: 1px solid #e8e4de; padding: 56px 0; }
.banner-block { margin-bottom: 36px; }
.banner-block:last-child { margin-bottom: 0; }
.banner-block__label { font-size: 13px; color: #2c2c2c; margin-bottom: 16px; letter-spacing: 0.16em; text-transform: uppercase; padding-bottom: 10px; border-bottom: 1px solid #ede9e3; font-weight: 700; }
.banner-row { display: flex; gap: 16px; flex-wrap: wrap; }
.banner-item { height: 80px; flex: 1; min-width: 180px; border-radius: 4px; }
.banner-item--wide { height: 80px; flex: 1; min-width: 220px; border-radius: 4px; }
.banner-item--img { height: auto; overflow: hidden; display: flex; align-items: center; }
.banner-item--img img { width: 100%; height: auto; display: block; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: #2c2c2c; color: #888; padding: 60px 0 28px; }
.footer__logo { margin-bottom: 44px; display: block; }
.footer__logo img { height: 32px; filter: brightness(0) invert(1); }
.footer__nav { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; margin-bottom: 44px; }
.footer__nav-title { font-size: 11px; font-weight: 700; color: #fff; margin-bottom: 18px; letter-spacing: 0.12em; }
.footer__nav-list { list-style: none; }
.footer__nav-item { font-size: 11px; color: #777; padding: 5px 0; letter-spacing: 0.04em; }
.footer__sns { display: flex; gap: 20px; margin-bottom: 44px; align-items: center; }
.footer__sns-icon { font-size: 28px; color: #fff; line-height: 1; transition: opacity 0.18s; }
.footer__sns-icon:hover { opacity: 0.7; }
.footer__bottom { border-top: 1px solid #3e3a36; padding-top: 22px; text-align: center; }
.footer__copyright { font-size: 11px; color: #555; letter-spacing: 0.04em; }

/* ============================================================
   SHOP カード（検索結果・一覧ページ）
   ============================================================ */
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.shop-card { background: #fff; border-radius: 6px; box-shadow: 0 2px 10px rgba(58,53,48,0.07); display: block; transition: box-shadow 0.25s, transform 0.25s; overflow: hidden; }
.shop-card:hover { box-shadow: 0 8px 28px rgba(58,53,48,0.13); transform: translateY(-3px); }
.shop-card__img { width: 100%; aspect-ratio: 4/3; overflow: hidden; }
.shop-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.shop-card__body { padding: 18px 20px 22px; }
.shop-card__category { font-size: 11px; color: #b5935a; letter-spacing: 0.1em; margin-bottom: 6px; font-weight: 500; }
.shop-card__name { font-size: 16px; font-weight: 700; margin-bottom: 10px; line-height: 1.5; color: #2c2c2c; }
.shop-card__floor { font-size: 12px; color: #b0a898; display: flex; align-items: center; gap: 5px; margin-bottom: 12px; }
.shop-card__tags { display: flex; flex-wrap: wrap; gap: 4px; }
.shop-card__tag { font-size: 11px; border: 1px solid #e8d5bc; border-radius: 2px; padding: 4px 10px; color: #b5935a; background: #fdf8f3; letter-spacing: 0.04em; }

/* ============================================================
   GOURMET カード（検索結果・一覧ページ）
   ============================================================ */
.pickup-banner { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 52px; }
.pickup-card { position: relative; background: #fff; border-radius: 6px; overflow: hidden; box-shadow: 0 2px 10px rgba(58,53,48,0.07); transition: box-shadow 0.25s, transform 0.25s; }
.pickup-card:hover { box-shadow: 0 8px 28px rgba(58,53,48,0.13); transform: translateY(-3px); }
.pickup-card__img { width: 100%; height: 220px; overflow: hidden; }
.pickup-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pickup-card__label { position: absolute; top: 14px; left: 14px; background: #b5935a; color: #fff; font-size: 10px; padding: 4px 10px; letter-spacing: 0.1em; border-radius: 2px; }
.pickup-card__body { padding: 18px 20px 20px; }
.pickup-card__name { font-size: 16px; font-weight: 700; margin-bottom: 6px; color: #2c2c2c; }
.pickup-card__info { font-size: 11px; color: #b0a898; display: flex; align-items: center; gap: 5px; }
.genre-tabs { display: flex; gap: 4px; border-bottom: 2px solid #2c2c2c; margin-bottom: 32px; flex-wrap: wrap; }
.genre-tab { padding: 10px 20px; font-size: 12px; color: #665a50; border: 1px solid #e0d8ce; border-bottom: none; cursor: pointer; background: #faf8f5; letter-spacing: 0.06em; transition: all 0.15s; border-radius: 4px 4px 0 0; }
.genre-tab.is-active { background: #2c2c2c; color: #fff; border-color: #2c2c2c; }
.genre-tab:hover:not(.is-active) { background: #f0ece6; border-color: #c8bfb5; }
.gourmet-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.gourmet-card { background: #fff; border-radius: 6px; overflow: hidden; box-shadow: 0 2px 10px rgba(58,53,48,0.07); transition: box-shadow 0.25s, transform 0.25s; display: block; }
.gourmet-card:hover { box-shadow: 0 8px 28px rgba(58,53,48,0.13); transform: translateY(-3px); }
.gourmet-card__img { width: 100%; aspect-ratio: 4/3; overflow: hidden; }
.gourmet-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gourmet-card__body { padding: 16px 18px 20px; }
.gourmet-card__genre { font-size: 10px; color: #b5935a; margin-bottom: 6px; font-weight: 500; letter-spacing: 0.08em; }
.gourmet-card__name { font-size: 15px; font-weight: 700; margin-bottom: 8px; color: #2c2c2c; line-height: 1.4; }
.gourmet-card__floor { font-size: 11px; color: #b0a898; margin-bottom: 10px; display: flex; align-items: center; gap: 5px; }
.gourmet-card__hours { font-size: 11px; color: #665a50; border-top: 1px solid #f0ece6; padding-top: 10px; display: flex; align-items: center; gap: 5px; }

/* ============================================================
   OFFICE カード（検索結果・一覧ページ）
   ============================================================ */
.office-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.office-card { background: #fff; border-radius: 6px; box-shadow: 0 2px 10px rgba(58,53,48,0.07); display: block; transition: box-shadow 0.25s, transform 0.25s; overflow: hidden; }
.office-card:hover { box-shadow: 0 8px 28px rgba(58,53,48,0.13); transform: translateY(-3px); }
.office-card__img { width: 100%; aspect-ratio: 4/3; overflow: hidden; }
.office-card__body { padding: 18px 20px 22px; }
.office-card__category { font-size: 10px; color: #b5935a; letter-spacing: 0.1em; margin-bottom: 6px; font-weight: 500; }
.office-card__name { font-size: 15px; font-weight: 700; margin-bottom: 10px; line-height: 1.5; color: #2c2c2c; }
.office-card__floor { font-size: 11px; color: #b0a898; display: flex; align-items: center; gap: 5px; }

/* ============================================================
   SHOP DETAIL ページ
   ============================================================ */
.main-content { padding: 48px 0 24px; background: #fafafa; }
.section-bg { padding: 48px 0; }
.section-bg--white { background: #fafafa; }
.section-bg--cream { background: #f5f2ec; }
.shop-header { background: #fff; border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); padding: 48px; }
.shop-header__content { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.shop-identity { display: flex; align-items: center; gap: 20px; margin-bottom: 20px; }
.shop-logo { width: 80px; height: 80px; border-radius: 50%; background: #d0ccc8; border: 1px solid #c0bcb8; flex-shrink: 0; overflow: hidden; }
.shop-logo img { width: 100%; height: 100%; object-fit: cover; }
.shop-identity__text { flex: 1; }
.shop-name { font-size: 28px; font-weight: bold; color: #222; margin-bottom: 4px; }
.shop-name-ja { font-size: 13px; color: #888; }
.shop-catchcopy { font-size: 18px; color: #b5935a; font-weight: 500; margin-bottom: 16px; }
.shop-description { font-size: 14px; color: #555; line-height: 1.9; margin-bottom: 24px; }
.shop-badges { display: flex; gap: 8px; flex-wrap: wrap; }
.badge { display: inline-block; padding: 6px 14px; font-size: 12px; border-radius: 4px; }
.badge--primary { border: 1px solid #b5935a; color: #b5935a; }
.badge--new { background: #222; color: #fff; border: 1px solid #222; }
.badge--gourmet { border: 1px solid #7a9a5a; color: #7a9a5a; }
.gallery-main { width: 100%; aspect-ratio: 4/3; border-radius: 4px; overflow: hidden; margin-bottom: 12px; }
.gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.gallery-thumb { width: 100%; aspect-ratio: 4/3; border-radius: 4px; cursor: pointer; border: 3px solid transparent; transition: border-color 0.3s; object-fit: cover; display: block; }
.gallery-thumb:hover, .gallery-thumb.active { border-color: #b5935a; }
.info-section { margin-bottom: 0; }
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.info-box { background: #fff; border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); padding: 32px 32px 20px; display: flex; flex-direction: column; }
.info-box--fit { align-self: start; }
.info-table { width: 100%; border-collapse: collapse; }
.info-table th { padding: 18px 5% 18px 0; font-size: 12px; color: #222; font-weight: bold; text-align: left; vertical-align: top; width: 20%; white-space: nowrap; border-top: 1px solid #e8e4de; border-bottom: 2px solid #b5935a; }
.info-table td { padding: 18px 0 18px 20px; font-size: 14px; color: #333; vertical-align: top; border-top: 1px solid #e8e4de; border-bottom: 1px solid #e8e4de; word-break: break-all; }
.link { color: #b5935a; text-decoration: underline; }
.info-more-row { display: none; }
.info-more-trigger { margin-top: auto; padding-top: 12px; }
.info-close-row { margin-top: auto; padding-top: 12px; }
.info-more-btn { position: relative; display: flex; align-items: center; justify-content: center; width: 100%; padding: 16px 48px; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; color: #555; background: none; cursor: pointer; font-family: inherit; transition: all 0.3s; }
.info-more-btn i { position: absolute; right: 16px; }
.info-more-btn:hover { border-color: #b5935a; color: #b5935a; }
.info-sns { display: flex; gap: 16px; align-items: center; }
.info-sns__link { font-size: 22px; color: #555; transition: color 0.2s; }
.info-sns__link:hover { color: #b5935a; }
.floor-map__image { position: relative; border: 1px solid #ddd; border-radius: 4px; overflow: hidden; margin-bottom: 8px; }
.floor-map__image img { width: 100%; height: auto; display: block; }
.floor-map__pin { position: absolute; transform: translate(-50%, -100%); color: #ea4335; font-size: 24px; filter: drop-shadow(0 2px 3px rgba(0,0,0,0.35)); pointer-events: none; line-height: 1; }
.floor-map__link { position: relative; display: flex; align-items: center; justify-content: center; padding: 16px 48px; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; color: #555; transition: all 0.3s; margin-top: auto; }
.floor-map__link i { position: absolute; right: 16px; }
.floor-map__link:hover { border-color: #b5935a; color: #b5935a; }
.info-link { color: #b5935a; text-decoration: none; word-break: break-all; }
.info-link:hover { text-decoration: underline; }
.info-link i { font-size: 10px; margin-left: 4px; vertical-align: middle; }
.news-section { margin-bottom: 0; }
.recommend-section { margin-bottom: 0; }
.recommend-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; margin-bottom: 32px; }
.recommend-card { flex: 0 0 calc(25% - 15px); }
.recommend-card { background: #fff; border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); overflow: hidden; transition: box-shadow 0.3s; display: block; }
.recommend-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.recommend-card__image { width: 100%; height: 160px; overflow: hidden; }
.recommend-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.recommend-card:hover .recommend-card__image img { transform: scale(1.05); }
.recommend-card__body { padding: 16px; }
.recommend-card__name { font-size: 14px; font-weight: bold; color: #222; margin-bottom: 6px; transition: color 0.3s; }
.recommend-card:hover .recommend-card__name { color: #b5935a; }
.recommend-card__category { font-size: 12px; color: #888; margin-bottom: 4px; }
.recommend-card__floor { font-size: 11px; color: #aaa; }
.recommend-action { margin-top: 40px; }
.btn-more { position: relative; display: flex; align-items: center; justify-content: center; width: 40%; margin: 0 auto; padding: 16px 48px; background: #fff; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; color: #555; box-shadow: 0 1px 3px rgba(0,0,0,0.1); transition: all 0.3s; white-space: nowrap; }
.btn-more i { position: absolute; left: 16px; }
.btn-more:hover { border-color: #b5935a; color: #b5935a; }
.nd-slider { position: relative; background: #e5e2dc; border-radius: 4px; overflow: hidden; aspect-ratio: 4/3; }
.nd-slider__track { display: flex; height: 100%; transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
.nd-slider__slide { min-width: 100%; height: 100%; flex-shrink: 0; }
.nd-slider__slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nd-slider__arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; background: rgba(44,44,44,0.6); color: #fff; border: none; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 14px; transition: background 0.18s; z-index: 2; }
.nd-slider__arrow:hover { background: rgba(44,44,44,0.9); }
.nd-slider__arrow--prev { left: 12px; }
.nd-slider__arrow--next { right: 12px; }
.nd-slider__dots { position: absolute; bottom: 12px; left: 0; right: 0; display: flex; justify-content: center; gap: 6px; z-index: 2; }
.nd-slider__dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.5); border: none; cursor: pointer; transition: background 0.2s; padding: 0; }
.nd-slider__dot.is-active { background: #fff; }
.nd-thumbs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 10px; }
.nd-thumb { aspect-ratio: 4/3; border-radius: 3px; overflow: hidden; cursor: pointer; border: 2px solid transparent; transition: border-color 0.18s, opacity 0.18s; }
.nd-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nd-thumb.is-active { border-color: #b5935a; }
.nd-thumb:hover { opacity: 0.8; }

/* ============================================================
   NEWS PAGES 共通
   ============================================================ */
.news-tag { font-size: 10px; background: #f5f0e8; color: #b5935a; border: 1px solid #e8d9c0; border-radius: 2px; padding: 3px 10px; letter-spacing: 0.06em; white-space: nowrap; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 32px; }
.section-subtitle { font-size: 11px; color: #b5935a; letter-spacing: 0.14em; margin-top: 8px; padding-left: 16px; }
.nd-section { background: #fafafa; padding: 56px 0 72px; }
.nd-card { background: #fff; border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); padding: 48px; }
.nd-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.nd-page-title { font-size: 11px; font-weight: 700; color: #b5935a; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 24px; display: flex; align-items: center; gap: 8px; }
.nd-page-title::before { content: ''; width: 3px; height: 14px; background: #b5935a; border-radius: 2px; flex-shrink: 0; }
.nd-title { font-size: 22px; font-weight: 700; line-height: 1.55; color: #2c2c2c; letter-spacing: 0.04em; margin-bottom: 12px; }
.nd-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 28px; padding-bottom: 20px; border-bottom: 1px solid #e8e4de; flex-wrap: wrap; }
.nd-date { font-size: 12px; color: #b5935a; letter-spacing: 0.06em; }
.nd-body { font-size: 14px; line-height: 1.9; color: #3a3530; margin-bottom: 36px; }
.nd-body p { margin-bottom: 1.3em; }
.nd-shop-data { border-top: 2px solid #2c2c2c; }
.nd-shop-data__head { background: #2c2c2c; color: #fff; padding: 10px 16px; font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; display: inline-block; }
.nd-data-table { width: 100%; border-collapse: collapse; }
.nd-data-table tr { border-bottom: 1px solid #ede9e3; }
.nd-data-table tr:last-child { border-bottom: none; }
.nd-data-table th { width: 80px; padding: 13px 16px 13px 0; font-size: 12px; font-weight: 700; color: #b5935a; letter-spacing: 0.08em; white-space: nowrap; vertical-align: top; }
.nd-data-table td { padding: 13px 0; font-size: 13px; color: #3a3530; line-height: 1.6; vertical-align: top; }
.nd-floormap-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; background: #b5935a; color: #fff; border: none; font-size: 13px; font-weight: 700; padding: 15px; letter-spacing: 0.14em; cursor: pointer; transition: background 0.18s; font-family: inherit; margin-top: 20px; border-radius: 2px; text-decoration: none; }
.nd-floormap-btn:hover { background: #9a7c4a; }
.nd-back-link { position: relative; display: flex; align-items: center; justify-content: center; width: 100%; padding: 16px 48px; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; color: #555; background: none; margin-top: 28px; letter-spacing: 0.06em; transition: all 0.3s; text-decoration: none; }
.nd-back-link i { position: absolute; left: 16px; }
.nd-back-link:hover { border-color: #b5935a; color: #b5935a; }
.nd-related-section { background: #fafafa; padding: 56px 0; border-top: 1px solid #e8e4de; }
.nd-recommend-section { background: #f7f5f2; padding: 56px 0 72px; border-top: 1px solid #e8e4de; }
.nd-news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.nd-news-card { background: #fff; border: 1px solid #ede9e3; border-radius: 4px; overflow: hidden; text-decoration: none; color: inherit; transition: box-shadow 0.2s, transform 0.2s; }
.nd-news-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.08); transform: translateY(-2px); }
.nd-news-card__img { width: 100%; aspect-ratio: 16/9; overflow: hidden; }
.nd-news-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.nd-news-card:hover .nd-news-card__img img { transform: scale(1.04); }
.nd-news-card__body { padding: 14px 16px 16px; }
.nd-news-card__date { font-size: 11px; color: #b5935a; margin-bottom: 6px; }
.nd-news-card__title { font-size: 13px; font-weight: 700; line-height: 1.55; color: #2c2c2c; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.nd-news-list { display: flex; flex-direction: column; gap: 16px; }
.nd-news-hcard { display: flex; background: #fff; border: 1px solid #ede9e3; border-radius: 4px; overflow: hidden; text-decoration: none; color: inherit; transition: box-shadow 0.2s; }
.nd-news-hcard:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }
.nd-news-hcard__body { flex: 1; padding: 22px 28px; display: flex; flex-direction: column; gap: 10px; justify-content: center; }
.nd-news-hcard__meta { display: flex; align-items: center; gap: 10px; }
.nd-news-hcard__date { font-size: 12px; color: #b5935a; letter-spacing: 0.06em; }
.nd-news-hcard__title { font-size: 16px; font-weight: 700; line-height: 1.55; color: #2c2c2c; letter-spacing: 0.04em; }
.nd-news-hcard__desc { font-size: 13px; color: #665a50; line-height: 1.7; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.nd-news-hcard__shop { font-size: 12px; color: #aaa; display: flex; align-items: center; gap: 5px; margin-top: 4px; }
.nd-news-hcard__shop i { font-size: 11px; color: #b5935a; }
.nd-news-hcard__img { width: 240px; flex-shrink: 0; overflow: hidden; }
.nd-news-hcard__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; }
.nd-news-hcard:hover .nd-news-hcard__img img { transform: scale(1.04); }
.nd-recommend-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.nd-recommend-card { background: #fff; border: 1px solid #ede9e3; border-radius: 4px; overflow: hidden; text-decoration: none; color: inherit; transition: box-shadow 0.2s, transform 0.2s; }
.nd-recommend-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.08); transform: translateY(-2px); }
.nd-recommend-card__img { width: 100%; aspect-ratio: 16/9; overflow: hidden; }
.nd-recommend-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.nd-recommend-card:hover .nd-recommend-card__img img { transform: scale(1.04); }
.nd-recommend-card__body { padding: 14px 16px 16px; }
.nd-recommend-card__date { font-size: 11px; color: #b5935a; margin-bottom: 6px; }
.nd-recommend-card__title { font-size: 13px; font-weight: 700; line-height: 1.55; color: #2c2c2c; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.na-news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.na-news-card { background: #fff; border: 1px solid #ede9e3; border-radius: 4px; overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: box-shadow 0.2s, transform 0.2s; }
.na-news-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.08); transform: translateY(-2px); }
.na-news-card__img { width: 100%; aspect-ratio: 16/9; overflow: hidden; background: #e5e2dc; }
.na-news-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.na-news-card:hover .na-news-card__img img { transform: scale(1.04); }
.na-news-card__body { padding: 20px 20px 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.na-news-card__meta { display: flex; align-items: center; gap: 10px; }
.na-news-card__date { font-size: 11px; color: #b5935a; letter-spacing: 0.06em; }
.na-news-card__title { font-size: 14px; font-weight: 700; line-height: 1.55; color: #2c2c2c; letter-spacing: 0.04em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.na-news-card__shop { display: flex; align-items: center; gap: 6px; font-size: 11px; color: #888; margin-top: auto; padding-top: 10px; border-top: 1px solid #f0ece6; }
.na-news-card__shop i { font-size: 10px; color: #b5935a; }
.news-search-section { background: #fafafa; padding: 40px 0 56px; border-bottom: 1px solid #e8e4de; }
.news-search-bar { display: flex; align-items: stretch; background: #fff; border: 1.5px solid #ddd; border-radius: 4px; width: 100%; max-width: 640px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.04); transition: border-color 0.2s; margin: 0 auto 40px; }
.news-search-bar:focus-within { border-color: #b5935a; box-shadow: 0 2px 12px rgba(181,147,90,0.12); }
.news-search-bar__input { flex: 1; padding: 16px 18px; font-size: 15px; border: none; outline: none; background: transparent; color: #3a3530; letter-spacing: 0.04em; font-family: inherit; }
.news-search-bar__input::placeholder { color: #c0b8b0; }
.news-search-bar__btn { background: #b5935a; border: none; color: #fff; cursor: pointer; padding: 0 28px; display: flex; align-items: center; justify-content: center; gap: 8px; flex-shrink: 0; font-family: inherit; font-size: 14px; transition: background 0.18s; }
.news-search-bar__btn:hover { background: #9a7c4a; }
.news-filter-row { display: flex; flex-wrap: wrap; gap: 16px; align-items: flex-end; margin-bottom: 32px; }
.news-filter-group { display: flex; flex-direction: column; gap: 8px; }
.news-filter-label { font-size: 10px; font-weight: 700; color: #b5935a; letter-spacing: 0.16em; text-transform: uppercase; display: flex; align-items: center; gap: 6px; }
.news-filter-label::before { content: ''; width: 3px; height: 12px; background: #b5935a; border-radius: 2px; flex-shrink: 0; }
.news-search-actions { display: flex; align-items: center; justify-content: center; gap: 16px; padding-top: 28px; border-top: 1px solid #ede9e3; flex-wrap: wrap; }
.news-btn-search { display: flex; align-items: center; gap: 8px; background: #2c2c2c; color: #fff; border: none; font-size: 13px; padding: 14px 32px; letter-spacing: 0.14em; font-family: inherit; cursor: pointer; transition: background 0.18s; }
.news-btn-search:hover { background: #484440; }
.news-btn-reset { display: flex; align-items: center; gap: 8px; background: none; border: 1px solid #ccc; color: #888; font-size: 13px; padding: 14px 24px; letter-spacing: 0.1em; font-family: inherit; cursor: pointer; transition: all 0.18s; }
.news-btn-reset:hover { border-color: #999; color: #555; }
.news-result-count { font-size: 13px; color: #888; text-align: right; margin-top: 16px; width: 100%; }
.news-result-count strong { color: #2c2c2c; font-size: 22px; font-weight: 300; margin: 0 4px; }
.news-results-section { background: #f7f5f2; padding: 52px 0 72px; }
.news-sort-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; flex-wrap: wrap; gap: 12px; }
.news-sort-bar__count { font-size: 13px; color: #888; }
.news-sort-bar__count strong { color: #2c2c2c; font-weight: 700; }
.news-sort-bar__right { display: flex; align-items: center; gap: 8px; }
.news-sort-label { font-size: 11px; color: #aaa; letter-spacing: 0.08em; }

/* ============================================================
   TOP PAGE
   ============================================================ */
.top-section { background: #fff; border-top: 1px solid #e8e4de; padding: 52px 0; }
.top-section--gray { background: #f5f2ec; border-top: 1px solid #e8e4de; padding: 52px 0; }

/* 2. MAIN VISUAL */
.main-visual { overflow: hidden; position: relative; background: #2c2520; }
.main-visual::before { content: ''; position: absolute; inset: -20px; background: url('img/mv-bg.jpg') center/cover no-repeat; filter: blur(8px); z-index: 0; pointer-events: none; }
.main-visual::after { content: ''; position: absolute; inset: 0; background: rgba(255,255,255,0.38); z-index: 0; pointer-events: none; }
.main-visual__stage { position: relative; z-index: 1; padding: 40px 0 24px; }
.main-visual__track { display: flex; align-items: center; gap: 0; transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94); will-change: transform; }
.main-visual__slide { flex: 0 0 50%; height: auto; aspect-ratio: 1500 / 1000; border: 12px solid #fff; box-shadow: 0 6px 28px rgba(0,0,0,0.22); transform: scale(0.92); transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94); overflow: hidden; position: relative; display: flex; align-items: center; justify-content: center; margin-right: -80px; z-index: 1; }
.main-visual__slide::after { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,0.3); transition: opacity 0.6s ease; z-index: 2; pointer-events: none; }
.main-visual__slide a { position: absolute; inset: 0; display: block; z-index: 3; }
.main-visual__slide img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; position: absolute; inset: 0; transform: scale(1.06); transition: transform 6s ease; }
.main-visual__slide.is-active { transform: scale(1); z-index: 2; }
.main-visual__slide.is-active::after { opacity: 0; }
.main-visual__slide.is-active img { transform: scale(1); }
.main-visual__slide.is-jump-target,
.main-visual__slide.is-jump-target::after { transition: none !important; }
.main-visual__slide.is-jump-target img { transition: none !important; transform: scale(1.06) !important; }
.main-visual__arrow { position: absolute; top: 50%; background: none; border: none; color: #fff; font-size: 56px; cursor: pointer; z-index: 20; padding: 8px; text-shadow: 0 2px 16px rgba(0,0,0,0.6); line-height: 1; transition: transform 0.2s; }
.main-visual__arrow--prev { left: 25%; transform: translate(-50%, -50%); }
.main-visual__arrow--next { right: 25%; transform: translate(50%, -50%); }
.main-visual__arrow--prev:hover { transform: translate(-60%, -50%); }
.main-visual__arrow--next:hover { transform: translate(60%, -50%); }
.main-visual__dots { display: none; }
.main-visual__thumbs { position: relative; z-index: 1; display: flex; justify-content: center; gap: 12px; padding: 0 0 32px; }
.main-visual__thumb { width: 160px; height: 107px; border: 3px solid transparent; overflow: hidden; cursor: pointer; transition: border-color 0.2s, opacity 0.2s; background: #5a5048; opacity: 0.6; flex-shrink: 0; }
.main-visual__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.main-visual__thumb--active { border-color: #fff; opacity: 1; }

/* 3. QUICK NAV */
.quick-nav { background: #fff; border-bottom: 1px solid #e8e4de; padding: 24px 0; }
.quick-nav__list { display: grid; grid-template-columns: repeat(6, 1fr); max-width: 1100px; margin: 0 auto; }
.quick-nav__item { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 12px 20px; border-right: 1px solid #ede9e3; cursor: pointer; text-decoration: none; transition: opacity 0.2s; }
.quick-nav__item:first-child { border-left: 1px solid #ede9e3; }
.quick-nav__item:hover .quick-nav__icon { opacity: 0.65; }
.quick-nav__icon { display: flex; align-items: center; justify-content: center; }
.quick-nav__icon img { height: 36px; width: auto; }
.quick-nav__label { font-size: 13px; color: #665a50; letter-spacing: 0.04em; text-align: center; line-height: 1.4; white-space: nowrap; }

/* 4. 営業時間 + 検索 */
.hours-search { background: #f5f2ec; border-top: 1px solid #e8e4de; padding: 40px 0; }
.hours-search__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: start; }
.hours__title { font-size: 18px; font-weight: 700; margin-bottom: 18px; display: flex; align-items: center; gap: 10px; color: #2c2c2c; letter-spacing: 0.1em; }
.hours__icon { font-size: 28px; color: #C8A96E; }
.hours__table { width: 100%; border-collapse: collapse; }
.hours__table td { padding: 8px 12px 8px 0; font-size: 13px; border-bottom: 1px solid #ede9e3; color: #665a50; }
.hours__table td:last-child { font-size: 16px; font-weight: 700; color: #2c2c2c; }
.hours__note { font-size: 11px; color: #b0a898; margin-top: 12px; line-height: 1.8; }
.search__title { font-size: 18px; font-weight: 700; margin-bottom: 18px; letter-spacing: 0.1em; color: #2c2c2c; }
.search__bar { display: flex; border: 1.5px solid #ddd; border-radius: 4px; margin-bottom: 16px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.04); transition: border-color 0.2s; }
.search__bar:focus-within { border-color: #C8A96E; box-shadow: 0 2px 12px rgba(181,147,90,0.12); }
.search__input { flex: 1; padding: 12px 16px; font-size: 13px; border: none; outline: none; background: #fff; font-family: inherit; color: #3a3530; }
.search__input::placeholder { color: #c0b8b0; }
.search__btn { width: 48px; background: #C8A96E; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 16px; border: none; cursor: pointer; transition: background 0.18s; }
.search__btn:hover { background: #b5a058; }
.search__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.search__tag { font-size: 11px; border: 1px solid #e0d8ce; border-radius: 20px; padding: 5px 14px; color: #665a50; background: #fff; cursor: pointer; transition: all 0.18s; text-decoration: none; display: inline-block; }
.search__tag:hover { border-color: #C8A96E; color: #C8A96E; }
.search__tag--category { font-size: 11px; color: #C8A96E; font-weight: 700; letter-spacing: 0.08em; margin-top: 8px; width: 100%; }

/* 5. イベント + カレンダー */
.event-calendar__inner { display: grid; grid-template-columns: 1fr 340px; gap: 48px; align-items: start; }
.event-slider { position: relative; overflow: hidden; }
.event-slider__track { display: flex; gap: 20px; }
.event-slider__nav { display: flex; align-items: center; justify-content: space-between; margin-top: 18px; }
.event-slider__arrow { width: 36px; height: 36px; border: 1px solid #e0d8ce; background: #fff; display: flex; align-items: center; justify-content: center; font-size: 16px; color: #665a50; cursor: pointer; }
.event-slider__dots { display: flex; gap: 8px; }
.event-slider__dot { width: 8px; height: 8px; border-radius: 50%; background: #e0d8ce; cursor: pointer; }
.event-slider__dot--active { background: #C8A96E; }
.event-card { width: 340px; flex-shrink: 0; border: 1px solid #ede9e3; background: #fff; border-radius: 6px; overflow: hidden; text-decoration: none; display: block; color: inherit; }
.event-card__img { width: 100%; height: 230px; object-fit: contain; background: #f9f6f2; display: block; }
.event-card__body { padding: 16px; }
.event-card__tag { font-size: 10px; border: 1px solid #e8d5bc; border-radius: 20px; padding: 3px 10px; display: inline-block; margin-bottom: 8px; color: #C8A96E; background: #fdf8f3; }
.event-card__title { font-size: 13px; font-weight: 700; margin-bottom: 8px; line-height: 1.5; color: #2c2c2c; }
.event-card__date { font-size: 11px; color: #b0a898; }
.calendar-subtitle { font-size: 11px; font-weight: 700; color: #C8A96E; margin-bottom: 14px; letter-spacing: 0.1em; text-transform: uppercase; }
.calendar { border: 1px solid #ede9e3; background: #fff; padding: 18px; border-radius: 4px; }
.calendar__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.calendar__month { font-size: 15px; font-weight: 700; color: #2c2c2c; letter-spacing: 0.06em; }
.calendar__arrow { width: 28px; height: 28px; border: 1px solid #e0d8ce; display: flex; align-items: center; justify-content: center; font-size: 12px; color: #C8A96E; cursor: pointer; }
.calendar__grid { width: 100%; border-collapse: collapse; text-align: center; table-layout: fixed; }
.calendar__grid th { font-size: 11px; color: #b0a898; padding: 5px 0; font-weight: 400; }
.calendar__grid th:first-child { color: #d94040; }
.calendar__grid th:last-child { color: #4070c8; }
.calendar__grid td { font-size: 12px; padding: 7px 0; cursor: pointer; color: #3a3530; }
.calendar__grid td:first-child { color: #d94040; }
.calendar__grid td:last-child { color: #4070c8; }
.calendar__grid td:hover { background: #fdf8f3; }
.calendar__grid .holiday { background: #fff0f0; color: #d94040 !important; }
.calendar__grid .today span,
.calendar__grid .closed span,
.calendar__grid .has-event span { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 50%; color: #fff; line-height: 1; }
.calendar__grid .today span { background: #888888; }
.calendar__grid .closed span { background: #d94040; font-weight: 700; }
.calendar__grid .has-event span { background: #C8A96E; }
.calendar__legend { display: flex; gap: 12px; margin-top: 12px; font-size: 10px; color: #665a50; flex-wrap: wrap; }
.calendar__legend-item { display: flex; align-items: center; gap: 5px; }
.calendar__legend-dot { width: 8px; height: 8px; flex-shrink: 0; }
.calendar__legend-dot--holiday { background: #ffb8b8; border-radius: 2px; }
.calendar__legend-dot--closed { background: #d94040; border-radius: 50%; }
.calendar__legend-dot--today { background: #888888; border-radius: 50%; }
.calendar__legend-dot--event { background: #C8A96E; border-radius: 50%; }
.calendar__closed-note { font-size: 13px; font-weight: 700; color: #d94040; margin-top: 12px; line-height: 1.6; border: 2px solid #d94040; border-radius: 4px; padding: 14px 16px; display: block; text-align: center; }

/* 6. ショップニュース */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.news-card { border: 1px solid #ede9e3; background: #fff; border-radius: 6px; overflow: hidden; transition: box-shadow 0.25s, transform 0.25s; text-decoration: none; display: block; }
.news-card:hover { box-shadow: 0 8px 24px rgba(58,53,48,0.1); transform: translateY(-2px); }
.news-card__img { width: 100%; height: 180px; object-fit: cover; display: block; }
.news-card__body { padding: 14px 16px; }
.news-card__tag { font-size: 10px; border: 1px solid #e8d5bc; border-radius: 20px; padding: 3px 10px; display: inline-block; margin-bottom: 8px; color: #C8A96E; background: #fdf8f3; }
.news-card__title { font-size: 13px; font-weight: 700; line-height: 1.5; margin-bottom: 8px; color: #2c2c2c; }
.news-card__shop { font-size: 11px; color: #665a50; }
.news-card__date { font-size: 11px; color: #b0a898; }

/* 7. グルメ（横スクロール） */
.gourmet-scroll { overflow-x: auto; padding-bottom: 12px; }
.gourmet-scroll::-webkit-scrollbar { height: 4px; }
.gourmet-scroll::-webkit-scrollbar-track { background: #f0ece6; }
.gourmet-scroll::-webkit-scrollbar-thumb { background: #d4b896; border-radius: 2px; }
.gourmet-list { display: flex; gap: 20px; width: max-content; }
.gourmet-scroll .gourmet-card { width: 220px; background: #fff; flex-shrink: 0; border-radius: 6px; overflow: hidden; display: block; box-shadow: 0 2px 8px rgba(58,53,48,0.06); transition: box-shadow 0.25s, transform 0.25s; text-decoration: none; }
.gourmet-scroll .gourmet-card:hover { box-shadow: 0 6px 20px rgba(58,53,48,0.12); transform: translateY(-2px); }
.gourmet-scroll .gourmet-card__img { width: 100%; height: 150px; aspect-ratio: unset; object-fit: cover; display: block; }
.gourmet-scroll .gourmet-card__body { padding: 12px 14px; }
.gourmet-scroll .gourmet-card__category { font-size: 10px; color: #C8A96E; margin-bottom: 4px; font-weight: 500; }
.gourmet-scroll .gourmet-card__name { font-size: 13px; font-weight: 700; margin-bottom: 4px; color: #2c2c2c; line-height: 1.4; }
.gourmet-scroll .gourmet-card__floor { font-size: 11px; color: #b0a898; }

/* 8. NEWS */
.info-list { list-style: none; border-top: 1px solid #ede9e3; }
.info-item { display: flex; align-items: center; gap: 16px; padding: 14px 0; border-bottom: 1px solid #ede9e3; text-decoration: none; }
.info-item__date { font-size: 12px; color: #b0a898; white-space: nowrap; min-width: 90px; letter-spacing: 0.04em; }
.info-item__tag { font-size: 10px; border: 1px solid #e8d5bc; border-radius: 20px; padding: 3px 12px; white-space: nowrap; color: #C8A96E; background: #fdf8f3; }
.info-item__title { font-size: 13px; flex: 1; color: #3a3530; }
.info-item__arrow { font-size: 12px; color: #d4ccc4; }

/* PHOTO BANNER */
.photo-banner { width: 100%; line-height: 0; }
.photo-banner img { width: 100%; height: auto; display: block; object-fit: cover; }

/* 9. INSTAGRAM */
.instagram__handle { text-align: center; font-size: 13px; color: #C8A96E; margin-bottom: 20px; letter-spacing: 0.08em; }
.instagram-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px; }
.instagram-grid__item { aspect-ratio: 1; }

/* 10. アクセス */
.access-section { position: relative; overflow: hidden; background: none; border-top: 1px solid #e8e4de; padding: 52px 0; }
.access-section::before { content: ''; position: absolute; inset: 0; background: url('img/pixta_20597215.jpg') center/cover no-repeat; z-index: 0; }
.access-section::after { content: ''; position: absolute; inset: 0; background: rgba(255,255,255,0.65); z-index: 0; }
.access-section .container { position: relative; z-index: 1; }
.access__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.access__map { width: 100%; height: 300px; }
.access__info { background: rgba(255,255,255,0.9); padding: 24px; }
.access__address { font-size: 13px; line-height: 2; margin-bottom: 22px; color: #665a50; }
.access__routes { list-style: none; }
.access__route { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid #ede9e3; font-size: 13px; color: #3a3530; }
.access__route-icon { width: 20px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: #C8A96E; font-size: 15px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .container { padding: 0 28px; }
  .shop-grid { grid-template-columns: repeat(2, 1fr); }
  .gourmet-grid { grid-template-columns: repeat(2, 1fr); }
  .office-grid { grid-template-columns: repeat(2, 1fr); }
  .kana-grid { grid-template-columns: repeat(7, 1fr); }
}
@media (max-width: 900px) {
  .nd-card { padding: 28px; }
  .nd-layout { grid-template-columns: 1fr; gap: 40px; }
  .nd-right { order: -1; }
  .nd-recommend-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .container { padding: 0 20px; }
  /* ヘッダー */
  .header__utils .header__util-link,
  .header__utils .header__sep,
  .header__utils .header__lang,
  .header__utils .header__tenant-btn { display: none; }
  .header__sp-icon { display: flex; flex-direction: column; align-items: center; gap: 3px; text-decoration: none; color: #2c2c2c; font-size: 9px; letter-spacing: 0.06em; padding: 0 8px; white-space: nowrap; }
  .header__sp-icon i { font-size: 20px; }
  .header__sp-sep { display: block; width: 1px; height: 28px; background: #c8c0b8; align-self: center; }
  .header__logo { width: 130px; height: 30px; }
  .header__hamburger { width: 44px; height: 44px; border-radius: 50%; padding: 0; margin-left: 8px; gap: 4px; }
  .header__hamburger i { width: 18px; }
  /* トップページ */
  .top-section { padding: 36px 0; }
  .top-section--gray { padding: 36px 0; }
  .main-visual__stage { padding: 0; }
  .main-visual__slide { flex: 0 0 100%; height: auto; aspect-ratio: 1500 / 1000; border-width: 8px; margin-right: 0; transform: none !important; }
  .main-visual__slide::after { display: none; }
  .main-visual__arrow { font-size: 28px; }
  .main-visual__arrow--prev { left: 12px; transform: translate(0, -50%); }
  .main-visual__arrow--next { right: 12px; transform: translate(0, -50%); }
  .main-visual__arrow--prev:hover { transform: translate(0, -50%); }
  .main-visual__arrow--next:hover { transform: translate(0, -50%); }
  .main-visual__thumbs { gap: 8px; padding: 10px 12px 20px; }
  .main-visual__thumb { width: 120px; height: 80px; border-width: 3px; }
  .quick-nav { padding: 16px 0; }
  .quick-nav__list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
  .quick-nav__item { padding: 16px 8px; border-right: 1px solid #ede9e3; border-bottom: 1px solid #ede9e3; }
  .quick-nav__item:first-child { border-left: none; }
  .quick-nav__item:nth-child(4) { border-left: none; }
  .quick-nav__icon img { height: 28px; }
  .quick-nav__label { font-size: 11px; }
  .hours-search { padding: 28px 0; }
  .hours-search__inner { grid-template-columns: 1fr; gap: 28px; }
  .event-calendar__inner { grid-template-columns: 1fr; gap: 28px; }
  .calendar-wrap { display: block; }
  .event-card { min-width: calc(80vw - 40px); width: auto; }
  .event-card__img { object-fit: cover; background: none; }
  .news-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .news-card__img { height: 140px; }
  .instagram-grid { grid-template-columns: repeat(3, 1fr); }
  .access-section { padding: 36px 0; }
  .access__inner { grid-template-columns: 1fr; gap: 24px; }
  .access__map { height: 220px; }
  .info-item { flex-wrap: wrap; gap: 8px; }
  .info-item__date { min-width: auto; }
  .info-item__title { width: 100%; }
  /* 検索ページ */
  .shop-header { padding: 24px; }
  .shop-header__content, .info-grid { grid-template-columns: 1fr; gap: 32px; }
  .recommend-grid .recommend-card { flex: 0 0 calc(50% - 10px); }
  .news-search-bar { max-width: 100%; }
  .news-filter-row { flex-direction: column; align-items: stretch; }
  .news-filter-group { width: 100%; }
  .news-search-actions { flex-direction: column; align-items: stretch; }
  .news-btn-search, .news-btn-reset { width: 100%; justify-content: center; }
  .na-news-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .news-sort-bar { flex-direction: column; align-items: flex-start; }
  .page-hero { padding: 40px 0 36px; }
  .page-hero__en { font-size: 32px; }
  .search-panel { padding: 32px 0 40px; }
  .search-bar-wrap { padding: 0; }
  .search-bar { width: 100%; max-width: 100%; }
  .search-bar__input { padding: 14px 12px; font-size: 14px; min-width: 0; }
  .search-bar__btn { padding: 0 16px; font-size: 13px; }
  .filter-row { flex-direction: column; gap: 28px; }
  .filter-row .filter-section { width: 100%; margin-bottom: 0; }
  .filter-selects { flex-direction: row; }
  .filter-select { min-width: 0; flex: 1; }
  .shop-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .gourmet-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .office-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .kana-grid { grid-template-columns: repeat(5, 1fr); }
  .sort-bar { flex-direction: column; align-items: flex-start; gap: 12px; }
  .footer__nav { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .search-actions { flex-wrap: wrap; gap: 12px; }
  .pickup-banner { grid-template-columns: 1fr; }
  .banner-area { padding: 36px 0; }
  .banner-item--wide { min-width: 0; width: 100%; flex: none; }
  .banner-row:has(.banner-item--wide) { flex-direction: column; }
}
@media (max-width: 600px) {
  .nd-title { font-size: 18px; }
  .nd-news-hcard__img { width: 120px; }
  .nd-news-hcard__body { padding: 14px 16px; }
  .nd-news-hcard__title { font-size: 14px; }
  .nd-news-hcard__desc { display: none; }
  .nd-news-grid { grid-template-columns: 1fr; }
  .nd-recommend-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .section-head { flex-direction: column; gap: 8px; align-items: flex-start; }
}
@media (max-width: 480px) {
  .recommend-grid .recommend-card { flex: 0 0 100%; }
  .shop-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .gourmet-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .office-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .kana-grid { grid-template-columns: repeat(5, 1fr); }
  .footer__nav { grid-template-columns: 1fr 1fr; }
  .na-news-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   入居届フォーム（page-nyukyo.php）
   ============================================================ */

/* ステップナビ */
.nyukyo-step-nav { background: #fff; border-bottom: 1px solid #e8e4de; padding: 28px 0 0; }
.nyukyo-step-nav__inner { display: flex; align-items: flex-end; justify-content: center; }
.nyukyo-step-item { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 0 0 20px; position: relative; min-width: 120px; }
.nyukyo-step-item + .nyukyo-step-item::before { content: ''; position: absolute; left: 0; top: 20px; width: 100%; height: 2px; background: #e0d8ce; transform: translateX(-50%); z-index: 0; }
.nyukyo-step-item.is-done + .nyukyo-step-item::before { background: #b5935a; }
.nyukyo-step-num { width: 40px; height: 40px; border-radius: 50%; border: 2px solid #e0d8ce; background: #fff; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: #c0b0a0; position: relative; z-index: 1; transition: all 0.2s; }
.nyukyo-step-item.is-active .nyukyo-step-num { background: #b5935a; border-color: #b5935a; color: #fff; box-shadow: 0 0 0 4px rgba(181,147,90,0.15); }
.nyukyo-step-item.is-done .nyukyo-step-num { background: #b5935a; border-color: #b5935a; color: #fff; }
.nyukyo-step-label { font-size: 11px; color: #b0a898; letter-spacing: 0.1em; text-align: center; }
.nyukyo-step-item.is-active .nyukyo-step-label,
.nyukyo-step-item.is-done .nyukyo-step-label { color: #b5935a; }
.nyukyo-step-item.is-active .nyukyo-step-label { font-weight: 700; }
.nyukyo-step-bar { position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: transparent; }
.nyukyo-step-item.is-active .nyukyo-step-bar { background: #b5935a; }

/* ステップ非表示デフォルト（JS未起動時フォールバック） */
.nyukyo-step { display: none; }
.nyukyo-step[data-step="1"] { display: block; }

/* フォーム背景 */
.nyukyo-form-bg { background: #f7f5f2; min-height: 60vh; padding-bottom: 80px; }
.nyukyo-form-wrap { max-width: 780px; margin: 0 auto; padding: 48px 40px; }

/* カード */
.nyukyo-card { background: #fff; border: 1px solid #e8e4de; border-radius: 4px; padding: 48px 52px; margin-bottom: 28px; }
.nyukyo-card__title { font-family: 'Shippori Mincho', serif; font-size: 22px; font-weight: 600; color: #2c2c2c; letter-spacing: 0.08em; margin-bottom: 8px; }
.nyukyo-card__title span { color: #b5935a; }
.nyukyo-card__desc { font-size: 13px; color: #888; margin-bottom: 28px; line-height: 1.8; }

/* 注意書き */
.nyukyo-notice { background: #fffbf4; border: 1px solid #f0e0c0; border-radius: 3px; padding: 16px 20px; font-size: 12px; color: #8a7040; line-height: 1.9; margin-bottom: 24px; }
.nyukyo-notice__title { font-weight: 700; margin-bottom: 6px; display: flex; align-items: center; gap: 8px; }
.nyukyo-notice ul { padding-left: 16px; list-style: disc; }
.req-mark { color: #c0392b; }

/* 必須項目注釈 */
.nyukyo-required-note { font-size: 11px; color: #c0392b; text-align: right; margin: -4px 0 4px; }

/* フォーム行 */
.form-row { display: flex; align-items: flex-start; gap: 28px; padding: 20px 0; border-bottom: 1px solid #f0ece6; }
.nyukyo-required-note + .form-row,
.form-row:first-of-type { border-top: 1px solid #f0ece6; }
.form-label { flex: 0 0 190px; font-size: 13px; color: #2c2c2c; font-weight: 500; padding-top: 10px; letter-spacing: 0.04em; line-height: 1.5; }
.form-label .req { display: inline-block; background: #c0392b; color: #fff; font-size: 9px; padding: 2px 5px; border-radius: 2px; letter-spacing: 0.04em; margin-left: 6px; font-weight: 700; }
.form-label .opt { display: inline-block; background: #999; color: #fff; font-size: 9px; padding: 2px 5px; border-radius: 2px; letter-spacing: 0.04em; margin-left: 6px; }
.form-label .sub { display: block; font-size: 11px; color: #aaa; margin-top: 3px; font-weight: 400; }
.form-field { flex: 1; min-width: 0; }
.form-note { font-size: 11px; color: #aaa; margin-top: 6px; line-height: 1.7; }

/* CF7 input スタイル統一 */
.nyukyo-cf7-wrap .inp,
.nyukyo-cf7-wrap input[type="text"].inp,
.nyukyo-cf7-wrap input[type="email"].inp,
.nyukyo-cf7-wrap input[type="tel"].inp,
.nyukyo-cf7-wrap input[type="url"].inp,
.nyukyo-cf7-wrap textarea.inp,
.nyukyo-cf7-wrap select.inp { width: 100%; border: 1px solid #ddd; border-radius: 3px; padding: 10px 14px; font-size: 14px; font-family: inherit; color: #3a3530; background: #fff; outline: none; transition: border-color 0.18s, box-shadow 0.18s; line-height: 1.5; appearance: none; }
.nyukyo-cf7-wrap input.inp:focus,
.nyukyo-cf7-wrap textarea.inp:focus,
.nyukyo-cf7-wrap select.inp:focus { border-color: #b5935a; box-shadow: 0 0 0 3px rgba(181,147,90,0.1); }
.nyukyo-cf7-wrap textarea.inp { min-height: 100px; resize: vertical; }
.nyukyo-cf7-wrap select.inp { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23b5935a'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; cursor: pointer; }

/* カスタムラジオボタン */
.nyukyo-radio-wrap { display: flex; flex-direction: row; flex-wrap: wrap; gap: 10px; padding-top: 4px; }
.nyukyo-radio-wrap[data-field="type_of_notification"],
.nyukyo-radio-wrap[data-field="sale_type"] { flex-wrap: nowrap; }
.nyukyo-radio-item { display: flex; align-items: center; gap: 8px; font-size: 14px; color: #3a3530; cursor: pointer; padding: 8px 14px; border: 1px solid #e0d8ce; border-radius: 3px; transition: all 0.15s; user-select: none; }
.nyukyo-radio-item:hover { border-color: #b5935a; background: #fdf8f3; }
.nyukyo-radio-item.is-checked { border-color: #b5935a; background: #fdf8f3; color: #b5935a; font-weight: 500; }
.nyukyo-radio-item input[type="radio"] { accent-color: #b5935a; width: 15px; height: 15px; flex-shrink: 0; pointer-events: none; }

/* acceptance */
.nyukyo-cf7-wrap .wpcf7-acceptance .wpcf7-list-item { margin: 0; }
.nyukyo-cf7-wrap .wpcf7-acceptance label { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: #2c2c2c; cursor: pointer; }
.nyukyo-cf7-wrap .wpcf7-acceptance input[type="checkbox"] { accent-color: #b5935a; width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; }

/* 文字カウンター */
.inp-with-counter { position: relative; }
.char-counter { position: absolute; right: 10px; bottom: 8px; font-size: 10px; color: #c0b0a0; pointer-events: none; }
.inp-with-counter .inp { padding-right: 56px; }
.textarea-counter { bottom: 12px; }

/* キーワード */
.keyword-rows { display: flex; flex-direction: column; gap: 8px; }
.keyword-row { display: flex; align-items: center; gap: 10px; }
.keyword-num { width: 22px; height: 22px; border-radius: 50%; background: #e8e4de; display: flex; align-items: center; justify-content: center; font-size: 11px; color: #888; flex-shrink: 0; }

/* SNS */
.sns-rows { display: flex; flex-direction: column; gap: 12px; }
.sns-row { display: flex; align-items: center; gap: 12px; }
.sns-icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.sns-icon--ig { background: #fce4ec; color: #e91e63; }
.sns-icon--x  { background: #e8e8e8; color: #111; }
.sns-icon--fb { background: #e3f2fd; color: #1565c0; }
.sns-icon--ln { background: #e8f5e9; color: #2e7d32; }
.sns-icon--other { background: #f3e5f5; color: #7b1fa2; }

/* カテゴリー */
.category-select { display: flex; flex-direction: column; gap: 16px; }
.category-main { display: flex; gap: 12px; }
.category-btn { flex: 1; padding: 14px 8px; border: 1px solid #e0d8ce; border-radius: 3px; background: #fff; font-size: 13px; color: #665a50; font-family: inherit; cursor: pointer; text-align: center; letter-spacing: 0.06em; transition: all 0.15s; }
.category-btn:hover { border-color: #b5935a; background: #fdf8f3; }
.category-btn.is-active { background: #b5935a; color: #fff; border-color: #b5935a; font-weight: 700; }
.category-sub { display: flex; flex-wrap: wrap; gap: 8px; padding: 16px; background: #f7f5f2; border-radius: 3px; }
.category-sub__label { width: 100%; font-size: 11px; color: #aaa; margin-bottom: 4px; letter-spacing: 0.08em; }
.category-sub__btn { font-size: 12px; border: 1px solid #e0d8ce; border-radius: 20px; padding: 7px 18px; color: #665a50; background: #fff; cursor: pointer; transition: all 0.15s; font-family: inherit; }
.category-sub__btn:hover { border-color: #b5935a; color: #b5935a; }
.category-sub__btn.is-active { background: #b5935a; color: #fff; border-color: #b5935a; }

/* アップロードエリア */
.upload-area { border: 2px dashed #d4ccc4; border-radius: 4px; background: #fafaf8; padding: 32px 20px; text-align: center; cursor: pointer; transition: all 0.2s; position: relative; }
.upload-area:hover,
.upload-area.is-dragover { border-color: #b5935a; background: #fdf8f3; }
.upload-area__icon { font-size: 32px; color: #d4ccc4; margin-bottom: 10px; transition: color 0.2s; }
.upload-area:hover .upload-area__icon { color: #b5935a; }
.upload-area__text { font-size: 13px; color: #999; line-height: 1.7; }
.upload-area__text strong { display: block; font-size: 14px; color: #665a50; margin-bottom: 4px; }
.upload-area__input { position: absolute; opacity: 0; width: 0; height: 0; overflow: hidden; }

/* 写真グリッド */
.photo-grid { display: flex; flex-direction: column; gap: 12px; }
.photo-grid__main .upload-area { padding: 48px 20px; }
.photo-grid__subs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.photo-upload { display: flex; flex-direction: column; gap: 8px; }
.photo-upload__label { font-size: 12px; color: #888; text-align: center; }

/* 同意ボックス */
.consent-box { border: 1px solid #e0d8ce; border-radius: 3px; padding: 24px; background: #fafaf8; }
.consent-text { font-size: 13px; color: #555; line-height: 2; height: 160px; overflow-y: auto; margin-bottom: 20px; }

/* 非表示フィールド（hidden CF7 fields） */
.nyukyo-hidden-field { display: none !important; }

/* ナビボタン */
.nyukyo-nav { display: flex; align-items: center; justify-content: center; gap: 16px; padding-top: 8px; }
.nyukyo-btn-prev { background: #fff; border: 1px solid #d4ccc4; color: #665a50; font-size: 13px; font-family: inherit; padding: 14px 32px; letter-spacing: 0.1em; cursor: pointer; display: flex; align-items: center; gap: 10px; transition: all 0.18s; }
.nyukyo-btn-prev:hover { border-color: #b5a898; color: #3a3530; }
.nyukyo-btn-next { background: #2c2c2c; color: #fff; border: none; font-size: 13px; font-family: inherit; padding: 14px 44px; letter-spacing: 0.14em; cursor: pointer; display: flex; align-items: center; gap: 10px; font-weight: 500; transition: background 0.18s; }
.nyukyo-btn-next:hover { background: #484440; }
.nyukyo-btn-submit { background: #b5935a; color: #fff; border: none; font-size: 14px; font-family: inherit; padding: 16px 52px; letter-spacing: 0.16em; cursor: pointer; display: flex; align-items: center; gap: 12px; font-weight: 500; transition: background 0.18s; }
.nyukyo-btn-submit:hover { background: #9e7d47; }

/* バリデーションエラー */
.form-row.has-error .form-field > .inp,
.form-row.has-error .form-field > div > .inp { border-color: #c0392b; }
.nyukyo-error-tip { display: block; font-size: 11px; color: #c0392b; margin-top: 6px; }

/* CF7 エラーメッセージ非表示（自前でハンドリング） */
.nyukyo-cf7-wrap .wpcf7-not-valid-tip { display: none; }

/* 確認画面 */
.nyukyo-confirm-section { margin-bottom: 36px; }
.nyukyo-confirm-title { font-size: 13px; color: #b5935a; font-weight: 700; letter-spacing: 0.14em; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid #e8e4de; display: flex; align-items: center; justify-content: space-between; }
.nyukyo-confirm-table { width: 100%; border-collapse: collapse; }
.nyukyo-confirm-table th,
.nyukyo-confirm-table td { padding: 12px 14px; border-bottom: 1px solid #f0ece6; font-size: 14px; text-align: left; vertical-align: top; }
.nyukyo-confirm-table th { width: 180px; color: #888; font-weight: 400; font-size: 13px; }
.nyukyo-confirm-edit { font-size: 11px; color: #b5935a; border: 1px solid #e0d4c0; padding: 4px 12px; border-radius: 2px; cursor: pointer; background: none; font-family: inherit; transition: all 0.15s; white-space: nowrap; }
.nyukyo-confirm-edit:hover { background: #fdf8f3; }

/* 送信完了 */
.nyukyo-complete__inner { text-align: center; padding: 40px 20px; }
.nyukyo-complete__icon { font-size: 56px; color: #b5935a; margin-bottom: 24px; }
.nyukyo-complete__title { font-family: 'Shippori Mincho', serif; font-size: 26px; color: #2c2c2c; margin-bottom: 16px; letter-spacing: 0.06em; }
.nyukyo-complete__text { font-size: 14px; color: #666; line-height: 2; }
.nyukyo-complete__note { font-size: 12px; color: #aaa; }
.nyukyo-complete__btn { margin-top: 40px; display: flex; justify-content: center; }

/* CF7 submitボタン（JS経由でのみ発火） */
#nyukyo-cf7-submit { display: none; }

/* レスポンシブ */
@media (max-width: 768px) {
  .nyukyo-form-wrap { padding: 28px 20px; }
  .nyukyo-card { padding: 28px 20px; }
  .form-row { flex-direction: column; gap: 8px; }
  .form-label { flex: none; padding-top: 0; }
  .nyukyo-step-item { min-width: 64px; }
  .nyukyo-step-label { font-size: 10px; }
  .photo-grid__subs { grid-template-columns: 1fr; }
  .nyukyo-nav { flex-direction: column-reverse; }
  .nyukyo-btn-next,
  .nyukyo-btn-prev,
  .nyukyo-btn-submit { width: 100%; justify-content: center; }
  .category-main { flex-direction: row; }
}
