/*
Theme Name: Salon Reserve Template
Theme URI: https://example.com/
Author: OpenAI
Author URI: https://openai.com/
Description: 美容室・サロン向け予約テンプレート。メニュー、スタッフ、FAQ、お知らせ、予約受付管理を備えたクラシックテーマです。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: salon-reserve
*/

:root{
  --sr-bg:#f8f5f1;
  --sr-base:#ffffff;
  --sr-text:#2f2a26;
  --sr-sub:#786b61;
  --sr-accent:#b88a6a;
  --sr-accent-dark:#8f6649;
  --sr-border:#e9dfd6;
  --sr-max:1180px;
  --sr-radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","Yu Gothic","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;background:var(--sr-bg);color:var(--sr-text);line-height:1.8}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(calc(100% - 32px),var(--sr-max));margin-inline:auto}
.section{padding:72px 0}
.section--alt{background:#fcfaf8}
.hero__mini{display:flex;gap:16px;flex-wrap:wrap;margin-top:18px;color:var(--sr-sub);font-size:13px}
.hero__mini span{padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.65);border:1px solid var(--sr-border)}
.section__head{margin-bottom:28px}
.section__eyebrow{display:block;font-size:12px;letter-spacing:.18em;color:var(--sr-accent);text-transform:uppercase}
.section__title{margin:8px 0 0;font-size:clamp(26px,4vw,40px);line-height:1.3}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;background:var(--sr-accent);color:#fff;font-weight:700;transition:.25s}
.btn:hover{background:var(--sr-accent-dark)}
.btn--ghost{background:transparent;border:1px solid var(--sr-accent);color:var(--sr-accent)}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.5) blur(10px);border-bottom:1px solid var(--sr-border)}
.site-header__row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0}
.site-logo{font-weight:800;font-size:20px;letter-spacing:.08em}
.gnav ul{display:flex;gap:18px;list-style:none;margin:0;padding:0;font-size:14px}
.hero{position:relative;padding:88px 0;background:linear-gradient(135deg,#f8f5f1 0%,#f2ebe3 100%)}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero__lead{font-size:14px;color:var(--sr-accent);letter-spacing:.12em}
.hero__title{font-size:clamp(34px,5vw,60px);line-height:1.2;margin:10px 0 16px}
.hero__text{color:var(--sr-sub)}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.hero__card{background:#fff;border-radius:24px;padding:18px;border:1px solid var(--sr-border);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--sr-base);border:1px solid var(--sr-border);border-radius:var(--sr-radius);overflow:hidden;box-shadow:0 8px 28px rgba(0,0,0,.04)}
.card__body{padding:20px}
.card__title{margin:0 0 8px;font-size:20px;line-height:1.4}
.card__meta{font-size:13px;color:var(--sr-sub);display:flex;gap:12px;flex-wrap:wrap}
.card__text{font-size:14px;color:var(--sr-sub)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.list-clean{list-style:none;margin:0;padding:0}
.faq-item{background:#fff;border:1px solid var(--sr-border);border-radius:16px;padding:18px 20px}
.faq-item + .faq-item{margin-top:14px}
.faq-item summary{cursor:pointer;font-weight:700}
.faq-item__a{margin-top:12px;color:var(--sr-sub)}
.info-box{background:#fff;padding:24px;border-radius:var(--sr-radius);border:1px solid var(--sr-border)}
.site-footer{padding:52px 0 110px;background:#fff;border-top:1px solid var(--sr-border);margin-top:60px}
.site-footer__grid{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:end}
.archive-head{padding:56px 0 28px}
.page-title{font-size:clamp(30px,4vw,44px);margin:0}
.page-lead{color:var(--sr-sub)}
.single-wrap{padding:52px 0}
.entry-content,.editor-content{font-size:16px}
.entry-content h2,.editor-content h2{font-size:28px;margin-top:2em}
.entry-content h3,.editor-content h3{font-size:22px;margin-top:1.6em}
.entry-content p,.editor-content p{margin:0 0 1.2em}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#f1e3d9;color:var(--sr-accent-dark);font-size:12px;font-weight:700}
.reserve-form{background:#fff;border:1px solid var(--sr-border);border-radius:24px;padding:24px;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.reserve-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.reserve-field{display:flex;flex-direction:column;gap:8px}
.reserve-field--full{grid-column:1 / -1}
.reserve-field label{font-size:14px;font-weight:700}
.reserve-field input,.reserve-field select,.reserve-field textarea{width:100%;padding:13px 14px;border:1px solid var(--sr-border);border-radius:12px;font:inherit;background:#fff}
.reserve-field textarea{min-height:120px;resize:vertical}
.reserve-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:20px}
.notice{padding:14px 16px;border-radius:12px;background:#fff4ea;border:1px solid #f1d6bc;color:#8f6649;margin-bottom:20px}
.fixed-cta{position:fixed;left:0;right:0;bottom:0;z-index:110;background:rgba(255,255,255,.97);border-top:1px solid var(--sr-border);padding:10px}
.fixed-cta__inner{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:min(calc(100% - 20px),720px);margin:0 auto}
.fixed-cta__btn{display:flex;align-items:center;justify-content:center;min-height:46px;border-radius:12px;background:var(--sr-accent);color:#fff;font-size:14px;font-weight:700}
.fixed-cta__btn--light{background:#4caf50}
.fixed-cta__btn--dark{background:#333}
.table-like{width:100%;border-collapse:collapse;background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--sr-border)}
.table-like th,.table-like td{padding:14px 16px;border-bottom:1px solid var(--sr-border);text-align:left;font-size:14px}
.table-like th{width:28%;background:#fcfaf8}
@media (max-width: 900px){
  .hero__grid,.cards,.grid-2,.site-footer__grid,.reserve-form__grid{grid-template-columns:1fr}
  .gnav{display:none}
  .hero{padding:64px 0}
}


.site-header{
background:#fff;
border-bottom:1px solid #eee;
}

.header-inner{
max-width:1200px;
margin:auto;
display:flex;
align-items:center;
justify-content:space-between;
padding:20px;
}

.nav-list{
display:flex;
gap:30px;
list-style:none;
margin:0;
padding:0;
}

.nav-list a{
text-decoration:none;
color:#333;
font-weight:500;
}

.btn-reserve{
background:#c59d5f;
color:#fff;
padding:10px 18px;
border-radius:4px;
text-decoration:none;
}

.site-footer{
background:#111;
color:#fff;
padding:60px 20px;
}

.footer-nav-list{
display:flex;
gap:20px;
list-style:none;
justify-content:center;
margin-bottom:20px;
}

.footer-nav-list a{
color:#fff;
text-decoration:none;
}

/* =========================
   共通
========================= */
.page-head{
  padding: 80px 20px 40px;
  text-align: center;
}

.page-head .inner{
  max-width: 1080px;
  margin: 0 auto;
}

.page-head h1{
  margin: 0 0 12px;
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.3;
  font-weight: 700;
  color: #222;
}

.page-head p{
  margin: 0;
  font-size: 15px;
  line-height: 2;
  color: #666;
}

.menu-list-sec,
.staff-list-sec{
  padding: 0 20px 80px;
}

.menu-list-sec .inner,
.staff-list-sec .inner{
  max-width: 1080px;
  margin: 0 auto;
}

/* =========================
   MENU ARCHIVE
========================= */
.menu-list{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 40px 30px;
}

.menu-card{
  background: #fff;
}

.menu-card__link{
  display: block;
  text-decoration: none;
  color: inherit;
}

.menu-card__img{
  overflow: hidden;
  border-radius: 16px;
  aspect-ratio: 4 / 3;
  background: #f4f4f4;
  margin-bottom: 18px;
}

.menu-card__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}

.menu-card__link:hover .menu-card__img img{
  transform: scale(1.05);
}

.menu-card__body{
  padding: 0 4px;
}

.menu-card__price{
  margin: 0 0 10px;
  font-size: 24px;
  line-height: 1.2;
  font-weight: 700;
  color: #b48b57;
}

.menu-card__title{
  margin: 0 0 10px;
  font-size: 22px;
  line-height: 1.5;
  font-weight: 700;
  color: #222;
}

.menu-card__text{
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 2;
  color: #666;
}

.menu-card__time{
  margin: 0 0 12px;
  font-size: 13px;
  line-height: 1.8;
  color: #888;
}

.menu-card__more{
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: #222;
  border-bottom: 1px solid #222;
  padding-bottom: 2px;
}

/* =========================
   STAFF ARCHIVE
========================= */
.staff-list{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 40px 24px;
}

.staff-card__link{
  display: block;
  text-decoration: none;
  color: inherit;
}

.staff-card__img{
  overflow: hidden;
  border-radius: 16px;
  aspect-ratio: 3 / 4;
  background: #f4f4f4;
  margin-bottom: 16px;
}

.staff-card__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}

.staff-card__link:hover .staff-card__img img{
  transform: scale(1.05);
}

.staff-card__body{
  text-align: left;
}

.staff-card__position{
  margin: 0 0 8px;
  font-size: 12px;
  letter-spacing: .08em;
  color: #b48b57;
}

.staff-card__title{
  margin: 0 0 10px;
  font-size: 24px;
  line-height: 1.4;
  font-weight: 700;
  color: #222;
}

.staff-card__text{
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 2;
  color: #666;
}

.staff-card__more{
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: #222;
  border-bottom: 1px solid #222;
  padding-bottom: 2px;
}

/* =========================
   PAGINATION
========================= */
.navigation.pagination{
  margin-top: 50px;
  text-align: center;
}

.navigation.pagination .nav-links{
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
}

.navigation.pagination a,
.navigation.pagination span{
  min-width: 42px;
  height: 42px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #ddd;
  border-radius: 999px;
  text-decoration: none;
  color: #333;
  background: #fff;
}

.navigation.pagination .current{
  background: #222;
  color: #fff;
  border-color: #222;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1024px){
  .menu-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .staff-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px){
  .page-head{
    padding: 56px 20px 28px;
  }

  .menu-list-sec,
  .staff-list-sec{
    padding: 0 20px 56px;
  }

  .menu-list,
  .staff-list{
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .menu-card__title{
    font-size: 20px;
  }

  .staff-card__title{
    font-size: 22px;
  }
}

.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #fff;
  border-bottom: 1px solid #eee;
}

.header-inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.header-logo a{
  text-decoration: none;
  color: #222;
  font-size: 20px;
  font-weight: 700;
}

.global-nav{
  margin-left: auto;
}

.nav-list{
  display: flex;
  align-items: center;
  gap: 28px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.nav-list a{
  text-decoration: none;
  color: #222;
  font-size: 14px;
  font-weight: 500;
}

.btn-reserve,
.global-nav__reserve{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 140px;
  padding: 12px 18px;
  border-radius: 999px;
  background: #222;
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
}

.hamburger{
  display: none;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  position: relative;
  z-index: 1101;
}

.hamburger span{
  display: block;
  width: 24px;
  height: 2px;
  margin: 5px auto;
  background: #222;
  transition: transform .3s ease, opacity .3s ease;
}

.nav-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: .3s;
  z-index: 998;
}

.pc-only{
  display: block;
}

.sp-only{
  display: none;
}

@media (max-width: 767px){
  .pc-only{
    display: none;
  }

  .sp-only{
    display: block;
  }

  .hamburger{
    display: block;
  }

  .hamburger.is-active span:nth-child(1){
    transform: translateY(7px) rotate(45deg);
  }

  .hamburger.is-active span:nth-child(2){
    opacity: 0;
  }

  .hamburger.is-active span:nth-child(3){
    transform: translateY(-7px) rotate(-45deg);
  }

  .global-nav{
    position: fixed;
    top: 0;
    right: 0;
    width: min(86vw, 360px);
    height: 100dvh;
    padding: 88px 24px 32px;
    background: #fff;
    transform: translateX(100%);
    transition: transform .35s ease;
    z-index: 1100;
    overflow-y: auto;
    margin-left: 0;
  }

  .global-nav.is-open{
    transform: translateX(0);
  }

  .global-nav[aria-hidden="true"]{
    visibility: hidden;
  }

  .global-nav.is-open[aria-hidden="false"]{
    visibility: visible;
  }

  .nav-list{
    display: block;
  }

  .nav-list li + li{
    margin-top: 18px;
  }

  .nav-list a{
    display: block;
    padding: 10px 0;
    font-size: 16px;
    border-bottom: 1px solid #eee;
  }

  .global-nav__cta{
    margin-top: 24px;
  }

  .global-nav__reserve{
    width: 100%;
  }

  .nav-overlay.is-open{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}