/* ============================================================
   富士家 pages.css — サブページ共通
   ============================================================ */

/* ページヒーロー */
.page-hero{position:relative;min-height:340px;display:flex;align-items:center;padding-top:64px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(.6) brightness(.45);transform:scale(1.04);animation:heroZoom 12s ease-out forwards}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,8,6,.75) 0%,rgba(10,8,6,.3) 70%,transparent 100%),linear-gradient(to top,rgba(10,8,6,.6) 0%,transparent 60%)}
.page-hero-dark{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-soft) 100%)}
.page-hero-dark::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(184,148,42,.08) 0%,transparent 55%),radial-gradient(ellipse at 70% 50%,rgba(155,35,53,.08) 0%,transparent 55%)}
.page-hero-content{position:relative;z-index:2;padding:3.5rem clamp(1rem,6vw,4rem) 4.5rem;animation:fadeUp 1s .2s both}
.page-hero-en{font-family:var(--font-en);font-size:clamp(.65rem,1.2vw,.75rem);letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.page-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.2;margin-bottom:.75rem}
.page-hero-sub{font-size:clamp(.85rem,1.6vw,1rem);color:var(--paper-2);opacity:.8;letter-spacing:.06em}
.breadcrumb{position:absolute;bottom:1.25rem;left:clamp(1rem,6vw,4rem);z-index:2;display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--paper-2);opacity:.5}
.breadcrumb a:hover{opacity:1;color:var(--gold)}

/* 通知バナー */
.notice-banner{background:rgba(155,35,53,.18);border-top:1px solid rgba(155,35,53,.4);border-bottom:1px solid rgba(155,35,53,.4);padding:.85rem 0}
.notice-banner .container{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.88rem;color:var(--paper-2)}
.notice-icon{font-size:1rem;color:#e07080;flex-shrink:0}
.notice-link{margin-left:auto;color:var(--gold);font-size:.82rem;letter-spacing:.06em;white-space:nowrap}
.notice-link:hover{color:var(--gold-lt)}

/* アクティブナビ */
.nav-active{color:var(--gold) !important}
.nav-active::after{transform:scaleX(1) !important}

/* 概要グリッド */
.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.overview-img{position:relative}
.overview-img img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.8)}
.overview-lead{font-size:clamp(1rem,2vw,1.2rem);font-weight:600;line-height:1.8;margin-bottom:1rem}
.overview-text p{font-size:.92rem;color:var(--paper-2);margin-bottom:1rem;line-height:1.9}
.overview-points{display:flex;flex-direction:column;gap:.85rem;margin:1.5rem 0 2rem}
.overview-points li{display:flex;align-items:flex-start;gap:.75rem}
.pt-mark{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;margin-top:.1rem}
.pt-mark.circle{border:1px solid rgba(255,255,255,.3);color:var(--paper-2)}
.pt-mark.check{border:1px solid var(--gold);color:var(--gold)}
.pt-mark.yen{border:1px solid rgba(184,148,42,.5);color:var(--gold)}
.overview-points strong{display:block;font-size:.9rem;margin-bottom:.15rem}
.overview-points p{font-size:.82rem;color:var(--paper-2);opacity:.7;margin:0}

/* メリット */
.merits-section{background:linear-gradient(to bottom,var(--ink-soft),var(--ink))}
.merits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.merit-card{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:transform var(--tr),box-shadow var(--tr)}
.merit-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.merit-img{overflow:hidden;aspect-ratio:4/3}
.merit-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.7) brightness(.8);transition:transform var(--tr),filter var(--tr)}
.merit-card:hover .merit-img img{transform:scale(1.04);filter:saturate(.9) brightness(.9)}
.merit-body{padding:1.4rem}
.merit-num-ja{display:inline-block;font-size:.85rem;font-weight:700;color:var(--gold);border:1px solid rgba(184,148,42,.35);padding:.15rem .5rem;margin-bottom:.6rem}
.merit-body h3{font-size:1rem;font-weight:700;margin-bottom:.6rem}
.merit-body p{font-size:.85rem;color:var(--paper-2);opacity:.8;line-height:1.8}

