/* =========================================================
   PETAR WONG HAIR 採用LP スタイルシート
   トーン：クリーン・可読性重視（オフホワイト/クリーム地＋チャコール文字）
   モバイル最優先のレスポンシブ設計
   ========================================================= */

/* ---------- デザイントークン（CSS変数） ---------- */
:root{
  /* 地・面 */
  --bg:#ffffff;          /* ベース白 */
  --cream:#f7f5f0;       /* クリーム地 */
  --surf:#f1eee7;        /* サーフェス（薄ベージュ） */
  /* 罫線 */
  --bd:rgba(40,38,34,.12);
  --bd2:rgba(40,38,34,.24);
  /* 文字 */
  --t1:#2b2b29;          /* メインテキスト（チャコール） */
  --t2:#6f6b63;          /* サブテキスト */
  --t3:#a29d92;          /* 補助テキスト（装飾・非本文用） */
  --t-muted:#6b6760;     /* 補助テキスト（白背景でAAコントラスト確保用） */
  /* インク（CTAダーク） */
  --ink:#2b2b29;
  --ink-h:#454440;       /* ホバー時 */
  /* LINEグリーン */
  --line:#06c755;
  --line-h:#05b14c;
  /* バッジ用アクセント */
  --info-bg:#e9f1fb; --info-tx:#1c5a9c;   /* ブルー系 */
  --succ-bg:#eaf3de; --succ-tx:#3b6d11;   /* グリーン系 */
  --accent:#9a6a4f;      /* コッパー系アクセント */
  /* レイアウト */
  --maxw:880px;          /* 本文最大幅 */
  --radius:12px;
  --radius-sm:8px;
  /* フォント */
  --font-jp:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",sans-serif;
  --font-en:"Outfit",var(--font-jp);
  /* ヘッダー高さ */
  --header-h:56px;
}

/* ---------- リセット ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--cream);
  color:var(--t1);
  font-family:var(--font-jp);
  font-weight:400;
  line-height:1.8;
  -webkit-text-size-adjust:100%;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;}
ul{list-style:none;margin:0;padding:0;}
button{font-family:inherit;cursor:pointer;}

/* アイコン共通（currentColorで描画） */
.ic{
  width:1em;height:1em;flex:none;
  fill:none;stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
  vertical-align:-.15em;
}

/* スキップ：本文最大幅のセンタリング枠（フレーム） */
main{
  max-width:var(--maxw);
  margin:0 auto;
  background:var(--bg);
}

/* ---------- アクセシビリティ：フォーカスリング ---------- */
:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:3px;
}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:.5px solid var(--bd);
}
.header-inner{
  max-width:var(--maxw);
  margin:0 auto;
  height:var(--header-h);
  display:flex;align-items:center;gap:16px;
  padding:0 18px;
}
.brand{
  font-family:var(--font-en);
  font-weight:600;
  font-size:15px;
  letter-spacing:.04em;
  text-decoration:none;
  color:var(--t1);
}
.header-nav{
  display:none;
  margin-left:auto;
  gap:20px;
}
.header-nav a{
  font-size:13px;color:var(--t2);text-decoration:none;
  transition:color .2s;
}
.header-nav a:hover{color:var(--t1);}
.header-cta{
  display:none;
  font-size:13px;
  padding:7px 16px;border-radius:999px;
  background:var(--ink);color:#fff;text-decoration:none;
  transition:background .2s;
}
.header-cta:hover{background:var(--ink-h);}

/* ハンバーガー */
.menu-toggle{
  margin-left:auto;
  width:40px;height:40px;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  background:none;border:none;padding:0;
}
.menu-toggle span{
  display:block;width:20px;height:2px;background:var(--t1);border-radius:2px;
  transition:transform .3s,opacity .3s;
}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ---------- モバイルメニュー ---------- */
.nav-overlay{
  position:fixed;inset:0;z-index:60;
  background:rgba(20,18,16,.45);
  opacity:0;transition:opacity .3s;
}
.nav-overlay.is-open{opacity:1;}
.mobile-nav{
  position:fixed;top:0;right:0;z-index:70;
  width:72%;max-width:320px;height:100%;
  background:var(--bg);
  box-shadow:-10px 0 40px rgba(0,0,0,.12);
  padding:72px 26px 26px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.22,.61,.36,1);
}
.mobile-nav.is-open{transform:translateX(0);}
.mobile-nav a{
  font-size:15px;color:var(--t1);text-decoration:none;
  padding:12px 4px;border-bottom:.5px solid var(--bd);
}
.mobile-nav-cta{
  margin-top:16px;
  text-align:center;
  background:var(--ink);color:#fff !important;
  border-radius:var(--radius-sm);border-bottom:none !important;
  font-weight:500;
}

