/* =====================================================================
   Melow. サロン予約  デザイン方針：白・アイボリー・ベージュ・モカ基調。
   ナチュラルで上品な小規模サロン感。AI感/SaaS感/派手さは避ける。
   ===================================================================== */
:root{
  --bg:#FAF8F5;        /* 背景（薄いアイボリー） */
  --card:#FFFFFF;      /* カード背景 */
  --ink:#33302D;       /* メイン文字 */
  --muted:#8A8178;     /* サブ文字 */
  --accent:#8B6F5A;    /* アクセント（モカ） */
  --accent-d:#6F5847;  /* アクセント濃（hover） */
  --accent-soft:#EFE7DE;/* 薄いアクセント背景 */
  --line:#E6DDD4;      /* ボーダー */
  --sub-border:#D8CEC5;/* サブボタン枠 */
  --sub-ink:#5F5148;   /* サブボタン文字 */
  --danger:#B85C5C;    /* 注意・キャンセル系 */
  --danger-bg:#FFF7F7; /* 注意ボタン背景 */
  --danger-border:#E8CACA;
  --shadow:0 1px 2px rgba(90,70,50,.05);
  font-family:"Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",system-ui,-apple-system,"Yu Gothic UI",Meiryo,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);line-height:1.7;font-size:15px;
  font-family:inherit;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--accent-d)}
h1,h2,h3{margin:.1em 0 .5em;font-weight:700;letter-spacing:.01em}
h1{font-size:1.3rem}h2{font-size:1.08rem}h3{font-size:.98rem}

/* ロゴ Melow.：画像があれば画像、無ければセリフ体テキストで上品に表示 */
.brand{font-family:'Didot','Bodoni 72','Hiragino Mincho ProN',Georgia,'Times New Roman',serif;
  font-weight:600;font-size:1.5rem;letter-spacing:.01em;color:var(--ink);line-height:1;
  display:inline-flex;align-items:center}
.brand-img{height:26px;width:auto;display:block}
.brand-txt{display:inline-block}
.brand-lg{font-size:2.6rem}
.brand-lg .brand-img{height:56px}

/* 控えめな装飾：中央に小さな菱形をあしらった細い区切り線 */
.divider-deco{display:flex;align-items:center;gap:12px;margin:18px 0}
.divider-deco::before,.divider-deco::after{content:"";flex:1;height:1px;background:var(--line)}
.divider-deco>span{width:7px;height:7px;background:var(--accent);opacity:.55;transform:rotate(45deg);border-radius:1px;flex:none}

/* 見出しの小さな菱形アクセント（お客さま画面のみ・管理画面は素のまま） */
h2.sec,h3.sec{display:flex;align-items:center;gap:9px}
h2.sec::before,h3.sec::before{content:"";width:6px;height:6px;background:var(--accent);opacity:.7;
  transform:rotate(45deg);border-radius:1px;flex:none}

.app{max-width:900px;margin:0 auto;padding:0 14px 90px}

/* トップバー：白地・細ボーダー・影なし（清潔感） */
.topbar{position:sticky;top:0;z-index:10;background:var(--card);color:var(--ink);
  min-height:58px;padding:8px 18px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--line)}
.topbar .title{font-weight:700}
.topbar .sub{font-size:.74rem;color:var(--muted);margin-top:2px}

.card{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:18px;margin:14px 0;box-shadow:var(--shadow)}
.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.row.between{justify-content:space-between}
.grid{display:grid;gap:12px}
.grid.cols2{grid-template-columns:1fr 1fr}
.grid.cols3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:560px){.grid.cols3{grid-template-columns:1fr 1fr}}
.muted{color:var(--muted)}
.small{font-size:.83rem}
.right{text-align:right}
.center{text-align:center}
.hr{height:1px;background:var(--line);margin:14px 0}

label{display:block;font-size:.83rem;color:var(--muted);margin:10px 0 4px}
input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line);
  border-radius:12px;background:#fff;color:var(--ink);font-size:15px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(139,111,90,.12)}
textarea{min-height:76px;resize:vertical}