/* 価格テーブル */
.price-section{background:var(--ink-soft)}
.price-table-wrap{overflow-x:auto;margin-bottom:1rem}
.price-table{width:100%;min-width:480px;border-collapse:collapse}
.price-table thead tr{background:rgba(184,148,42,.1);border-bottom:1px solid var(--gold)}
.price-table th{padding:.9rem 1rem;text-align:left;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.price-table tbody tr{border-bottom:1px solid rgba(255,255,255,.06);transition:background var(--tr)}
.price-table tbody tr:hover{background:rgba(255,255,255,.03)}
.price-table td{padding:1rem;font-size:.88rem;color:var(--paper-2);vertical-align:middle}
.price-table td strong{color:var(--paper);font-size:.95rem}
.row-popular{background:rgba(184,148,42,.05) !important}
.ptag{display:inline-block;font-size:.65rem;letter-spacing:.08em;padding:.12rem .5rem;margin-bottom:.3rem;font-weight:600}
.ptag.basic{border:1px solid rgba(255,255,255,.2);color:var(--paper-2)}
.ptag.popular{background:rgba(184,148,42,.2);border:1px solid rgba(184,148,42,.5);color:var(--gold-lt)}
.ptag.premium{background:rgba(167,140,92,.15);border:1px solid rgba(167,140,92,.4);color:#c4a876}
.ptag.takeout{border:1px solid rgba(255,255,255,.15);color:var(--paper-2);opacity:.7}
.price-cell{color:var(--gold-lt) !important;font-weight:700 !important;white-space:nowrap}
.table-note{font-size:.8rem;color:var(--paper-2);opacity:.55}

/* 予約フロー */
.booking-flow-section{background:var(--ink)}
.booking-steps{display:flex;align-items:flex-start;flex-wrap:wrap;gap:.5rem;max-width:900px;margin:0 auto}
.booking-step{flex:1;min-width:140px;background:rgba(255,255,255,.03);border:1px solid var(--border);padding:1.4rem 1.2rem}
.bstep-num{display:block;font-family:var(--font-en);font-size:2rem;font-style:italic;color:var(--gold);line-height:1;margin-bottom:.5rem}
.booking-step h3{font-size:.88rem;font-weight:700;margin-bottom:.5rem}
.booking-step p{font-size:.8rem;color:var(--paper-2);opacity:.7;line-height:1.7}
.bstep-arrow{font-size:1.4rem;color:var(--gold);opacity:.35;padding-top:1.5rem;flex-shrink:0}

/* 当日の流れ（詳細ページ） */
.ontheday-section{background:var(--ink-soft)}
.ontheday-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.otd-item{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05);overflow:hidden}
.otd-img{aspect-ratio:4/3;overflow:hidden}
.otd-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.65) brightness(.75);transition:filter var(--tr),transform var(--tr)}
.otd-item:hover .otd-img img{filter:saturate(.9) brightness(.9);transform:scale(1.04)}
.otd-body{padding:.85rem}
.otd-num{display:inline-block;font-size:.7rem;font-weight:700;color:var(--gold);letter-spacing:.1em;border:1px solid rgba(184,148,42,.3);padding:.1rem .35rem;margin-bottom:.4rem}
.otd-body h3{font-size:.88rem;font-weight:700;margin-bottom:.3rem}
.otd-body p{font-size:.78rem;color:var(--paper-2);opacity:.7;line-height:1.7}