/* ---------- セクション共通 ---------- */
.sec{
  padding:44px 18px;
  border-bottom:.5px solid var(--bd);
}
.sec-cream{background:var(--cream);}
.sec-eyebrow{
  font-family:var(--font-en);
  font-size:12px;font-weight:600;letter-spacing:.18em;
  color:var(--accent);
  margin:0 0 4px;
}
.sec-title{
  font-size:22px;font-weight:700;
  margin:0 0 18px;
  letter-spacing:.01em;
}
.sec-lead{
  font-size:14px;color:var(--t2);line-height:1.9;margin:0;
}

/* ---------- ヒーロー ---------- */
.hero{border-bottom:.5px solid var(--bd);}
.hero-media{
  /* 画像未配置でも崩れないプレースホルダ背景 */
  background:linear-gradient(135deg,var(--surf),var(--cream));
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
}
.hero-img{
  width:100%;height:100%;object-fit:cover;
  /* 画像未配置/失敗時：grad背景で覆い、broken-image・altテキストの露出を防ぐ */
  background:linear-gradient(135deg,var(--surf),var(--cream));
  color:transparent;font-size:0;text-indent:-9999px;overflow:hidden;
}
/* 画像読込前/失敗時のプレースホルダ表記 */
.hero-media::after{
  content:"PETAR WONG HAIR";
  position:absolute;inset:0;z-index:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-size:18px;letter-spacing:.1em;
  color:var(--t3);
}
.hero-img{position:relative;z-index:1;}
.hero-body{padding:24px 18px 36px;}
.badge-list{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 14px;}
.badge{
  font-size:11.5px;padding:4px 12px;border-radius:999px;font-weight:500;
}
.badge-blue{background:var(--info-bg);color:var(--info-tx);}
.badge-green{background:var(--succ-bg);color:var(--succ-tx);}
.badge-neutral{background:var(--surf);color:var(--t2);}
.hero-title{
  font-size:27px;font-weight:700;line-height:1.5;
  margin:0 0 10px;letter-spacing:.01em;
}
.hero-sub{
  font-size:13px;color:var(--t2);margin:0 0 22px;
}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 22px;border-radius:var(--radius-sm);
  font-size:15px;font-weight:500;text-decoration:none;
  border:none;
  transition:background .2s,transform .12s,box-shadow .2s,color .2s;
}
.btn:active{transform:translateY(1px);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:var(--ink-h);}
.btn-line{background:var(--line);color:#fff;}
.btn-line:hover{background:var(--line-h);}
.btn-outline{
  background:transparent;color:var(--t1);
  border:1px solid var(--bd2);
}
.btn-outline:hover{background:var(--surf);}
.btn-block{width:100%;}
.cta-group{display:flex;flex-direction:column;gap:10px;}
.cta-group-center{margin-top:22px;}
@media(min-width:480px){
  .cta-group{flex-direction:row;}
  .cta-group .btn{flex:1;}
}

/* ---------- サロンの魅力：統計 ---------- */
.stat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  margin:0 0 18px;
}
.stat{
  background:var(--cream);border-radius:var(--radius-sm);
  padding:16px 6px;text-align:center;
  display:flex;flex-direction:column;gap:4px;
}
.sec-cream .stat{background:var(--bg);}
.stat-num{font-family:var(--font-en);font-size:22px;font-weight:600;line-height:1;}
.stat-num-sm{font-size:16px;font-weight:700;font-family:var(--font-jp);}
.stat-label{font-size:11px;color:var(--t2);}

/* ---------- 募集にあたって（メッセージ） ---------- */
.message-body{font-size:14.5px;line-height:2;color:var(--t1);}
.message-body p{margin:0 0 14px;}
.ic-quote{font-size:26px;color:var(--accent);}
.message-em{font-weight:700;}
.message-accent{color:var(--accent);font-weight:700;margin-bottom:0 !important;}

