/* FanSales — モバイルファースト / 白・緑・グレー基調 */
:root{
  --green:#2e7d5b; --green-d:#246449; --green-l:#eafaf1;
  --ink:#1f2a28; --muted:#6b7a75; --line:#e1e8e4; --bg:#f4f7f5; --card:#fff;
  --warn:#b8860b; --warn-bg:#fff8e6; --danger:#b3261e; --danger-bg:#fdeceb;
  --info:#2d6cb5; --radius:14px; --shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.6;font-size:15px;-webkit-text-size-adjust:100%}
.boot{padding:40px;text-align:center;color:var(--muted)}
button{font-family:inherit;font-size:15px;cursor:pointer}
a{color:var(--green-d)}
input,select,textarea{font-family:inherit;font-size:16px;width:100%;padding:12px 12px;border:1px solid var(--line);
  border-radius:10px;background:#fff;color:var(--ink)}
textarea{min-height:84px;resize:vertical}
label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px;font-weight:600}
.req::after{content:" *";color:var(--danger)}

/* layout */
.app-header{position:sticky;top:0;z-index:20;background:var(--green);color:#fff;
  display:flex;align-items:center;gap:10px;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top))}
.app-header .brand{font-weight:700;font-size:17px;letter-spacing:.02em}
.app-header .spacer{flex:1}
.app-header .who{font-size:12px;opacity:.9;text-align:right;line-height:1.3}
.menu-btn{background:rgba(255,255,255,.15);border:0;color:#fff;border-radius:10px;padding:8px 12px}
main{max-width:880px;margin:0 auto;padding:16px 14px 90px}
.page-title{font-size:19px;font-weight:700;margin:6px 2px 14px;display:flex;align-items:center;gap:8px}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px;margin-bottom:14px}
.card h3{margin:0 0 10px;font-size:15px}
.grid{display:grid;gap:12px}
@media(min-width:620px){.grid.cols2{grid-template-columns:1fr 1fr}.grid.cols3{grid-template-columns:1fr 1fr 1fr}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;
  background:var(--green);color:#fff;border:0;border-radius:12px;padding:14px 18px;font-weight:700;min-height:48px}
.btn:active{background:var(--green-d)}
.btn.secondary{background:#fff;color:var(--green-d);border:1.5px solid var(--green)}
.btn.ghost{background:#eef2f0;color:var(--ink)}
.btn.danger{background:var(--danger)}
.btn.sm{width:auto;padding:9px 14px;min-height:0;font-size:13px;border-radius:10px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-row .btn{width:auto;flex:1;min-width:120px}

/* stat tiles */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:620px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:12px}
.stat .n{font-size:22px;font-weight:800;color:var(--green-d)}
.stat .l{font-size:12px;color:var(--muted)}
.stat.warn .n{color:var(--warn)} .stat.danger .n{color:var(--danger)}

/* badges */
.badge{display:inline-block;background:var(--green-l);color:var(--green-d);border:1px solid #cdeadd;
  border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600;white-space:nowrap}
.badge.grey{background:#eef2f0;color:var(--muted);border-color:var(--line)}
.badge.warn{background:var(--warn-bg);color:var(--warn);border-color:#f0d98a}
.badge.danger{background:var(--danger-bg);color:var(--danger);border-color:#f3c9c6}
.badge.info{background:#eaf2fb;color:var(--info);border-color:#cfe0f5}

/* list */
.lead-item{display:flex;align-items:center;gap:12px;padding:14px 14px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;text-align:left;width:100%}
.lead-item:active{background:#fbfdfc}
.lead-item .main{flex:1;min-width:0}
.lead-item .name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lead-item .sub{font-size:12px;color:var(--muted)}
.chev{color:var(--muted)}

/* alerts */
.alert{border-radius:12px;padding:11px 13px;font-size:13px;margin:8px 0;border:1px solid}
.alert.warn{background:var(--warn-bg);border-color:#f0d98a;color:#6b5200}
.alert.danger{background:var(--danger-bg);border-color:#f3c9c6;color:#7a1a15}
.alert.info{background:#eef4fb;border-color:#cfe0f5;color:#244e7a}
.alert.green{background:var(--green-l);border-color:#cdeadd;color:var(--green-d)}
.alert ul{margin:6px 0 0 18px;padding:0}

/* stepper */
.steps{display:flex;gap:6px;overflow-x:auto;padding:4px 0 10px;margin-bottom:8px}
.step-dot{flex:0 0 auto;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 11px}
.step-dot.active{background:var(--green);color:#fff;border-color:var(--green)}
.step-dot.done{background:var(--green-l);color:var(--green-d);border-color:#cdeadd}

/* table */
.kv{width:100%;border-collapse:collapse;font-size:14px}
.kv th{text-align:left;color:var(--muted);font-weight:600;width:42%;padding:8px 6px;vertical-align:top;border-bottom:1px solid var(--line)}
.kv td{padding:8px 6px;border-bottom:1px solid var(--line)}

/* money */
.money-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:8px 0}
.money-grid .m{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px;text-align:center}
.money-grid .m.burden{background:var(--green-l);border-color:#cdeadd}
.money-grid .m .l{font-size:11px;color:var(--muted)}
.money-grid .m .v{font-size:16px;font-weight:800;color:var(--ink)}

/* tabs */
.tabs{display:flex;gap:6px;overflow-x:auto;margin:0 0 12px;position:sticky;top:56px;background:var(--bg);padding:8px 0;z-index:10}
.tab{flex:0 0 auto;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:13px;color:var(--muted)}
.tab.active{background:var(--green);color:#fff;border-color:var(--green)}

/* drawer menu */
.drawer-bg{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:40;display:none}
.drawer-bg.open{display:block}
.drawer{position:fixed;top:0;left:0;bottom:0;width:260px;background:#fff;z-index:50;transform:translateX(-100%);
  transition:transform .2s;padding:16px;box-shadow:var(--shadow);overflow:auto}
.drawer.open{transform:translateX(0)}
.drawer a{display:block;padding:13px 12px;border-radius:10px;color:var(--ink);text-decoration:none;font-weight:600}
.drawer a:active,.drawer a.active{background:var(--green-l);color:var(--green-d)}
.drawer .sec{font-size:11px;color:var(--muted);margin:14px 6px 4px;text-transform:uppercase;letter-spacing:.05em}

/* login */
.login-wrap{max-width:380px;margin:8vh auto;padding:18px}
.login-wrap .logo{text-align:center;font-size:26px;font-weight:800;color:var(--green-d);margin-bottom:4px}
.login-wrap .tag{text-align:center;color:var(--muted);font-size:13px;margin-bottom:18px}

.help{font-size:12px;color:var(--muted);margin-top:3px}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#1f2a28;color:#fff;
  padding:12px 18px;border-radius:12px;z-index:80;max-width:90%;font-size:14px;box-shadow:var(--shadow)}
.toast.err{background:var(--danger)}
.empty{text-align:center;color:var(--muted);padding:30px 10px}
.spin{text-align:center;color:var(--muted);padding:24px}
.inline-link{background:none;border:0;color:var(--green-d);text-decoration:underline;padding:0;width:auto}
hr.sep{border:0;border-top:1px solid var(--line);margin:14px 0}
.foot-note{font-size:11px;color:var(--muted);margin-top:8px}