/* ボタン：大きめで押しやすく（主要CTAは高さ48px・角丸12px） */
button{cursor:pointer;border:none;border-radius:12px;height:48px;padding:0 18px;font-size:15px;
  font-weight:600;font-family:inherit;background:var(--accent);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,border-color .15s}
button:hover{background:var(--accent-d)}
button.ghost{background:#fff;border:1px solid var(--sub-border);color:var(--sub-ink)}
button.ghost:hover{background:#FBF9F6}
button.danger{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger)}
button.danger:hover{background:#FDEEEE}
button.ok{background:var(--accent);color:#fff}        /* 肯定操作＝モカ */
button.ok:hover{background:var(--accent-d)}
button.warn{background:#fff;border:1px solid var(--sub-border);color:var(--sub-ink)} /* 弱い注意＝サブ */
button.warn:hover{background:#FBF9F6}
button.sm{height:auto;min-height:36px;padding:8px 13px;font-size:13px;border-radius:10px}
button:disabled{opacity:.45;cursor:not-allowed}

.chip{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--accent-soft);
  font-size:.77rem;color:#6E5B49;white-space:nowrap}
.badge{display:inline-block;min-width:18px;padding:1px 6px;border-radius:999px;
  background:var(--danger);color:#fff;font-size:.72rem;text-align:center}

/* ステータス：淡背景＋濃文字のくすみトーン（青・原色は使わない） */
.st{padding:3px 11px;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap}
.st-confirmed{background:#E8EEE6;color:#55694F}
.st-completed{background:#EEE6DC;color:#6E5B49}
.st-cancelled{background:#ECE7E2;color:#8A8178}
.st-provisional{background:#F3EAD9;color:#8C7233}
.st-change_requested,.st-cancel_requested{background:#EDE6DE;color:#7A6B5C}
.st-no_show{background:#F6E7E7;color:#B85C5C}
.st-expired{background:#ECE9E6;color:#9A9188}

/* タブバー */
.tabbar{display:flex;gap:4px;overflow-x:auto;background:var(--card);border-bottom:1px solid var(--line);
  position:sticky;top:58px;z-index:9;padding:7px 10px}
.tabbar button{height:auto;background:transparent;color:var(--muted);border-radius:10px;
  white-space:nowrap;padding:9px 14px;font-weight:600}
.tabbar button:hover{background:#FBF9F6}
.tabbar button.active{background:var(--accent-soft);color:var(--ink)}

.list-item{border:1px solid var(--line);border-radius:12px;padding:14px;margin:10px 0;background:#fff}
.list-item.tight{padding:11px 13px;margin:8px 0}
.kv{display:flex;justify-content:space-between;gap:12px;padding:5px 0;border-bottom:1px dashed var(--line)}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted);font-size:.86rem}

.slotgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:9px}
.slot{border:1px solid var(--line);border-radius:12px;padding:11px 6px;text-align:center;background:#fff;font-size:.88rem}
.slot.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-d);font-weight:700}
.selectable{cursor:pointer}
.selectable:hover{border-color:var(--accent)}

.notice{background:var(--accent-soft);border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:.86rem;color:#5F5148}
.notice.warn{background:#F7EFDF;border-color:#E9D9B6;color:#836A38}
.notice.danger{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger)}

.overlay{position:fixed;inset:0;background:rgba(51,48,45,.38);display:flex;align-items:flex-end;
  justify-content:center;z-index:50}
.modal{background:#fff;border-radius:18px 18px 0 0;width:100%;max-width:900px;max-height:88vh;
  overflow:auto;padding:20px;padding-bottom:30px}
@media(min-width:600px){.overlay{align-items:center}.modal{border-radius:18px}}
.modal h2{margin-top:0}

.stepper{display:flex;gap:6px;margin:6px 0 10px}
.step{flex:1;height:5px;border-radius:3px;background:var(--line)}
.step.done{background:var(--accent)}
.pricetag{font-weight:700;color:var(--accent)}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:#33302D;color:#fff;
  padding:11px 20px;border-radius:24px;font-size:.9rem;z-index:100;box-shadow:0 4px 16px rgba(51,48,45,.2);
  opacity:0;transition:opacity .2s;pointer-events:none}
.toast.show{opacity:1}
