/* =========================================================
   美容室 予約管理アプリ  スタイル
   業務アプリとして落ち着いた配色・高コントラスト・大きめタップ領域
   ========================================================= */
:root{
  --bg:#f4f5f7;
  --panel:#ffffff;
  --ink:#1f2430;
  --ink-soft:#5a6172;
  --line:#d7dbe3;
  --line-strong:#b9c0cc;
  --primary:#2563a8;
  --primary-dark:#1d4f86;
  --owner:#1f6fd6;       /* オーナー: 青 */
  --owner-bg:#e3eefc;
  --staff:#d23b3b;       /* スタッフ: 赤 */
  --staff-bg:#fbe6e6;
  --success:#1f7a4d;
  --danger:#c0392b;
  --warn:#b9770e;
  --focus:#1d4f86;
  /* 時間1コマの横幅(px)。PHP側の COL_W と一致させること */
  --col-w:64px;
  --row-h:42px;
}

*{box-sizing:border-box;}
/* hidden 属性は必ず非表示にする (display:flex 等の指定に打ち消されないように) */
[hidden]{display:none !important;}
html,body{margin:0;padding:0;}
body{
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  background:var(--bg); color:var(--ink); font-size:15px; line-height:1.5;
  -webkit-text-size-adjust:100%;
}