/* ---------- 募集要項 ---------- */
.group-head{
  font-size:14px;font-weight:700;
  margin:8px 0 12px;padding-bottom:7px;
  border-bottom:2px solid var(--accent);
  display:inline-block;
}
.job-grid{
  display:grid;grid-template-columns:1fr;gap:12px;
  margin-bottom:26px;
}
@media(min-width:600px){
  .job-grid{grid-template-columns:1fr 1fr;}
}
.card{
  background:var(--bg);border:1px solid var(--bd);
  border-radius:var(--radius);
  padding:16px 18px;
}
.sec-cream .card{background:var(--bg);}
.card-head{
  display:flex;align-items:center;gap:7px;
  font-weight:700;font-size:15px;
  margin-bottom:6px;
}
.card-head .ic{font-size:18px;color:var(--accent);}

/* スペック定義リスト */
.spec{margin:0;}
.spec-row{
  display:flex;justify-content:space-between;gap:12px;
  font-size:13px;
  padding:8px 0;border-top:.5px solid var(--bd);
}
.spec-row dt{color:var(--t2);white-space:nowrap;margin:0;font-weight:400;}
.spec-row dd{margin:0;text-align:right;}
.job-note{
  /* 白背景での補助テキスト：AAコントラスト確保のため濃いトーンを使用 */
  font-size:12px;color:var(--t-muted);line-height:1.7;
  margin:6px 0 0;
}

/* 事業所情報のスペックは縦並びで読みやすく */
.spec-access .spec-row{font-size:13.5px;}
.spec-access .spec-row dd{text-align:right;}
.spec-access a{color:var(--info-tx);text-decoration:none;}
.spec-access a:hover{text-decoration:underline;}
@media(max-width:420px){
  .spec-access .spec-row{flex-direction:column;gap:2px;}
  .spec-access .spec-row dd{text-align:left;}
}

/* ---------- 写真ギャラリー ---------- */
.gallery-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.gallery-item{
  position:relative;
  border-radius:var(--radius-sm);overflow:hidden;
  background:linear-gradient(135deg,var(--surf),#fff);
  aspect-ratio:1/1;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  /* 画像未配置/失敗時：grad背景で覆い、broken-image・altテキストの露出を防ぐ */
  background:linear-gradient(135deg,var(--surf),#fff);
  color:transparent;font-size:0;text-indent:-9999px;overflow:hidden;
  position:relative;z-index:1;
}
.gallery-cap{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(transparent,rgba(0,0,0,.55));
  color:#fff;font-size:11px;
  padding:14px 10px 8px;
}
/* 画像未配置時のプレースホルダ表記（imgの下に敷く） */
.gallery-item::before{
  content:attr(data-ph);
  position:absolute;inset:0;z-index:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--t3);font-size:11px;text-align:center;padding:0 8px;
}

/* ---------- Googleマップ ---------- */
.map-wrap{
  margin-top:18px;
  border-radius:var(--radius);overflow:hidden;
  border:.5px solid var(--bd);
  background:var(--surf);
  aspect-ratio:16/10;
}
.map-wrap iframe{
  width:100%;height:100%;border:0;display:block;
}

/* ---------- FAQ ---------- */
.faq-list{border-top:.5px solid var(--bd);}
.faq-item{border-bottom:.5px solid var(--bd);}
.faq-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:none;border:none;
  text-align:left;
  font-size:14px;font-weight:500;color:var(--t1);
  padding:16px 2px;
}
.faq-chev{
  font-size:18px;color:var(--t3);flex:none;
  transition:transform .3s;
}
.faq-q[aria-expanded="true"] .faq-chev{transform:rotate(180deg);}
.faq-a{
  overflow:hidden;
  max-height:0;
  transition:max-height .3s ease,padding .3s ease;
}
.faq-a p{
  margin:0;
  font-size:13.5px;color:var(--t2);line-height:1.9;
  padding:0 2px 16px;
}
/* 将来の長文回答で見切れ防止のため上限を引き上げ */
.faq-item.is-open .faq-a{max-height:600px;}