/* チェックリスト */
.checklist-section{background:var(--ink)}
.checklist-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:840px;margin:0 auto}
.cl-heading{font-size:.9rem;font-weight:700;letter-spacing:.06em;margin-bottom:1.2rem;padding-bottom:.6rem;border-bottom:1px solid var(--border)}
.cl-heading span{display:block;font-family:var(--font-en);font-size:.65rem;letter-spacing:.2em;margin-bottom:.2rem;opacity:.6}
.guest-heading{color:var(--paper-2)}
.fujiya-heading{color:var(--gold)}
.cl-sub{font-size:.75rem;letter-spacing:.1em;color:var(--gold);opacity:.7;margin-bottom:.6rem;text-transform:uppercase}
.cl-list{display:flex;flex-direction:column;gap:.6rem}
.cl-list li{display:flex;align-items:center;gap:.6rem;font-size:.88rem;color:var(--paper-2)}
.cl-icon{flex-shrink:0;width:1.6rem;height:1.6rem;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;color:var(--paper-2)}
.cl-icon.check{border-color:var(--gold);color:var(--gold)}

/* CTA BOX */
.page-cta-section{background:var(--ink-soft)}
.page-cta-box{max-width:600px;margin:0 auto;text-align:center;padding:3rem;border:1px solid var(--border);background:rgba(255,255,255,.025)}
.page-cta-lead{font-size:clamp(.9rem,1.8vw,1.05rem);color:var(--paper-2);margin-bottom:2rem;line-height:2}

/* 店舗 */
.store-section{background:var(--ink)}
.store-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.store-img{position:relative}
.store-img img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.8)}
.store-text p{font-size:.92rem;color:var(--paper-2);margin-bottom:1rem;line-height:1.9}

/* 予約方法カード */
.contact-methods-section{background:var(--ink-soft)}
.contact-methods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.contact-method-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;transition:transform var(--tr),border-color var(--tr)}
.contact-method-card:hover{transform:translateY(-4px);border-color:var(--border)}
.line-card{border-color:rgba(6,199,85,.2)}
.line-card:hover{border-color:rgba(6,199,85,.4)}
.cm-icon{font-size:2.2rem;color:var(--gold);display:flex;align-items:center}
.tel-icon,.mail-icon{color:var(--paper-2)}
.contact-method-card h3{font-size:1.05rem;font-weight:700}
.cm-tag{font-size:.72rem;color:var(--gold);letter-spacing:.08em;border:1px solid rgba(184,148,42,.3);padding:.15rem .6rem}
.contact-method-card p{font-size:.85rem;color:var(--paper-2);opacity:.75;line-height:1.8;flex:1}
.btn-tel{display:inline-block;padding:.75rem 1.5rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.2);color:var(--paper);font-size:1rem;font-weight:700;letter-spacing:.05em;transition:var(--tr)}
.btn-tel:hover{background:rgba(255,255,255,.1)}

