/* ====== Base Theme ====== */
:root{
  --bg:#f9fafb; --text:#1f2937; --muted:#6b7280; --border:#e5e7eb; --surface:#fff;
  --btn-bg:#e6f1ff; --btn-bg-hover:#d7eaff; --btn-border:#b6d4fe; --btn-text:#0b2a6b;
  --shadow-sm:0 1px 2px 0 rgb(0 0 0 / .05);
  --shadow-md:0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);
  --radius:.75rem; --header-h:64px;
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,"Noto Sans JP",sans-serif;line-height:1.6}
h1,h2,h3{line-height:1.3;margin:.4rem 0 .6rem;font-weight:700}

/* ====== Header & Navigation ====== */
.site-header{position:sticky;top:0;z-index:1000;background:color-mix(in srgb, var(--surface) 90%, transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);max-width:1200px;margin:0 auto;padding:0 1rem}
.header-brand a{display:flex;align-items:center;gap:.75rem;font-weight:700;text-decoration:none;color:var(--text)}
.header-nav{display:none}
.mobile-nav-toggle{display:inline-flex;background:transparent;border:1px solid var(--border);padding:.5rem .75rem;border-radius:.5rem;color:var(--text);cursor:pointer}
.icon-close{display:none}
body.nav-open .icon-menu{display:none}
body.nav-open .icon-close{display:inline}

/* PC nav */
@media (min-width:1024px){
  .header-nav{display:flex;align-items:center;gap:.5rem}
  .mobile-nav-toggle{display:none}
}
.header-nav a,
.header-nav .button,
.header-nav .button-outline{
  display:inline-flex;align-items:center;justify-content:center;gap:.25rem;
  padding:.5rem 1rem;border-radius:.5rem;font-weight:700;text-decoration:none;
  background:var(--btn-bg); color:var(--btn-text); border:1px solid var(--btn-border);
  box-shadow:var(--shadow-sm); transition:background-color .15s,border-color .15s,transform .05s
}
.header-nav a:hover{background:var(--btn-bg-hover)}
.header-nav a.active{background:color-mix(in srgb, var(--btn-bg) 60%, #93c5fd 40%)}

/* Mobile panel */
#mobileNavPanel{position:fixed;top:var(--header-h);left:0;width:100%;background:#fff;border-bottom:1px solid var(--border);transform:translateY(-110%);transition:transform .25s ease}
body.nav-open #mobileNavPanel{transform:translateY(0)}
#mobileNavPanel nav{display:flex;flex-direction:column;gap:.5rem;padding:1rem}
#mobileNavPanel a{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1rem;border-radius:.5rem;background:var(--btn-bg);color:var(--btn-text);border:1px solid var(--btn-border)}

/* ====== Layout ====== */
.container{max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem}
.card{background:#fff;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-md)}
.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
label{font-weight:600;color:var(--muted);font-size:.9rem}
input,select,textarea{width:100%;padding:.6rem .8rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg);color:var(--text);font-size:1rem}
input:focus,select:focus,textarea:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px color-mix(in srgb, #60a5fa 25%, transparent)}

/* Buttons（塗りボタン統一） */
.button,.button-outline,a.button,a.button-outline,button.button,button.button-outline{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.6rem 1.2rem;border-radius:.5rem;text-decoration:none;cursor:pointer;
  font-weight:700;line-height:1.2;font-size:1rem;background:var(--btn-bg);color:var(--btn-text);border:1px solid var(--btn-border);box-shadow:var(--shadow-sm);
  transition:background-color .15s,border-color .15s,transform .05s
}
.button:hover,.button-outline:hover{background:var(--btn-bg-hover)}
.button.small,.button-outline.small{padding:.5rem 1rem}

/* Table */
.table-responsive{width:100%;overflow-x:auto}
.table{width:100%;border-collapse:collapse;text-align:left}
.table th{padding:1rem;font-size:.85rem;color:var(--muted)}
.table td{padding:1rem;border-top:1px solid var(--border)}

/* Alerts */
.alert{padding:.6rem .8rem;border-radius:.5rem;margin:.6rem 0}
.alert.ok{background:#eef;border:1px solid #cfe;color:#053}
.alert.err{background:#fee;border:1px solid #f99;color:#900}

/* Status Badges（薄い色） */
.badge{display:inline-block;padding:.28rem .6rem;border-radius:.5rem;font-weight:600;line-height:1;border:1px solid transparent}
.st-confirmed{background:#e8f1ff;border-color:#cfe0ff;color:#1e3a8a}  /* 薄い青 */
.st-pending  {background:#fef9c3;border-color:#fde68a;color:#92400e}  /* 薄い黄 */
.st-cancelled{background:#fde7ef;border-color:#f9c6da;color:#9d174d}  /* 薄いピンク */

/* Responsive（顧客カード等の雛形） */
.cards{display:none;gap:.75rem}
.card-item{border:1px solid var(--border);border-radius:var(--radius);padding:1rem;background:#fff;display:flex;flex-direction:column;gap:.35rem;box-shadow:var(--shadow-sm)}
.card-item .name{font-weight:700}
/* スマホでも表は表示し、横スクロール可能にする */
.table-wrap{width:100%; overflow-x:auto;}
@media (max-width:720px){
  /* .cards があるページは併用可。無くても table を隠さない */
  .cards{display:grid;grid-template-columns:1fr; gap:.75rem}
}

/* ====== Header Navigation: サイズを完全固定 ====== */
.header-nav a,
.header-nav .button,
.header-nav .button-outline{
  display:inline-flex; align-items:center; justify-content:center;
  min-height: 40px;               /* ★高さ固定 */
  padding: .5rem 1rem;            /* ★左右余白を統一 */
  border-width: 1px;              /* ★枠線幅も統一 */
  border-style: solid;
  border-color: var(--btn-border);
  border-radius: .5rem;
  font-weight: 700;
  line-height: 1;                 /* ★行高固定で文字によるズレ防止 */
  text-decoration:none;
  background: var(--btn-bg);
  color: var(--btn-text);
  box-shadow: var(--shadow-sm);
  transition: background-color .15s, border-color .15s, transform .05s;
}
.header-nav a:hover{ background: var(--btn-bg-hover); }
.header-nav a.active{
  /* アクティブ時もサイズが変わらないよう、余白・枠線は同じ */
  background: color-mix(in srgb, var(--btn-bg) 60%, #93c5fd 40%);
  border-color: var(--btn-border);
}
/* ボタン風（新規予約/ログアウト）もサイズを同じに */
.header-nav .button-outline.small{ min-height:40px; padding:.5rem 1rem; }
/* === Mobile 表示の強制表示＆横スクロール対応 === */
.table-wrap{width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch;}
.table{min-width:720px;} /* 列数が多くても横スクロールで崩れないように */

@media (max-width:720px){
  /* 以前は .table-wrap を display:none にしていた可能性 → 絶対に隠さない */
  .table-wrap{display:block;}
  /* カードUIがあるページでも、テーブルは隠さず併用OK */
  .cards{display:grid; grid-template-columns:1fr; gap:.75rem;}
}

/* === モバイルナビ（オーバーレイ）が中身を隠してしまう対策 === */
.mobile-nav-panel{
  position:fixed; top:var(--header-h,64px); left:0; right:0;
  background:#fff; border-bottom:1px solid var(--border, #e5e7eb);
  transform:translateY(-120%); transition:transform .25s ease, opacity .2s;
  opacity:0; pointer-events:none; z-index:1001;
}
body.nav-open .mobile-nav-panel{ transform:translateY(0); opacity:1; pointer-events:auto; }
