/* style.css — 幅を狭めに固定して、サンプル画面と同等の見た目にする調整版 */
/* 上書きしてください */

*, *::before, *::after { box-sizing: border-box; }
:root{
  --blue:#4b66b2;
  --gold:#9a7300;
  --card:#fff;
  --accent:#f2e6c9;
  --low:#fff8e1;
  --medium:#ffe082;
  --high:#ffb300;
  font-family:"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
}

/* App の幅をサンプルに合わせて狭くする（例: 360px） */
html,body{height:100%;margin:0;background:linear-gradient(#fafafa,#f0f0f0);}
.app{ max-width:360px; margin:12px auto; padding:0; background:var(--card); border-radius:12px; box-shadow:0 6px 18px rgba(0,0,0,0.12); overflow:hidden; }

/* header */
header{ background:var(--blue);color:#fff;padding:12px 10px;display:flex;align-items:center;justify-content:center;border-top-left-radius:12px;border-top-right-radius:12px;}
header h1{margin:0;font-size:18px;text-align:center;}

/* top area */
.top-cream{ background:var(--accent); padding:8px 10px; }
.top-cream-inner{ display:flex; align-items:center; justify-content:space-between; }
.user-area{ font-weight:700; padding-left:4px; font-size:14px; }
.logout-area{ display:flex; align-items:center; }
.logout-btn{ background:#fff; border:2px solid #c6c6c6; color:#333; padding:6px 8px; border-radius:8px; font-size:13px; }

/* nav */
.nav-top-box{ margin:10px; border-radius:10px; background:#fff; box-shadow:0 6px 14px rgba(0,0,0,0.06); padding:8px; }
.nav-top-inner{ display:flex; gap:8px; justify-content:center; align-items:center; }

/* ナビボタン（サンプルに近い小さめ固定幅） */
.nav-btn{
  background:var(--gold);
  color:#fff;
  border:none;
  width:96px;
  height:38px;
  padding:0;
  border-radius:8px;
  font-size:14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 0 rgba(0,0,0,0.12);
}
.nav-btn[aria-selected="true"]{ transform:translateY(1px); box-shadow:0 2px 0 rgba(0,0,0,0.08) inset; }

/* form */
.form{ padding:12px; display:flex; flex-direction:column; gap:8px; }
label{ font-size:13px; color:#333; }
input[type="text"], input[type="password"], input[type="number"], input[type="date"], textarea{
  padding:9px; border:1px solid #ccc; border-radius:8px; font-size:14px; width:100%;
}
.inline-row{ display:flex; gap:8px; flex-wrap:wrap; }
.inline-item{ flex:1 1 48%; min-width:100px; display:flex; flex-direction:column; gap:6px; }

/* buttons */
.btn{ border:none; padding:9px 12px; border-radius:8px; font-size:14px; cursor:pointer; box-shadow:0 3px 0 rgba(0,0,0,0.12); }
.btn.primary{ background:var(--gold); color:#fff; box-shadow:0 4px 0 rgba(0,0,0,0.12); }
.btn.secondary{ background:#dcdcdc; color:#333; box-shadow:0 3px 0 rgba(0,0,0,0.08); }

/* login full width */
.login-btn{ display:block; width:100%; background:#e0e0e0; color:#000; padding:10px; border-radius:6px; border:1px solid #bdbdbd; margin-top:8px; }

/* calendar */
.cal-grid{ display:grid; grid-template-columns: repeat(7, calc((100% - 36px) / 7)); gap:6px; margin-top:8px; }
.cal-weekday{ text-align:center; padding:6px 4px; font-weight:700; background:transparent; font-size:13px; }
.cal-day{ padding:8px; border-radius:6px; background:#fff; border:1px solid #eee; min-height:56px; position:relative; display:flex; flex-direction:column; align-items:center; justify-content:flex-start; cursor:pointer; }
.cal-day .date{ font-weight:700; font-size:13px; }
.cal-day .count{ font-weight:700; font-size:14px; margin-top:6px; color:#333; }

/* 色分け */
.cal-day--empty{ background:#fff; border-color:#eee; color:#333; }
.cal-day--low{ background:var(--low); border-color:#ffefc1; color:#222; }
.cal-day--medium{ background:var(--medium); border-color:#ffd26a; color:#222; }
.cal-day--high{ background:var(--high); border-color:#ff9800; color:#111; }

/* Chart wrapper を狭めにして中央寄せ（サンプルと同じ幅に） */
.chart-wrap{
  width: 320px;
  max-width: 100%;
  margin: 6px auto 12px;
  padding: 6px 8px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 6px 14px rgba(0,0,0,0.04);
}
#guestChart{ width:100% !important; height:260px !important; display:block; }

/* modal/card/toast */
.modal{ position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); width:92%; max-width:520px; box-shadow:0 10px 30px rgba(0,0,0,0.3); z-index:1200; background:#fff; border-radius:10px; padding:12px; }
.hidden{ display:none; }
.card{ background:#fff; border-radius:8px; padding:8px; margin-bottom:8px; border:1px solid #e6e6e6; position:relative; padding-right:16px; }
#toast{ position:fixed; left:50%; bottom:12px; transform:translateX(-50%); background:#333; color:#fff; padding:8px 12px; border-radius:8px; z-index:2000; font-size:13px; }
footer{ padding:8px; text-align:center; font-size:12px; color:#999; }
.muted{ color:#666; font-size:12px; }

/* small screens */
@media (max-width:360px){
  .app{ margin:8px; }
  .nav-top-inner{ gap:6px; }
  .nav-btn{ width:86px; height:36px; font-size:13px; }
  .cal-day{ min-height:52px; }
  .chart-wrap{ width: 100%; }
}