/* ---------- お問い合わせフォーム ---------- */
.form{margin:22px 0 18px;}
.field{margin-bottom:16px;}
.field-row{display:flex;gap:12px;}
.field-row .field{flex:1;}
.field label{
  display:block;
  font-size:12.5px;color:var(--t2);font-weight:500;
  margin-bottom:6px;
}
.req{
  display:inline-block;
  font-size:10px;font-weight:500;
  color:#fff;background:var(--accent);
  padding:1px 7px;border-radius:999px;
  margin-left:4px;vertical-align:1px;
}
.field input,
.field select,
.field textarea{
  width:100%;
  font-family:inherit;font-size:15px;color:var(--t1);
  background:var(--bg);
  border:1px solid var(--bd2);border-radius:var(--radius-sm);
  padding:11px 13px;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(154,106,79,.14);
}
.field textarea{resize:vertical;min-height:110px;}
/* バリデーションエラー表示 */
.field.has-error input,
.field.has-error select,
.field.has-error textarea,
.field.has-error .seg{
  border-color:#d4503b;
  box-shadow:0 0 0 3px rgba(212,80,59,.12);
}
.field-error{
  display:block;
  font-size:11.5px;color:#d4503b;margin-top:5px;
}

/* セグメント（ラジオ）UI */
.seg{display:flex;gap:9px;}
.seg-opt{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;
  padding:10px 8px;
  border:1px solid var(--bd2);border-radius:var(--radius-sm);
  background:var(--bg);
  cursor:pointer;
  transition:background .2s,border-color .2s,color .2s;
}
.seg-opt input{position:absolute;opacity:0;width:0;height:0;}
.seg-opt:has(input:checked){
  background:var(--ink);color:#fff;border-color:var(--ink);
}
.seg-opt:has(input:focus-visible){
  outline:2px solid var(--accent);outline-offset:2px;
}

/* ハニーポット（視覚的に隠す。display:noneは一部ボットに見抜かれるため位置で隠す） */
.hp-field{
  position:absolute !important;
  left:-9999px;width:1px;height:1px;overflow:hidden;
}

.form-privacy{
  /* 白背景での補助テキスト：AAコントラスト確保のため濃いトーンを使用 */
  font-size:11.5px;color:var(--t-muted);margin:0 0 14px;
}
.form-privacy a{color:var(--info-tx);}
.form-status{
  margin:14px 0 0;font-size:13px;
  padding:12px 14px;border-radius:var(--radius-sm);
  line-height:1.7;
}
.form-status.is-success{background:var(--succ-bg);color:var(--succ-tx);}
.form-status.is-error{background:#fbe9e7;color:#c0392b;}

/* 代替CTA（LINE / Instagram） */
.alt-cta{
  display:flex;gap:10px;margin-top:20px;
}
.alt-cta .btn{flex:1;}

/* ---------- フッター ---------- */
.site-footer{
  background:var(--cream);
  text-align:center;
  padding:36px 18px 40px;
}
.footer-name{font-size:14px;font-weight:700;margin:0 0 6px;}
.footer-addr{font-size:12px;color:var(--t2);margin:0 0 4px;}
.footer-tel{font-size:12px;margin:0 0 16px;}
.footer-tel a{color:var(--t2);text-decoration:none;}
.footer-nav{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;
  margin-bottom:16px;
}
.footer-nav a{
  font-size:12px;color:var(--info-tx);text-decoration:none;
}
.footer-nav a:hover{text-decoration:underline;}
.footer-copy{
  font-size:11px;color:var(--t3);margin:0;
  font-family:var(--font-en);letter-spacing:.04em;
}

/* ---------- スクロール出現アニメーション ---------- */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease,transform .6s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:none;
}

/* ---------- スマホ専用改行（base=スマホで改行、PC=760px以上で無効化） ---------- */
.br-sp{display:inline;}
.sep-pc{display:none;}

/* ---------- デスクトップ拡張 ---------- */
@media(min-width:760px){
  .menu-toggle{display:none;}
  .header-nav{display:flex;}
  .header-cta{display:inline-block;}
  .sec{padding:64px 40px;}
  .hero-body{padding:36px 40px 56px;}
  .hero-media{aspect-ratio:21/9;}
  .hero-title{font-size:34px;}
  .sec-title{font-size:26px;}
  /* PCでは改行を無効化し、ヒーローの区切り「／」を表示 */
  .br-sp{display:none;}
  .sep-pc{display:inline;}
}

/* ---------- prefers-reduced-motion 尊重 ---------- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation-duration:.001ms !important;
    transition-duration:.001ms !important;
  }
  .reveal{opacity:1;transform:none;}
}