/* メールガイド */
.mail-guide-section{background:var(--ink)}
.mail-guide-list{max-width:640px;margin:0 auto;display:flex;flex-direction:column}
.mail-guide-list li{display:flex;align-items:flex-start;gap:1.2rem;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.mg-num{flex-shrink:0;font-family:var(--font-en);font-size:1.5rem;font-style:italic;color:var(--gold);line-height:1;min-width:2rem}
.mail-guide-list strong{display:block;font-size:.9rem;margin-bottom:.15rem}
.mail-guide-list p{font-size:.8rem;color:var(--paper-2);opacity:.65;margin:0}

/* 注意事項 */
.rule-section{background:var(--ink)}
.rule-section.alt-bg{background:var(--ink-soft)}
.rule-toc{background:rgba(255,255,255,.03);border-bottom:1px solid var(--border);padding:.85rem 0;position:sticky;top:64px;z-index:50;backdrop-filter:blur(8px)}
.toc-list{max-width:var(--max);margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem);display:flex;gap:1.5rem;overflow-x:auto;scrollbar-width:none}
.toc-list::-webkit-scrollbar{display:none}
.toc-list a{font-size:.78rem;color:var(--paper-2);opacity:.6;white-space:nowrap;letter-spacing:.06em;transition:opacity var(--tr),color var(--tr)}
.toc-list a:hover{opacity:1;color:var(--gold)}
.rule-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.rule-card{background:rgba(255,255,255,.03);border:1px solid var(--border);padding:1.5rem}
.rule-diamond{display:block;color:var(--gold);font-size:.9rem;margin-bottom:.6rem}
.rule-card h3{font-size:.95rem;font-weight:700;margin-bottom:.6rem}
.rule-card p{font-size:.88rem;color:var(--paper-2);line-height:1.8}
.rule-card strong{color:var(--gold-lt)}
.capacity-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.cap-item{background:rgba(255,255,255,.03);border:1px solid var(--border);padding:2rem;text-align:center}
.cap-label{display:block;font-family:var(--font-en);font-size:.7rem;letter-spacing:.3em;color:var(--gold);opacity:.7;margin-bottom:.5rem}
.cap-num{font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;margin-bottom:.75rem}
.cap-desc{font-size:.85rem;color:var(--paper-2);opacity:.7;line-height:1.8}
.notes-list{display:flex;flex-direction:column;gap:.85rem}
.notes-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.88rem;color:var(--paper-2);line-height:1.8;padding:.75rem 1rem;background:rgba(255,255,255,.025);border-left:2px solid rgba(184,148,42,.25)}
.notes-list li strong{color:var(--paper)}
.note-mark{color:var(--gold);flex-shrink:0;font-weight:700}
.payment-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.card-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}
.card-badge{font-size:.68rem;font-weight:700;letter-spacing:.06em;border:1px solid rgba(255,255,255,.2);padding:.2rem .55rem;color:var(--paper-2);opacity:.7}
.cancel-section{background:linear-gradient(135deg,var(--ink) 0%,rgba(155,35,53,.08) 100%)}
.cancel-warning{display:flex;align-items:flex-start;gap:.75rem;background:rgba(155,35,53,.15);border:1px solid rgba(155,35,53,.4);padding:1.2rem 1.5rem;margin-bottom:2rem;max-width:760px}
.warn-icon{font-size:1.1rem;color:#e07080;flex-shrink:0;margin-top:.1rem}
.cancel-warning p{font-size:.88rem;color:var(--paper-2);line-height:1.8}
.cancel-warning strong{color:var(--paper)}
.cancel-table-wrap{overflow-x:auto;max-width:560px;margin-bottom:1.5rem}
.cancel-table{width:100%;min-width:380px;border-collapse:collapse}
.cancel-table thead tr{background:rgba(184,148,42,.1);border-bottom:1px solid var(--gold)}
.cancel-table th{padding:.85rem 1.2rem;text-align:left;font-size:.78rem;letter-spacing:.1em;color:var(--gold)}
.cancel-table td{padding:.9rem 1.2rem;font-size:.9rem;color:var(--paper-2);border-bottom:1px solid rgba(255,255,255,.06)}
.cancel-table td strong{color:var(--paper)}
.cancel-free{background:rgba(100,200,100,.04)}
.cancel-full{background:rgba(155,35,53,.07)}
.cancel-rate{font-size:1.1rem;font-weight:700;color:var(--paper)}
.free-rate{color:#6cc97e}
.mid-rate{color:var(--gold-lt)}
.full-rate{color:#e07080}
.cancel-notes{display:flex;flex-direction:column;gap:.6rem;max-width:700px}
.cancel-notes li{display:flex;gap:.6rem;font-size:.85rem;color:var(--paper-2);line-height:1.8}
.cancel-notes strong{color:var(--paper)}

/* 実績ページ */
.track-records-section{background:var(--ink)}
.track-article{padding:3rem 0}
.track-divider{height:1px;background:linear-gradient(to right,var(--gold),transparent);opacity:.2}
.track-header{display:flex;align-items:flex-start;gap:1.2rem;margin-bottom:1.2rem}
.track-num-ja{flex-shrink:0;width:3.5rem;height:3.5rem;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:var(--gold);background:rgba(184,148,42,.05)}
.track-header h3{font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;margin-bottom:.25rem}
.track-tag{font-size:.78rem;color:var(--gold);letter-spacing:.1em;opacity:.75}
.track-desc{font-size:.92rem;color:var(--paper-2);line-height:1.9;margin-bottom:1.5rem;max-width:720px}
.track-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.track-gallery.two-col{grid-template-columns:repeat(2,1fr);max-width:580px}
.track-gallery.one-col{grid-template-columns:1fr;max-width:420px}
.track-gallery.three-col{grid-template-columns:repeat(3,1fr)}
.track-gallery figure{overflow:hidden}
.track-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.7) brightness(.8);transition:filter var(--tr),transform var(--tr)}
.track-gallery figure:hover img{filter:saturate(.9) brightness(.95);transform:scale(1.04)}

/* おすすめシチュエーション */
.situations-section{background:var(--ink-soft)}
.situations-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}
.sit-item{position:relative;overflow:hidden}
.sit-item img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.65) brightness(.7);transition:filter var(--tr),transform var(--tr)}
.sit-item:hover img{filter:saturate(.9) brightness(.9);transform:scale(1.05)}
.sit-item figcaption{position:absolute;bottom:0;left:0;right:0;padding:.5rem .7rem;background:linear-gradient(to top,rgba(0,0,0,.75),transparent);font-size:.78rem;letter-spacing:.06em;color:var(--paper);font-weight:500}

