
main.main{
  width: calc(100% - 230px);
  margin-left: 230px;
  margin-top: 20px;
}
.app{width:800px; max-width:100%;}

.notice{
  display:grid; grid-template-columns: 88px 1fr; gap:8px; align-items:start;
  background:var(--panel); border:1px solid var(--border); border-radius:8px; padding:10px 12px; box-shadow:0 1px 0 #00000008;
  margin-bottom:14px;
}
.notice .label{
  font-size:12px; color:#111827; background:#f3f4f6; border:1px solid var(--border); border-radius:6px; padding:6px 8px; text-align:center; font-weight:700;
}
.notice .msg{
  font-size:12px; color:#111827; background:#f9fafb; border:1px solid var(--border); border-radius:6px; padding:6px 8px;
}

.section + .section{margin-top:22px}
.section h2{font-size:20px; padding:0 0 10px 0; font-weight:700; display:flex; gap:10px; align-items:center}
.section h2 a{font-size:12px; color:var(--primary); text-decoration:none}
.section h2 a:hover{text-decoration:underline}

.inline-form{display:flex; gap:8px; align-items:center}
.input{flex:1;}
input[type="text"], .pill{
  width:100%; height:36px; border:1px solid var(--border); border-radius:8px; padding:0 12px; background:#fff; color:#111827; font-size:13px; outline:none;
}
input::placeholder{color:#9ca3af}

.pill{display:inline-flex; align-items:center; gap:6px; width:auto; padding:0 10px; background:#eef2f7; color:#111827}
.pill .caret{font-size:12px}

.btn{
  height:36px; padding:0 14px; border:1px solid #9aa3af66; border-radius:8px; background:#e5e7eb; color:#111827; font-weight:700; font-size:13px; cursor:pointer;
}
.btn:hover{filter:brightness(0.98)}

.counter{font-size:15px; color:#374151; margin:6px 0 10px}

/* スプレッドシート登録 */
.sheets .row{display:grid; 
  grid-template-columns: 24px 1fr auto;
  /*grid-template-columns: 1fr auto;*/
   gap:10px; align-items:start; padding:12px; background:var(--panel); border:1px solid var(--border); border-radius:10px; margin-bottom:12px; position:relative; overflow:hidden}
.sheets .num{font-weight:700; color:#111827; padding-top:4px}
.sheets .fields{display:flex; flex-direction:column; gap:8px}
.sheets .fields .group-label{font-size:12px; color:var(--muted)}
.sheets .fields input{height:36px}
.sheets .row .btn{align-self:center; width:72px}

/* rowローディングオーバーレイ */
.sheets .row.loading::after{
  content:""; position:absolute; left:0; top:0; right:0; bottom:0;
  background:rgba(0,0,0,0.08); border-radius:10px; z-index:2; pointer-events:all; cursor:not-allowed;
}

/* small top bar under LP登録 */
.lp-top{display:flex; align-items:center; gap:10px;}
.lp-top .spacer{flex:1}

@media (max-width:430px){
  .inline-form{flex-wrap:wrap}
  .pill{order:2}
  .btn{order:3}
  .input{order:1; flex-basis:100%}
  .sheets .row{grid-template-columns: 24px 1fr;}
  .sheets .row .btn{grid-column:2 / -1; justify-self:end}
}
div.fields div{word-break: break-all;}


.sidebar {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: 100;
  padding: 72px 0 0;
  box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1);
  z-index: 99;
  width: 210px !important;
}
@media (max-width: 767.98px) {
  .sidebar {
    top: 11.5rem;
    padding: 0;
  }
}
.navbar {
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .1);
}
@media (min-width: 767.98px) {
  .navbar {
    top: 0;
    position: sticky;
    z-index: 999;
  }
}
.sidebar .nav-link {
  color: #777;
}
.sidebar .nav-link.active {
  color: #0d6efd;
}
a.active{
  background: #3490dc;
  color: #fff !important;
}
.sidebar .nav-item .nav-link {
    cursor: pointer;
}
#sidebar>div>ul>li>span{
  background: transparent;
  color: #777;
}
#sidebar>div>ul>li>span[aria-expanded="false"]{
  background: transparent;
  color: #777;
}
span.nav-link.active{
  color: #000 !important;
}
.icon.icon-sm {
  height: 1.5rem;
}
.sidebar .nav-link[aria-expanded=true] .link-arrow{
  transform: rotate(90deg);
  transition: all 0.2s ease;
}
.multi-level.collapse:not(.show){
  overflow: hidden;
  height: 0;
  transition: height 2.66s;
}
.multi-level.collapse.show{
  overflow: inherit;
  height: auto;
  transition: height 2.66s;
}

/* ユーザー登録フォーム（画像調整） */
.user-form{display:grid; grid-template-columns: 140px 1fr 80px; gap:12px 10px; align-items:center}
.user-form .btn.primary{background:#c7d7f3; border-color:#a5bff0; color:#111827}
.user-form .btn.primary:hover{filter:brightness(0.97)}