/* ---------- アプリバー ---------- */
.appbar{background:var(--panel);border-bottom:2px solid var(--line-strong);position:sticky;top:0;z-index:50;}
.appbar-inner{display:flex;align-items:center;gap:12px;padding:8px 14px;flex-wrap:wrap;}
.brand{font-weight:700;font-size:18px;color:var(--primary-dark);text-decoration:none;}
.mainnav{display:flex;gap:4px;flex-wrap:wrap;align-items:center;}
.mainnav a{padding:8px 12px;border-radius:8px;text-decoration:none;color:var(--ink);font-weight:600;}
.mainnav a:hover{background:#eef1f6;}
.nav-group{display:inline-flex;gap:2px;padding-left:8px;margin-left:4px;border-left:1px solid var(--line);}
.nav-group a{font-weight:500;color:var(--ink-soft);padding:8px 8px;}
.appbar-right{margin-left:auto;display:flex;align-items:center;gap:10px;}
.user-name{font-weight:600;}
.role-badge{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;}
.role-owner{background:var(--owner);}
.role-staff{background:var(--staff);}

/* ---------- フラッシュ ---------- */
.flash{padding:12px 16px;margin:10px 14px;border-radius:8px;font-weight:600;}
.flash-success{background:#e4f4ea;color:var(--success);border:1px solid #b6e0c6;}
.flash-error{background:#fbe6e6;color:var(--danger);border:1px solid #f0b9b9;}
.flash-info{background:#e7eefc;color:var(--primary-dark);border:1px solid #bcd2f3;}

/* ---------- コンテンツ ---------- */
.content{padding:14px;}
.page-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px;}
.page-title{font-size:20px;font-weight:700;margin:0;}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;margin-bottom:14px;}
.muted{color:var(--ink-soft);}
.right{margin-left:auto;}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  min-height:44px;padding:10px 18px;border-radius:10px;border:1px solid var(--line-strong);
  background:#fff;color:var(--ink);font-size:15px;font-weight:700;cursor:pointer;text-decoration:none;
}
.btn:hover{background:#f0f3f8;}
.btn:focus-visible{outline:3px solid var(--focus);outline-offset:2px;}
.btn-primary{background:var(--primary);border-color:var(--primary-dark);color:#fff;}
.btn-primary:hover{background:var(--primary-dark);}
.btn-success{background:var(--success);border-color:#155f3b;color:#fff;}
.btn-danger{background:var(--danger);border-color:#922b1f;color:#fff;}
.btn-ghost{background:transparent;border-color:var(--line);}
.btn-sm{min-height:36px;padding:6px 12px;font-size:14px;}
.btn-lg{min-height:54px;font-size:17px;padding:14px 22px;}
.btn[disabled]{opacity:.5;cursor:not-allowed;}
.btn-block{width:100%;}

/* ---------- フォーム ---------- */
.form-row{margin-bottom:14px;}
.form-row label{display:block;font-weight:700;margin-bottom:5px;}
.input,select,textarea{
  width:100%;min-height:44px;padding:9px 12px;border:1px solid var(--line-strong);
  border-radius:8px;font-size:15px;background:#fff;color:var(--ink);
}
textarea{min-height:80px;}
.input:focus,select:focus,textarea:focus{outline:3px solid var(--focus);outline-offset:1px;border-color:var(--primary);}
.field-error{color:var(--danger);font-size:13px;margin-top:4px;font-weight:600;}
.has-error .input,.has-error select,.has-error textarea{border-color:var(--danger);background:#fdf3f3;}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;}
.form-actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap;}
.hint{font-size:13px;color:var(--ink-soft);margin-top:4px;}
.inline{display:inline;}

/* ---------- 日別予約表 ---------- */
.day-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.day-date{font-size:20px;font-weight:700;min-width:230px;text-align:center;}
.day-toolbar .spacer{flex:1;}

.day-scroll{overflow-x:auto;border:1px solid var(--line-strong);border-radius:10px;background:#fff;position:relative;width:100%;}
/* 画面幅にフィットさせる。情報列は固定幅、時間列は残り幅を均等分割。
   バー位置は％指定なので、時間列の幅が変わっても常に整列する。
   → どんなタブレット幅でも 9:00〜17:00 の全マスが横スクロールなしで収まる。 */
.day-table{border-collapse:collapse;width:100%;table-layout:fixed;}
.day-table th,.day-table td{border:1px solid var(--line);padding:0;}
.day-table thead th{
  background:#eef1f6;font-size:12px;font-weight:700;height:38px;text-align:center;
  position:sticky;top:0;z-index:20;
}
/* 情報列は固定幅（タブレット最優先でコンパクトに） */
.col-no{width:32px;}
.col-start{width:50px;}
.col-name{width:84px;}
.col-menu{width:120px;}
.col-staff{width:60px;}
.col-price{width:64px;}
.col-end{width:50px;}
.col-status{width:70px;}
/* 編集ボタン列は通常（PC・タブレット）は非表示。スマホでのみ表示する。 */
.col-edit{display:none;}
/* 編集は鉛筆アイコンのボタン（テキスト無し）。色で編集を連想させる。 */
.btn-edit{min-height:30px;padding:4px 8px;color:var(--primary-dark);}
.btn-edit .ic-edit{display:block;}
/* メニュー列は文字の頭に少しだけ余白を持たせて読みやすく（名前列と同程度） */
.day-table td.col-menu{padding-left:7px;}
/* 時間列は幅指定なし＝残り幅を均等分割（％バーと整列）。
   時刻は紙と同じく各マスの上部中央に表示（開始時刻）。 */
.time-col{font-size:11px;line-height:1.05;padding:2px 0;overflow:hidden;text-align:center;}
.time-col .th-h{display:block;font-weight:700;}
.time-col .th-m{display:block;font-size:9px;color:var(--ink-soft);}

.sticky-left{position:sticky;z-index:15;background:#fff;}
.sticky-right{position:sticky;z-index:15;background:#fff;}
.day-table thead .sticky-left,.day-table thead .sticky-right{z-index:25;background:#eef1f6;}
/* 左列の left 値（列幅に対応） */
.l0{left:0;}
.l1{left:32px;}      /* No 32 */
.l2{left:82px;}      /* +開始 50 */
.l3{left:166px;}     /* +名前 84 */
/* 右列の right 値（列幅に対応） */
.r0{right:0;}        /* 状態 70 */
.r1{right:70px;}     /* 終了 50 */
.r2{right:120px;}    /* 料金 64 (=70+50) */
.r3{right:184px;}    /* 担当 60 (=120+64) */
.sticky-left.shadow{box-shadow:2px 0 4px rgba(0,0,0,.08);}
.sticky-right.shadow{box-shadow:-2px 0 4px rgba(0,0,0,.08);}

.day-table tbody td{height:var(--row-h);vertical-align:middle;}
.cell-pad{padding:4px 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cell-center{text-align:center;}
.row-no{color:var(--ink-soft);font-size:12px;text-align:center;}
.cust-name{font-weight:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;}
.cust-caution{color:var(--danger);font-size:11px;font-weight:700;}

/* タイムライン */
.timeline-cell{padding:0;position:relative;}
.timeline{position:relative;height:var(--row-h);width:100%;}
.slot-bg{position:absolute;top:0;height:100%;border-right:1px dashed #e4e7ee;cursor:pointer;}
.slot-bg:hover{background:#eef6ff;}
.slot-bg.hour{border-right:1px solid #cfd5df;}

.res-bar{
  position:absolute;top:3px;height:calc(var(--row-h) - 6px);border-radius:6px;
  padding:2px 5px;overflow:hidden;cursor:pointer;color:#fff;font-size:10.5px;line-height:1.2;
  border:1px solid rgba(0,0,0,.18);box-shadow:0 1px 2px rgba(0,0,0,.15);min-width:14px;
}
.res-bar:focus-visible{outline:3px solid #ffd34d;outline-offset:1px;}
.res-bar .bar-menu{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;}
.res-bar .bar-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;opacity:.95;}
.bar-owner{background:var(--owner);}
.bar-staff{background:var(--staff);}
.bar-canceled{background:#9aa3b2;text-decoration:line-through;opacity:.85;}
.bar-paid{box-shadow:inset 0 0 0 2px rgba(255,255,255,.6),0 1px 2px rgba(0,0,0,.2);}

.status-pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;}
.st-reserved{background:#e7eefc;color:var(--primary-dark);}
.st-visited{background:#fff3da;color:var(--warn);}
.st-paid{background:#e4f4ea;color:var(--success);}
.st-canceled{background:#eceef2;color:var(--ink-soft);}
.st-no_show{background:#fbe6e6;color:var(--danger);}

/* ---------- 集計フッター ---------- */
.summary-bar{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.sum-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 16px;min-width:110px;}
.sum-card .label{font-size:12px;color:var(--ink-soft);}
.sum-card .value{font-size:22px;font-weight:700;}

/* ---------- カード/テーブル(集計) ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px;}
.kpi{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px;}
.kpi .label{font-size:13px;color:var(--ink-soft);}
.kpi .value{font-size:26px;font-weight:700;}
.data-table{width:100%;border-collapse:collapse;background:#fff;}
.data-table th,.data-table td{border:1px solid var(--line);padding:8px 10px;text-align:left;}
.data-table th{background:#eef1f6;}
.data-table td.num,.data-table th.num{text-align:right;}

/* ---------- メニュー選択ボタン ---------- */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;}
.menu-section-title{font-weight:700;margin:14px 0 8px;}
.menu-btn{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  min-height:60px;padding:10px 12px;border:2px solid var(--line-strong);border-radius:10px;
  background:#fff;cursor:pointer;text-align:left;font-size:15px;font-weight:700;
}
.menu-btn .dur{font-size:12px;color:var(--ink-soft);font-weight:600;}
.menu-btn.selected{border-color:var(--primary);background:var(--owner-bg);}
.menu-btn.set{border-style:dashed;}

.selected-list{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0;}
.chip{background:var(--owner-bg);border:1px solid var(--primary);border-radius:999px;padding:5px 12px;font-weight:700;}
.chip a{color:var(--primary-dark);text-decoration:underline;}
/* 担当列は途切れた文字を「…」なしでそのまま隠す */
.day-table td.col-staff{text-overflow:clip;}

/* ---------- 確認/モーダル ---------- */
.modal-back{position:fixed;inset:0;background:rgba(20,24,33,.5);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;}
.modal{background:#fff;border-radius:12px;max-width:520px;width:100%;padding:20px;max-height:90vh;overflow:auto;}
.modal h2{margin-top:0;}
.confirm-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--line);}
.confirm-row .k{color:var(--ink-soft);font-weight:600;}
.confirm-row .v{font-weight:700;text-align:right;}

/* ---------- 検索結果リスト ---------- */
.result-list{display:flex;flex-direction:column;gap:8px;}
.result-item{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 14px;border:1px solid var(--line-strong);border-radius:10px;background:#fff;}
.res-time{font-size:18px;font-weight:700;white-space:nowrap;}
.res-staff{display:flex;gap:6px;flex-wrap:wrap;flex:1;min-width:120px;}
.res-actions{display:flex;gap:8px;flex-wrap:wrap;}
.staff-tag{padding:3px 10px;border-radius:999px;color:#fff;font-weight:700;font-size:13px;white-space:nowrap;}
.tag-owner{background:var(--owner);}
.tag-staff{background:var(--staff);}
/* スマホ：時間・スタッフ・予約ボタンを縦並びにして横幅いっぱいに */
@media (max-width:640px){
  .result-item{flex-direction:column;align-items:stretch;gap:10px;}
  .res-staff{flex:none;}
  .res-actions{flex-direction:column;}
  .res-actions .btn{width:100%;}
}

/* ---------- ローディング ---------- */
.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;z-index:200;}
.spinner{width:42px;height:42px;border:5px solid #cfd5df;border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ---------- 認証画面 ---------- */
.auth-body{background:linear-gradient(160deg,#e9eef6,#f4f5f7);}
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}
.auth-card{background:#fff;border-radius:14px;padding:28px;max-width:420px;width:100%;box-shadow:0 6px 24px rgba(0,0,0,.08);}
.auth-card h1{font-size:22px;margin:0 0 4px;}

/* ---------- 補助 ---------- */
.row-actions{display:flex;gap:8px;flex-wrap:wrap;}
.tab-toggle{display:flex;gap:0;border:1px solid var(--line-strong);border-radius:8px;overflow:hidden;width:fit-content;}
.tab-toggle button{border:0;background:#fff;padding:10px 16px;font-weight:700;cursor:pointer;}
.tab-toggle button.active{background:var(--primary);color:#fff;}
@media (max-width:700px){
  .mainnav .nav-group{display:none;}
}

/* ===== タブレットサイズ（〜1024px）：名前・メニュー列を狭くして時間マスを広く ===== */
@media (max-width:1024px){
  .col-name{width:68px;}
  .col-menu{width:84px;}
  .l3{left:150px;}   /* No32 + 開始50 + 名前68 */
}

/* ===== 中間幅（〜900px）の予約表 =====
   タイムマーカー以外の列をさらに細く・小さい文字にし、文字は折り返して
   省略せず全て表示する（時間マスの幅を最大限確保）。 */
@media (max-width:900px){
  .day-table th,.day-table td{font-size:11px;}
  .day-table .cell-pad{padding:2px 3px;}
  .day-table td.col-menu{padding-left:4px;}  /* 名前列と同程度の余白に */
  /* 省略せず折り返して全部見せる（「09:…」のような切れを防ぐ） */
  .day-table .cell-pad,
  .day-table td.col-staff,
  .cust-name{white-space:normal;overflow:visible;text-overflow:clip;word-break:break-all;}
  /* お客様名は通常の太さ */
  .cust-name{font-weight:normal;font-size:11px;}
  .col-no{width:20px;}
  .col-start{width:36px;}
  .col-name{width:64px;}
  .col-menu{width:74px;}
  .col-staff{width:40px;}
  .col-price{width:46px;}
  .col-end{width:36px;}
  .col-status{width:40px;}
  .status-pill{padding:1px 3px;font-size:10px;white-space:normal;}
  .time-col{font-size:10px;}
  .res-bar{font-size:9.5px;padding:1px 3px;line-height:1.15;}
  /* 固定列のオフセットも縮小後の幅に合わせる */
  .l1{left:20px;} .l2{left:56px;} .l3{left:120px;}
  .r1{right:40px;} .r2{right:76px;} .r3{right:122px;}
}

/* ===== 小タブレット幅（641〜768px）：名前・メニュー列をさらに狭く ===== */
@media (min-width:641px) and (max-width:768px){
  .col-name{width:44px;}
  .col-menu{width:58px;}
  .l3{left:100px;}   /* No20 + 開始36 + 名前44 */
}

/* ===== スマホ表示の予約表 =====
   時間グリッド・料金・終了・状態・No.は隠し、担当/お客様名/メニュー/開始 のみ表示。
   担当は狭く（3文字程度で途切れてOK）、メニューは少し広く。 */
@media (max-width:640px){
  /* スマホでもタイムマーカーを表示する。固定列はやめ、横スクロールで全体を確認。
     その他の列は最小幅にして時間部分を最大限広く確保する。 */
  .day-table .sticky-left,.day-table .sticky-right{position:static;box-shadow:none;}
  .day-table{min-width:720px;}     /* 時間マスが読める最低幅を確保（横スクロール） */
  /* セルの上を左右スワイプしてもスクロールできるように（指でのスクロールを滑らかに） */
  .day-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;}
  .col-no{width:20px;}
  .col-start{width:36px;}
  .col-name{width:54px;}
  .col-menu{width:50px;}
  .col-staff{width:34px;}
  .col-price{width:42px;}
  .col-end{width:34px;}
  .col-status{width:42px;}
  /* 編集アイコンボタン列を表示（一番右） */
  .col-edit{display:table-cell;width:46px;}
  .btn-edit{min-height:34px;padding:6px;}
  .day-table th,.day-table td{font-size:11px;}
  .day-table .cell-pad{padding:2px 2px;}
  .day-table td.col-menu{padding-left:4px;}
  .res-bar{font-size:9px;padding:1px 2px;line-height:1.1;}
  .status-pill{padding:1px 3px;font-size:9px;}
}