/* FAQ ページ */
.faq-page-section{background:var(--ink)}
.faq-category{margin-bottom:3rem}
.faq-cat-title{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:700;letter-spacing:.05em;color:var(--gold);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(184,148,42,.2)}
.faq-cat-icon{font-size:.8rem;opacity:.7}
.faq-link{color:var(--gold);border-bottom:1px solid rgba(184,148,42,.4)}
.faq-cancel-list{display:flex;flex-direction:column;gap:.4rem;margin:.75rem 0}
.faq-cancel-list li{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--paper-2)}
.cancel-rate-tag{display:inline-block;font-size:.72rem;font-weight:700;padding:.1rem .4rem;min-width:3rem;text-align:center}
.cancel-rate-tag.full{background:rgba(155,35,53,.3);color:#e07080;border:1px solid rgba(155,35,53,.5)}
.cancel-rate-tag.mid{background:rgba(184,148,42,.2);color:var(--gold-lt);border:1px solid rgba(184,148,42,.4)}
.cancel-rate-tag.free{background:rgba(100,200,100,.15);color:#6cc97e;border:1px solid rgba(100,200,100,.3)}
.faq-more{text-align:center;padding:3rem;background:rgba(255,255,255,.025);border:1px solid var(--border);max-width:560px;margin:2rem auto 0}
.faq-more h3{font-size:1.1rem;font-weight:700;margin-bottom:.75rem;color:var(--gold)}
.faq-more p{font-size:.9rem;color:var(--paper-2);opacity:.75;margin-bottom:1.5rem;line-height:1.8}

/* 統計（placeページ用） */
.stats-section{background:var(--ink-soft);padding:3rem 0}

/* レスポンシブ */
@media(max-width:900px){
  .overview-grid,.store-grid,.merits-grid,.contact-methods-grid,.checklist-grid,.rule-cards,.capacity-grid,.payment-grid{grid-template-columns:1fr}
  .ontheday-grid{grid-template-columns:repeat(2,1fr)}
  .booking-steps{flex-direction:column;align-items:stretch}
  .bstep-arrow{transform:rotate(90deg);text-align:center;padding:0}
  .track-gallery{grid-template-columns:repeat(2,1fr)}
  .situations-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:540px){
  .ontheday-grid{grid-template-columns:1fr}
  .situations-grid{grid-template-columns:1fr}
  .track-gallery{grid-template-columns:1fr}
}
