:root{--bg:#f6f7fb;--card:#fff;--text:#182033;--muted:#667085;--line:#e5e7eb;--primary:#1f6feb;--ok:#166534;--warn:#92400e;--danger:#991b1b;--soft:#eef4ff}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",Meiryo,sans-serif;background:var(--bg);color:var(--text);line-height:1.65}.topbar{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--line);padding:12px 16px;display:flex;gap:16px;align-items:center;justify-content:space-between}.brand a{font-weight:800;color:var(--text);text-decoration:none}.brand span{margin-left:8px;color:var(--muted);font-size:12px}nav{display:flex;gap:10px;flex-wrap:wrap}nav a{color:var(--primary);text-decoration:none;font-weight:700}.container{max-width:1080px;margin:0 auto;padding:20px 14px}.footer{text-align:center;color:var(--muted);font-size:12px;padding:24px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(16,24,40,.04);margin-bottom:14px}.card h1,.card h2,.card h3{margin-top:0}.hero{background:linear-gradient(135deg,#fff,#eef4ff)}.metric{font-size:28px;font-weight:900}.muted{color:var(--muted)}.btn{display:inline-block;border:0;border-radius:12px;background:var(--primary);color:#fff!important;padding:10px 14px;text-decoration:none;font-weight:800;cursor:pointer}.btn.secondary{background:#344054}.btn.light{background:#eef4ff;color:#1f3b7a!important}.btn.danger{background:var(--danger)}input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;font:inherit}label{font-weight:800;display:block;margin:10px 0 4px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}th{font-size:13px;color:var(--muted)}.pill{display:inline-block;border-radius:999px;padding:3px 10px;font-weight:800;font-size:12px}.pill.ok{background:#dcfce7;color:var(--ok)}.pill.warn{background:#fef3c7;color:var(--warn)}.pill.danger{background:#fee2e2;color:var(--danger)}.danger{border-color:#fecaca;background:#fff7f7}.notice{background:#f8fafc;border-left:5px solid var(--primary);padding:12px;border-radius:12px}.help{display:inline-flex;align-items:center;justify-content:center;margin-left:4px;width:20px;height:20px;border-radius:50%;background:var(--soft);color:#1f3b7a;font-weight:900;font-size:12px;cursor:help}.up{color:var(--ok);font-weight:900}.down{color:var(--danger);font-weight:900}@media(max-width:680px){.topbar{align-items:flex-start;flex-direction:column}.metric{font-size:24px}th,td{font-size:14px}.container{padding:14px 10px}}

/* v0.1.1 help modal and danger actions */
.help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.35rem;
  height: 1.35rem;
  border: 0;
  border-radius: 999px;
  background: #eef4ff;
  color: #2353a3;
  font-weight: 700;
  cursor: pointer;
  margin-left: .25rem;
  vertical-align: middle;
}
.help:hover, .help:focus { outline: 2px solid #9bbcff; }
.help-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.35);
  z-index: 1000;
  padding: 1rem;
}
.help-modal.is-open { display: flex; }
.help-modal-panel {
  width: min(520px, 100%);
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(0,0,0,.18);
  padding: 1.25rem;
  position: relative;
}
.help-modal-panel h2 { margin-top: 0; }
.help-modal-close {
  position: absolute;
  top: .7rem;
  right: .8rem;
  border: 0;
  background: #f1f1f1;
  border-radius: 999px;
  width: 2rem;
  height: 2rem;
  font-size: 1.2rem;
  cursor: pointer;
}
.btn.danger, button.danger {
  background: #b42318;
  color: #fff;
}
.inline-form { display: inline; }
.small-note { font-size: .9rem; color: #667085; }

/* v0.1.4 chart and preventive UI */
.chart-box{width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:18px;background:#fff;padding:8px}.chart-box svg{width:100%;min-width:620px;height:auto;display:block}.error-list{border-left:5px solid var(--danger);background:#fff7f7;padding:12px;border-radius:12px}.success-list{border-left:5px solid var(--ok);background:#f0fdf4;padding:12px;border-radius:12px}.form-hint{font-size:.9rem;color:var(--muted);margin-top:4px}.action-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.nowrap{white-space:nowrap}
.inline-form{display:inline-flex;gap:6px;flex-wrap:wrap;margin-top:8px}.task-item{margin-bottom:12px}

/* v0.1.6 chart tooltip */
.chart-box{position:relative}.chart-point{cursor:pointer}.chart-point:hover,.chart-point:focus{stroke:#ffffff;stroke-width:3;outline:none}.chart-tooltip{display:none;position:absolute;z-index:5;min-width:220px;max-width:280px;background:#101828;color:#fff;border-radius:14px;padding:10px 12px;font-size:13px;line-height:1.55;box-shadow:0 14px 28px rgba(16,24,40,.22);pointer-events:none}.chart-tooltip.is-open{display:block}.chart-tooltip .muted{color:#d0d5dd}input[type="checkbox"]{width:auto;margin-right:6px}

/* v0.1.7b guide content */
.guide-section h2{border-bottom:1px solid var(--line);padding-bottom:6px}.check-list{padding-left:0;list-style:none}.check-list li{position:relative;padding-left:1.7rem;margin:.35rem 0}.check-list li:before{content:"✓";position:absolute;left:0;top:0;color:var(--ok);font-weight:900}.guide-section p{font-size:1.02rem}.manual-note{background:#fffdf0;border-left:5px solid #f59e0b;padding:12px;border-radius:12px}

details pre{white-space:pre-wrap;background:#f7f7f7;border:1px solid #ddd;border-radius:8px;padding:12px;overflow:auto;}
code{background:#f2f2f2;border-radius:4px;padding:1px 4px;}


/* v0.1.8b navigation redesign: project UX review with web designer + beginner perspective */
.topbar{
  position:sticky;
  top:0;
  z-index:10;
  background:#fff;
  border-bottom:1px solid var(--line);
  padding:12px 16px;
  display:block;
}
.topbar-main{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  max-width:1180px;
  margin:0 auto 10px;
}
.brand a{font-size:1.05rem;}
.user-chip{
  font-size:13px;
  color:#344054;
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 12px;
  font-weight:800;
  white-space:nowrap;
}
.role-badge{
  display:inline-block;
  margin-left:6px;
  padding:2px 8px;
  border-radius:999px;
  background:#e0f2fe;
  color:#075985;
  font-size:12px;
}
.nav-groups{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(320px,1.4fr) minmax(260px,1fr) auto;
  gap:12px;
  align-items:stretch;
}
.nav-group{
  border:1px solid var(--line);
  border-radius:16px;
  padding:10px;
  background:#f8fafc;
  box-shadow:0 4px 14px rgba(16,24,40,.035);
}
.nav-group-title{
  display:block;
  width:max-content;
  margin-bottom:8px;
  padding:3px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  color:#344054;
  background:#fff;
  border:1px solid var(--line);
}
.stock-menu{border-left:5px solid var(--primary);}
.admin-menu{border-left:5px solid #b45309;background:#fffbeb;}
.account-menu{border-left:5px solid #64748b;}
.nav-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.nav-links a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:7px 12px;
  border-radius:12px;
  background:#fff;
  border:1px solid #d0d5dd;
  color:#1f3b7a;
  text-decoration:none;
  font-weight:850;
  line-height:1.2;
}
.nav-links a:hover,.nav-links a:focus{
  outline:3px solid #bfdbfe;
  border-color:#93c5fd;
  background:#eff6ff;
}
.admin-menu .nav-links a{color:#7c2d12;border-color:#fed7aa;}
.admin-menu .nav-links a:hover,.admin-menu .nav-links a:focus{background:#fff7ed;outline-color:#fed7aa;}
.logout-link{color:#7f1d1d!important;border-color:#fecaca!important;background:#fff7f7!important;}
.readonly-box{padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#f8fafc;color:#344054}.menu-note{font-size:.9rem;color:var(--muted);margin-top:4px}
@media(max-width:920px){
  .nav-groups{grid-template-columns:1fr;}
  .account-menu .nav-links a{width:auto;}
}
@media(max-width:680px){
  .topbar{padding:10px;}
  .topbar-main{align-items:flex-start;flex-direction:column;margin-bottom:8px;}
  .user-chip{white-space:normal;}
  .nav-group{border-radius:14px;padding:9px;}
  .nav-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .nav-links a{width:100%;font-size:14px;padding:9px 8px;}
  .account-menu .nav-links{grid-template-columns:1fr;}
}


/* v0.1.8c navigation UX rebuild: world-class web designer review */
.topbar{background:#ffffff;border-bottom:1px solid #d0d5dd;padding:14px 16px 16px;box-shadow:0 8px 22px rgba(16,24,40,.06)}
.topbar-main{max-width:1200px;margin:0 auto 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.brand a{font-size:1.08rem;font-weight:900;color:#101828}.brand span{display:inline-flex;align-items:center;margin-left:8px;padding:2px 8px;border-radius:999px;background:#f2f4f7;color:#475467;font-size:12px;font-weight:800}.user-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid #c7d7fe;background:#eef4ff;color:#1d2939;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:900}.role-badge{background:#1f6feb;color:#fff;border:0;padding:3px 9px}.nav-groups{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:minmax(420px,1.65fr) minmax(360px,1.25fr) minmax(160px,.55fr);gap:14px;align-items:stretch}.nav-group{position:relative;border:1px solid #d0d5dd;border-radius:20px;padding:14px;background:#f9fafb;box-shadow:0 8px 22px rgba(16,24,40,.06)}.nav-group-title{display:flex;align-items:center;gap:8px;width:100%;margin:0 0 10px;padding:0;border:0;background:transparent;color:#101828;font-size:14px;font-weight:950}.nav-group-title::before{content:"";width:10px;height:10px;border-radius:999px;background:#1f6feb;box-shadow:0 0 0 4px #dbeafe}.admin-menu .nav-group-title::before{background:#b45309;box-shadow:0 0 0 4px #ffedd5}.account-menu .nav-group-title::before{background:#64748b;box-shadow:0 0 0 4px #e2e8f0}.stock-menu{border-left:0;background:linear-gradient(180deg,#ffffff,#f8fbff)}.admin-menu{border-left:0;background:linear-gradient(180deg,#ffffff,#fff8ed)}.account-menu{border-left:0;background:linear-gradient(180deg,#ffffff,#f8fafc)}.menu-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.admin-buttons{grid-template-columns:repeat(2,minmax(0,1fr))}.account-buttons{grid-template-columns:1fr}.nav-links a.menu-button{position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;min-height:58px;width:100%;padding:10px 12px;border:1px solid #c7d7fe;border-radius:16px;background:#fff;color:#1f3b7a!important;text-decoration:none;box-shadow:0 3px 0 rgba(31,111,235,.12);transition:transform .14s ease,box-shadow .14s ease,background .14s ease,border-color .14s ease}.nav-links a.menu-button::after{content:"›";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:20px;font-weight:900;color:#98a2b3;transition:transform .14s ease,color .14s ease}.nav-links a.menu-button:hover,.nav-links a.menu-button:focus{transform:translateY(-2px);box-shadow:0 10px 18px rgba(31,111,235,.16);background:#eff6ff;border-color:#60a5fa;outline:3px solid #dbeafe}.nav-links a.menu-button:hover::after,.nav-links a.menu-button:focus::after{transform:translate(3px,-50%);color:#1f6feb}.menu-main{display:block;font-size:14px;font-weight:950;line-height:1.2;letter-spacing:.01em}.menu-sub{display:block;font-size:11px;font-weight:800;color:#667085;line-height:1.2;margin-top:2px}.admin-menu .nav-links a.menu-button{border-color:#fed7aa;color:#7c2d12!important;box-shadow:0 3px 0 rgba(180,83,9,.12)}.admin-menu .nav-links a.menu-button:hover,.admin-menu .nav-links a.menu-button:focus{background:#fff7ed;border-color:#fdba74;box-shadow:0 10px 18px rgba(180,83,9,.16);outline-color:#ffedd5}.logout-link{border-color:#fecaca!important;background:#fff7f7!important;color:#7f1d1d!important;box-shadow:0 3px 0 rgba(153,27,27,.12)!important}.logout-link:hover,.logout-link:focus{background:#fee2e2!important;outline-color:#fecaca!important}.logout-link .menu-sub{color:#991b1b}.nav-links a.menu-button:active{transform:translateY(0);box-shadow:0 2px 0 rgba(16,24,40,.12)}
@media(max-width:1050px){.nav-groups{grid-template-columns:1fr}.menu-buttons,.admin-buttons{grid-template-columns:repeat(3,minmax(0,1fr))}.account-buttons{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){.topbar{padding:12px 10px}.topbar-main{align-items:flex-start;flex-direction:column}.user-chip{border-radius:14px;flex-wrap:wrap}.nav-group{border-radius:18px;padding:12px}.menu-buttons,.admin-buttons,.account-buttons{grid-template-columns:1fr 1fr}.nav-links a.menu-button{min-height:62px;padding:10px}.menu-main{font-size:14px}.menu-sub{font-size:11px}.account-buttons{grid-template-columns:1fr}}
@media(max-width:420px){.menu-buttons,.admin-buttons{grid-template-columns:1fr}}

/* v0.1.8d: collapsible header, content-first layout, clearer click targets */
.topbar{padding:10px 16px;}
.topbar-main{margin-bottom:0;}
.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.menu-toggle{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #c7d7fe;background:#1f6feb;color:#fff;border-radius:999px;padding:8px 14px;font-weight:950;cursor:pointer;box-shadow:0 6px 16px rgba(31,111,235,.18);transition:transform .14s ease,box-shadow .14s ease,background .14s ease;}
.menu-toggle::before{content:"☰";font-size:15px;line-height:1;}
.menu-toggle:hover,.menu-toggle:focus{background:#1559c7;transform:translateY(-1px);box-shadow:0 10px 22px rgba(31,111,235,.24);outline:3px solid #dbeafe;}
.nav-groups[hidden]{display:none!important;}
.nav-groups{margin-top:12px;}
.container{padding-top:14px;}
body:not(.nav-is-open) .container{padding-top:14px;}
a,.btn,button,.menu-button,input[type="submit"]{transition:background .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease;}
a.btn:hover,a.btn:focus,.btn:hover,.btn:focus,button:hover,button:focus{box-shadow:0 8px 18px rgba(16,24,40,.16);transform:translateY(-1px);}
.card a:not(.btn):hover,.card a:not(.btn):focus,.table-wrap a:hover,.table-wrap a:focus{text-decoration-thickness:3px;text-underline-offset:3px;outline:2px solid #dbeafe;border-radius:6px;}
@media(max-width:680px){.topbar-main{gap:8px}.topbar-actions{width:100%;justify-content:space-between}.menu-toggle{flex:1}.user-chip{flex:1;justify-content:center}.nav-groups{margin-top:10px}}


/* v0.1.8e: cache-safe operation, hover menu for PC, tap menu for smartphone, emergency logout */
.quick-logout{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid #fecaca;
  background:#fff7f7;
  color:#7f1d1d!important;
  font-weight:950;
  text-decoration:none;
  box-shadow:0 4px 12px rgba(153,27,27,.08);
}
.quick-logout:hover,.quick-logout:focus{
  background:#fee2e2;
  outline:3px solid #fecaca;
  transform:translateY(-1px);
}
@media (hover:hover) and (pointer:fine){
  .topbar:hover .menu-toggle{background:#1559c7;}
  .topbar:hover .nav-groups:not([hidden]){animation:menuFadeIn .14s ease-out;}
}
@keyframes menuFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:680px){
  .quick-logout{flex:1;min-height:40px;}
  .topbar-actions{gap:8px;}
}
.danger-zone{border:2px solid #fecaca;background:#fff7f7;}
.reset-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:10px 0;}
.reset-options label{border:1px solid #fecaca;background:#fff;border-radius:12px;padding:8px 10px;}
@media(max-width:680px){.reset-options{grid-template-columns:1fr;}}


/* v0.1.9c: smartphone menu must not block page operation */
.menu-close-inside{
  display:none;
}
.nav-groups{
  max-height:calc(100vh - 96px);
  overflow:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.nav-is-open .topbar{
  box-shadow:0 10px 28px rgba(16,24,40,.12);
}
@media (hover:hover) and (pointer:fine){
  .menu-close-inside{display:none!important;}
}
@media (hover:none), (pointer:coarse), (max-width:680px){
  .topbar{
    position:sticky;
    top:0;
    z-index:50;
  }
  .nav-groups{
    max-height:min(68vh, 560px);
    overflow-y:auto;
    overflow-x:hidden;
    padding-bottom:10px;
    border-top:1px solid #e5e7eb;
  }
  .menu-close-inside{
    display:flex;
    width:100%;
    min-height:42px;
    align-items:center;
    justify-content:center;
    margin:0 0 10px;
    border:1px solid #fecaca;
    border-radius:14px;
    background:#fff7f7;
    color:#7f1d1d;
    font-weight:950;
    cursor:pointer;
  }
  .menu-close-inside:hover,
  .menu-close-inside:focus{
    background:#fee2e2;
    outline:3px solid #fecaca;
  }
  body.nav-is-open .container{
    padding-top:14px;
  }
  body.nav-is-open{
    overflow:auto;
  }
}


/* v0.1.9e: flexible compact menu layout */
.nav-section-title{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.nav-section-hint{
  font-size:12px;
  font-weight:700;
  color:#64748b;
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  border-radius:999px;
  padding:2px 8px;
}
.menu-buttons{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
  gap:10px;
  align-items:stretch;
}
.menu-button{
  min-width:0;
}
.menu-main,
.menu-sub{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.admin-compact-buttons{
  grid-template-columns:repeat(auto-fit, minmax(118px, 1fr));
  gap:8px;
}
.admin-compact-buttons .menu-button{
  padding:10px 11px;
  border-radius:13px;
}
.admin-compact-buttons .menu-main{
  font-size:14px;
}
.admin-compact-buttons .menu-sub{
  font-size:11px;
  line-height:1.25;
}
@media (min-width: 1100px){
  .menu-buttons{
    grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  }
  .admin-compact-buttons{
    grid-template-columns:repeat(auto-fit, minmax(122px, 1fr));
  }
}
@media (min-width: 1360px){
  .admin-compact-buttons{
    grid-template-columns:repeat(auto-fit, minmax(132px, 1fr));
  }
}
@media (max-width: 680px){
  .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
  }
  .menu-button{
    padding:10px 9px;
  }
  .menu-main{
    font-size:13px;
  }
  .menu-sub{
    font-size:10.5px;
  }
}
@media (max-width: 380px){
  .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:1fr;
  }
}


/* v0.1.9g: content overflow and compact vertical menu */
.break-anywhere,
.result-cell,
.secret-mask{
  overflow-wrap:anywhere;
  word-break:break-word;
  white-space:normal!important;
}
.status-table th{
  width:150px;
}
.status-table td{
  max-width:0;
}
.data-source-table{
  table-layout:fixed;
}
.data-source-table th,
.data-source-table td{
  white-space:normal;
  vertical-align:top;
}
.responsive-table table{
  min-width:720px;
}
.data-source-note{
  border-left:5px solid var(--primary);
}
.mini-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:8px;
}
.mini-grid p{
  margin:0;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f8fafc;
}
/* menu height reduction planned from v0.1.9e feedback */
.nav-groups{
  padding-top:10px;
  padding-bottom:10px;
}
.nav-group{
  padding:14px!important;
}
.menu-buttons{
  gap:8px!important;
}
.menu-button{
  min-height:58px!important;
  padding:10px 12px!important;
}
.menu-sub{
  line-height:1.25;
}
@media (min-width: 900px){
  .nav-groups{
    grid-template-columns:minmax(0,1.15fr) minmax(0,.95fr);
    align-items:start;
  }
  .admin-compact-buttons{
    grid-template-columns:repeat(auto-fit,minmax(118px,1fr));
  }
}
@media (min-width: 1280px){
  .nav-group{
    padding:12px 14px!important;
  }
  .menu-button{
    min-height:54px!important;
  }
}
@media (max-width:680px){
  .status-table th{
    width:110px;
  }
  .data-source-table{
    font-size:13px;
  }
  .responsive-table table{
    min-width:640px;
  }
}


/* v0.2.0: launch/backup pages */
code{
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  border-radius:8px;
  padding:2px 6px;
  color:#334155;
}
.card.notice{
  border-left:5px solid var(--primary);
}


/* v0.2.1 glossary and restore UI */
.glossary-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:12px;
}
.glossary-item{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:14px;
}
.glossary-item h3{
  margin:0 0 8px;
  color:#0f172a;
}
.glossary-item p{
  margin:0;
  color:#475569;
}


/* v0.2.1a: stock menu 4-column layout like admin menu */
@media (min-width: 900px){
  .stock-menu .menu-buttons{
    grid-template-columns:repeat(4, minmax(130px, 1fr));
  }
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(4, minmax(118px, 1fr));
  }
}
@media (min-width: 1280px){
  .stock-menu .menu-buttons{
    grid-template-columns:repeat(4, minmax(150px, 1fr));
  }
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(4, minmax(130px, 1fr));
  }
}
@media (max-width: 899px){
  .stock-menu .menu-buttons,
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 380px){
  .stock-menu .menu-buttons,
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:1fr;
  }
}


/* v0.2.1b: fix menu clipping caused by fixed 4-column button width */
.nav-groups{
  width:100%;
  max-width:100%;
  overflow:visible;
}
.nav-group{
  min-width:0;
  overflow:visible;
}
.stock-menu{
  min-width:0;
}
.admin-menu{
  min-width:0;
}
.menu-buttons{
  min-width:0;
}
.menu-button{
  min-width:0;
  max-width:100%;
}

/* Wide PC: split the available area without clipping either group */
@media (min-width: 900px){
  .nav-groups{
    display:grid!important;
    grid-template-columns:minmax(420px, 0.95fr) minmax(560px, 1.05fr);
    gap:16px;
    align-items:start;
  }
  .stock-menu .menu-buttons{
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }
}

/* Medium screens: stack groups so site operation is never cut off */
@media (max-width: 1190px){
  .nav-groups{
    grid-template-columns:1fr!important;
  }
  .stock-menu .menu-buttons,
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }
}

/* Smaller tablet/phone */
@media (max-width: 760px){
  .stock-menu .menu-buttons,
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 380px){
  .stock-menu .menu-buttons,
  .admin-menu .menu-buttons,
  .admin-compact-buttons{
    grid-template-columns:1fr;
  }
}


/* v0.2.2 family beta package */
.status-table td{
  white-space:normal;
}


/* v0.2.3 task assist wizard */
.wizard-steps{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 16px;
}
.wizard-step{
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  background:#f8fafc;
  color:#475569;
  font-weight:800;
  font-size:13px;
}
.wizard-step.active{
  background:#eef4ff;
  color:#1f3b7a;
  border-color:#bfdbfe;
}
.wizard-step.done{
  background:#dcfce7;
  color:#166534;
  border-color:#bbf7d0;
}
@media (max-width:680px){
  .wizard-step{
    width:100%;
    border-radius:12px;
  }
}


/* v0.2.3a: smartphone menu scroll fix */
@media (hover:none), (pointer:coarse), (max-width:760px){
  /* メニューを開いた時はヘッダーを固定しない。ページ全体を通常スクロールできるようにする。 */
  body.nav-is-open .topbar{
    position:relative!important;
    top:auto!important;
    z-index:20;
  }
  body.nav-is-open{
    overflow-y:auto!important;
    height:auto!important;
    touch-action:auto!important;
  }
  body.nav-is-open .nav-groups{
    max-height:none!important;
    overflow:visible!important;
    overscroll-behavior:auto!important;
    -webkit-overflow-scrolling:auto!important;
  }
  body.nav-is-open .container,
  body.nav-is-open .footer{
    pointer-events:auto;
  }
  .nav-groups{
    overscroll-behavior:auto!important;
  }
  .menu-close-inside{
    position:sticky;
    top:0;
    z-index:2;
  }
}

/* PCの誤開閉を減らす。ボタン/メニュー上だけで開閉するJSに合わせる。 */
@media (hover:hover) and (pointer:fine){
  .topbar{
    cursor:default;
  }
  .menu-toggle{
    cursor:pointer;
  }
}


/* v0.2.3b finishing */
.pagination{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:10px;
}
.pagination .btn{
  padding:6px 10px;
  min-width:38px;
  text-align:center;
}
details{
  border:1px solid var(--line);
  border-radius:12px;
  padding:8px 10px;
  background:#fff;
}
details summary{
  cursor:pointer;
  font-weight:900;
  color:#1f3b7a;
}
.danger-zone h3{
  margin-top:0;
}


/* v0.2.3c */
.release-note-body{
  white-space:pre-wrap;
  color:#334155;
  margin-top:8px;
}
.inpage-pagination button{
  margin-right:6px;
  margin-top:8px;
}
#price-history:target{
  scroll-margin-top:110px;
}


/* v0.2.3d */
.release-note-viewer{
  margin-top:14px;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  background:#f8fafc;
}
.release-note-viewer textarea{
  width:100%;
  min-height:260px;
  white-space:pre-wrap;
}
.inline-form{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:wrap;
}


/* v0.2.3e site settings */
.theme-choice-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;
  margin:12px 0;
}
.theme-choice{
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px;
  display:flex;
  gap:8px;
  align-items:center;
  cursor:pointer;
}
.theme-choice input{
  width:auto;
}
.theme-swatch{
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  display:inline-block;
}


/* v0.2.3j analysis board scroll target */
#analysis-board{
  scroll-margin-top:110px;
}
.highlight-flash{
  outline:3px solid var(--primary);
  box-shadow:0 0 0 8px rgba(31,111,235,.12);
  transition:box-shadow .2s ease, outline .2s ease;
}


/* v0.2.3l stock analysis board */
.analysis-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:14px;
}
.analysis-card{
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  background:#fff;
}
.analysis-card h3{
  margin-top:0;
}
.analysis-value{
  font-size:20px;
  font-weight:900;
  color:var(--primary);
  margin:.2rem 0 .6rem;
}
.analysis-card ul{
  padding-left:1.2rem;
}
.standard-card{
  background:linear-gradient(135deg,#fff,#f8fafc);
}
#analysis-board{
  scroll-margin-top:120px;
}


/* v0.2.5 analysis memo/task linkage */
.analysis-card .btn{
  margin-top:4px;
}
.analysis-card p:last-child{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}


/* v0.2.5a: general-user menu layout */
.nav-groups-user{
  grid-template-columns:minmax(320px,880px);
  justify-content:center;
}
.nav-groups-user .stock-menu{
  width:100%;
}
.nav-groups-user .menu-buttons{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
@media (max-width:900px){
  .nav-groups-user{grid-template-columns:1fr;}
  .nav-groups-user .menu-buttons{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:560px){
  .nav-groups-user .menu-buttons{grid-template-columns:1fr;}
}
.break-anywhere{overflow-wrap:anywhere;word-break:break-word;white-space:normal;}


/* v0.2.6f financial card wrapping */
.finance-doc-type{
  display:inline-block;
  max-width:100%;
  overflow-wrap:anywhere;
  word-break:break-word;
  line-height:1.5;
  vertical-align:top;
}
.finance-raw-detail{
  overflow:hidden;
}
.finance-raw-detail summary{
  cursor:pointer;
  font-weight:700;
}
.compact-table th,
.compact-table td{
  padding:8px 10px;
  vertical-align:top;
}
.compact-table{
  table-layout:fixed;
  width:100%;
}
.compact-table th:first-child,
.compact-table td:first-child{
  width:38%;
}
.break-anywhere{
  overflow-wrap:anywhere;
  word-break:break-word;
}


/* v0.2.6g finance overview and user-friendly display */
.finance-raw-detail{
  border-top:1px dashed var(--border);
  padding-top:10px;
}
.finance-doc-type{
  max-width:100%;
}


/* v0.2.7 financial history */
.finance-trend-mini{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  margin:10px 0;
}
.finance-trend-mini p{
  margin:4px 0;
}
.finance-history-table{
  table-layout:auto;
}
.finance-history-table th,
.finance-history-table td{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.finance-history-table th:nth-child(3),
.finance-history-table td:nth-child(3){
  min-width:180px;
}


/* v0.2.8 analysis help and beginner guide */
.analysis-help{
  position:relative;
  vertical-align:middle;
}
.analysis-help:focus::after,
.analysis-help:hover::after{
  content:attr(title);
  position:absolute;
  z-index:30;
  left:0;
  top:26px;
  width:min(360px, 82vw);
  background:#111827;
  color:#fff;
  border-radius:12px;
  padding:12px 14px;
  font-size:13px;
  line-height:1.7;
  font-weight:600;
  box-shadow:0 12px 30px rgba(15,23,42,.24);
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.analysis-guide{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px 16px;
  margin:12px 0 16px;
}
.analysis-guide h3{
  margin:0 0 8px;
}
.analysis-guide ol{
  margin:8px 0 0 20px;
  padding:0;
}
.analysis-guide li{
  margin:4px 0;
}
.analysis-card h3,
.card h2{
  overflow-wrap:anywhere;
}
@media(max-width:560px){
  .analysis-help:focus::after,
  .analysis-help:hover::after{
    left:auto;
    right:0;
    width:82vw;
  }
}


/* v0.2.9 beginner guide and glossary links */
.term-link{
  display:inline-block;
  margin:2px 4px 2px 0;
  padding:2px 8px;
  border-radius:999px;
  background:var(--soft);
  color:#1f3b7a;
  font-weight:800;
  text-decoration:none;
  overflow-wrap:anywhere;
}
.term-link:hover,.term-link:focus{
  text-decoration:underline;
}
.analysis-vocab-links{
  background:#fff;
  border:1px dashed var(--line);
  border-radius:14px;
  padding:10px 12px;
  margin:10px 0 14px;
  overflow-wrap:anywhere;
}
.guide-flow{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
}
.guide-step{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
}
.guide-step b{
  display:block;
  margin-bottom:4px;
}
.guide-step span{
  color:var(--muted);
}
.glossary-quick{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.glossary-quick button{
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--soft);
  color:#1f3b7a;
  font-weight:800;
  padding:6px 10px;
  cursor:pointer;
}
.glossary-item h3{
  overflow-wrap:anywhere;
}
.compact-table td,
.compact-table th{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
}


/* v0.3.0 practical analysis board */
.analysis-summary-strip{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  margin:10px 0 14px;
  overflow-wrap:anywhere;
}
.analysis-insights{
  display:grid;
  gap:8px;
  margin:12px 0;
}
.insight-item{
  border:1px solid var(--line);
  border-left-width:6px;
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
  overflow-wrap:anywhere;
}
.insight-item.ok{border-left-color:var(--ok);background:#f0fdf4;}
.insight-item.warn{border-left-color:var(--warn);background:#fffbeb;}
.insight-item.danger{border-left-color:var(--danger);background:#fff7f7;}
.insight-item.info{border-left-color:var(--primary);background:#f8fafc;}
.insight-label{
  display:inline-block;
  font-size:12px;
  font-weight:900;
  color:var(--muted);
  margin-bottom:4px;
}
.insight-item b{
  display:block;
  margin-bottom:4px;
}
.insight-item p{
  margin:0;
}
@media(max-width:560px){
  .analysis-insights{
    grid-template-columns:1fr;
  }
}


/* v0.3.0a financial history layout fixes */
.table-wrap{
  -webkit-overflow-scrolling:touch;
}
.finance-history-table{
  table-layout:fixed;
  min-width:860px;
}
.finance-history-table th,
.finance-history-table td{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
  vertical-align:top;
}
.finance-history-table .fin-date-col{
  width:112px;
  white-space:nowrap;
}
.finance-history-table .fin-period-col{
  width:64px;
  text-align:center;
}
.finance-history-table .fin-doc-col{
  width:260px;
}
.finance-history-table th:nth-child(n+4),
.finance-history-table td:nth-child(n+4){
  width:96px;
  text-align:right;
}
@media(max-width:760px){
  .finance-history-table{
    min-width:920px;
  }
  .finance-history-table th,
  .finance-history-table td{
    font-size:13px;
  }
}


/* v0.3.1 mobile form and earnings calendar */
.card form,
.card .form-row,
.card label{
  max-width:100%;
}
.card input[type="date"],
.card input[type="datetime-local"],
.card input[type="time"],
.card input[type="month"],
.card input[type="number"],
.card input[type="text"],
.card select,
.card textarea{
  max-width:100%;
  min-width:0;
}
@media(max-width:560px){
  .form-row{
    grid-template-columns:1fr;
  }
  input[type="date"],
  input[type="datetime-local"],
  input[type="time"],
  input[type="month"]{
    width:100%;
    min-width:0;
    display:block;
  }
}
.earnings-match-table,
.earnings-calendar-table{
  min-width:840px;
  table-layout:fixed;
}
.earnings-match-table th,
.earnings-match-table td,
.earnings-calendar-table th,
.earnings-calendar-table td{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
  vertical-align:top;
}


/* v0.3.1a clearer earnings API and stronger mobile form fix */
.compact-action-form{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.admin-diagnostic-detail summary{
  cursor:pointer;
  padding:8px 0;
}
.admin-diagnostic-detail[open] summary{
  margin-bottom:8px;
}
input[type="date"],
input[type="datetime-local"],
input[type="time"],
input[type="month"]{
  -webkit-appearance:none;
  appearance:none;
  inline-size:100%;
  width:100%;
  max-inline-size:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
input[type="date"]::-webkit-date-and-time-value,
input[type="datetime-local"]::-webkit-date-and-time-value,
input[type="time"]::-webkit-date-and-time-value,
input[type="month"]::-webkit-date-and-time-value{
  text-align:left;
  min-width:0;
}
.card input,
.card select,
.card textarea,
.card button{
  max-width:100%;
  box-sizing:border-box;
}
@media(max-width:560px){
  .compact-action-form .btn{
    width:100%;
    text-align:center;
  }
  .card input[type="date"],
  .card input[type="datetime-local"],
  .card input[type="time"],
  .card input[type="month"]{
    font-size:16px;
    padding-left:10px;
    padding-right:10px;
  }
}


/* v0.3.1b data source simplification and earnings table readability */
.card .action-row,
.card p:has(.btn){
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.card p:has(.btn) .btn{
  margin:0;
}
.earnings-match-table{
  min-width:720px;
  table-layout:fixed;
}
.earnings-match-table th:nth-child(1),
.earnings-match-table td:nth-child(1){width:170px;}
.earnings-match-table th:nth-child(2),
.earnings-match-table td:nth-child(2){width:120px;}
.earnings-match-table th:nth-child(3),
.earnings-match-table td:nth-child(3),
.earnings-match-table th:nth-child(4),
.earnings-match-table td:nth-child(4){width:130px;white-space:nowrap;}
.earnings-match-table th:nth-child(5),
.earnings-match-table td:nth-child(5){width:90px;text-align:center;}
.earnings-match-table th:nth-child(6),
.earnings-match-table td:nth-child(6){width:130px;}
.earnings-match-table .small-note{
  display:block;
  margin-top:4px;
  line-height:1.5;
}
@media(max-width:560px){
  .card p:has(.btn) .btn,
  .compact-action-form .btn{
    width:100%;
    text-align:center;
  }
  input, select, textarea{
    max-width:100%;
    min-width:0;
  }
  input[type="date"],
  input[type="datetime-local"],
  input[type="time"],
  input[type="month"]{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    flex:1 1 auto;
  }
}


/* v0.3.2 market comparison */
.analysis-card .analysis-value{
  overflow-wrap:anywhere;
}


/* v0.3.3 daily task assist */
.task-assist-summary .metric{
  line-height:1.2;
}
.daily-flow{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.daily-flow-step{
  border:1px solid var(--line);
  background:#f8fafc;
  border-radius:16px;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.daily-flow-step b{
  font-size:1.05rem;
}
.daily-flow-step span{
  color:var(--muted);
}
.assist-stock-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:12px;
}
.assist-stock-card{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:14px;
  overflow-wrap:anywhere;
}
.assist-stock-title{
  display:flex;
  justify-content:space-between;
  gap:8px;
  align-items:flex-start;
}
.assist-stock-title span{
  color:var(--muted);
  font-weight:800;
}
.assist-reasons{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:8px 0;
}
.assist-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:0;
}
.assist-actions .btn{
  margin:0;
}
.assist-memo-form textarea{
  min-height:220px;
}
.wizard-steps{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 16px;
}
.wizard-step{
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  background:#fff;
  color:var(--muted);
  font-weight:800;
}
.wizard-step.active{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}
.wizard-step.done{
  background:#dcfce7;
  color:var(--ok);
  border-color:#bbf7d0;
}
@media(max-width:560px){
  .daily-flow-step .btn,
  .assist-actions .btn,
  .assist-memo-form .btn,
  .compact-action-form .btn{
    width:100%;
    text-align:center;
  }
  .assist-stock-title{
    flex-direction:column;
  }
}


/* v0.3.4 daily task assist completion */
.task-assist-summary .metric{
  line-height:1.2;
}
.daily-check-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:12px;
}
.daily-check-card{
  border:1px solid var(--line);
  background:#fff;
  border-radius:16px;
  padding:14px;
  overflow-wrap:anywhere;
}
.daily-check-card.done{
  background:#f0fdf4;
  border-color:#bbf7d0;
}
.daily-check-head{
  display:flex;
  justify-content:space-between;
  gap:8px;
  align-items:flex-start;
}
.daily-check-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.daily-check-actions .btn{
  margin:0;
}
.assist-stock-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:12px;
}
.assist-stock-card{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:14px;
  overflow-wrap:anywhere;
}
.assist-stock-title{
  display:flex;
  justify-content:space-between;
  gap:8px;
  align-items:flex-start;
}
.assist-stock-title span{
  color:var(--muted);
  font-weight:800;
}
.assist-reasons{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:8px 0;
}
.assist-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:0;
}
.assist-actions .btn{
  margin:0;
}
.assist-memo-form textarea{
  min-height:220px;
}
.wizard-steps{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 16px;
}
.wizard-step{
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  background:#fff;
  color:var(--muted);
  font-weight:800;
}
.wizard-step.active{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}
.wizard-step.done{
  background:#dcfce7;
  color:var(--ok);
  border-color:#bbf7d0;
}
@media(max-width:560px){
  .daily-check-actions .btn,
  .assist-actions .btn,
  .assist-memo-form .btn,
  .compact-action-form .btn{
    width:100%;
    text-align:center;
  }
  .daily-check-head,
  .assist-stock-title{
    flex-direction:column;
  }
}


/* v0.3.4a navigation, API safety, earnings layout */
.page-back-tools{
  max-width:1080px;
  margin:12px auto 0;
  padding:0 14px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.page-back-tools .btn{
  padding:7px 10px;
  font-size:13px;
}
.check-line{
  display:flex;
  align-items:flex-start;
  gap:8px;
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  margin:10px 0;
}
.check-line input[type="checkbox"]{
  width:auto;
  margin-top:5px;
}
.earnings-calendar-table{
  min-width:760px;
  table-layout:fixed;
}
.earnings-calendar-table th,
.earnings-calendar-table td{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
  vertical-align:top;
}
.earnings-calendar-table .ec-date-col{width:112px;white-space:nowrap;}
.earnings-calendar-table .ec-code-col{width:86px;white-space:nowrap;}
.earnings-calendar-table .ec-name-col{width:190px;}
.earnings-calendar-table .ec-quarter-col{width:90px;text-align:center;}
.earnings-calendar-table .ec-year-col{width:96px;}
.earnings-calendar-table .ec-market-col{width:120px;}
.earnings-calendar-table .ec-sector-col{width:120px;}
@media(max-width:560px){
  .page-back-tools .btn{
    width:100%;
    text-align:center;
  }
}


/* v0.3.5 theme color applies to sticky header and menu */
.topbar{
  background:linear-gradient(180deg,var(--theme-header,#ffffff),#ffffff)!important;
  border-bottom-color:var(--theme-line,var(--line))!important;
}
.topbar-main .brand span,
.role-badge{
  background:var(--primary)!important;
  color:#fff!important;
}
.user-chip{
  border-color:var(--theme-line,#c7d7fe)!important;
  background:var(--soft)!important;
}
.nav-group-title::before{
  background:var(--primary)!important;
  box-shadow:0 0 0 4px var(--soft)!important;
}
.stock-menu{
  background:linear-gradient(180deg,#ffffff,var(--theme-header,#f8fbff))!important;
}
.admin-menu{
  background:linear-gradient(180deg,#ffffff,var(--theme-header2,#fff8ed))!important;
}
.nav-links a.menu-button{
  border-color:var(--theme-line,#c7d7fe)!important;
  color:var(--theme-text,#1f3b7a)!important;
}
.nav-links a.menu-button:hover,
.nav-links a.menu-button:focus{
  background:var(--soft)!important;
  border-color:var(--primary)!important;
}
.menu-toggle,
.quick-logout{
  border-color:var(--theme-line,#c7d7fe)!important;
}


/* v0.3.5a menu consolidation, dark sticky header, readable study tables */
.topbar{
  background:var(--primary)!important;
  background-image:linear-gradient(180deg,var(--primary),var(--theme-header2,var(--primary)))!important;
  border-bottom-color:rgba(255,255,255,.25)!important;
  color:#fff!important;
}
.topbar .brand a,
.topbar .brand span{
  color:#fff!important;
}
.topbar .brand span{
  background:rgba(255,255,255,.18)!important;
  border:1px solid rgba(255,255,255,.25)!important;
}
.topbar .user-chip{
  background:rgba(255,255,255,.14)!important;
  border-color:rgba(255,255,255,.35)!important;
  color:#fff!important;
}
.topbar .role-badge{
  background:#fff!important;
  color:var(--primary)!important;
}
.topbar .menu-toggle,
.topbar .quick-logout,
.topbar .menu-close-inside{
  background:#fff!important;
  color:var(--primary)!important;
  border-color:rgba(255,255,255,.75)!important;
}
.nav-groups{
  color:var(--text);
}
.analysis-card-guide-table{
  min-width:820px;
  table-layout:fixed;
}
.analysis-card-guide-table th,
.analysis-card-guide-table td{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:normal;
  vertical-align:top;
}
.analysis-card-guide-table th:nth-child(1),
.analysis-card-guide-table td:nth-child(1){
  width:150px;
  white-space:nowrap;
}
.analysis-card-guide-table th:nth-child(2),
.analysis-card-guide-table td:nth-child(2){
  width:450px;
}
.analysis-card-guide-table th:nth-child(3),
.analysis-card-guide-table td:nth-child(3){
  width:220px;
}
.help-audit-table{
  min-width:980px;
  table-layout:fixed;
}
.help-audit-table th,
.help-audit-table td{
  white-space:normal;
  overflow-wrap:anywhere;
  vertical-align:top;
}
.help-audit-table th:nth-child(1),
.help-audit-table td:nth-child(1){width:150px;}
.help-audit-table th:nth-child(2),
.help-audit-table td:nth-child(2),
.help-audit-table th:nth-child(3),
.help-audit-table td:nth-child(3){width:110px;text-align:center;}
.help-audit-table th:nth-child(4),
.help-audit-table td:nth-child(4){width:230px;}
.help-audit-table th:nth-child(5),
.help-audit-table td:nth-child(5){width:380px;}
@media(max-width:680px){
  #analysis-card-guide .table-wrap::before{
    content:"横にスクロールして確認できます";
    display:block;
    color:var(--muted);
    font-size:13px;
    margin-bottom:6px;
  }
}


/* v0.3.6 stock detail / analysis board finishing */
.stock-detail-hero .stock-detail-actions,
.stock-detail-actions,
.analysis-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.stock-detail-hero .stock-detail-actions .btn,
.stock-detail-actions .btn,
.analysis-actions .btn{
  margin:0;
}
.analysis-next-action{
  border:1px solid var(--line);
  border-left:7px solid var(--primary);
  border-radius:16px;
  padding:12px 14px;
  background:#fff;
  margin:12px 0;
  overflow-wrap:anywhere;
}
.analysis-next-action.ok{border-left-color:var(--ok);background:#f0fdf4;}
.analysis-next-action.warn{border-left-color:var(--warn);background:#fffbeb;}
.analysis-next-action.info{border-left-color:var(--primary);background:#f8fafc;}
.analysis-next-action span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  margin-bottom:4px;
}
.analysis-next-action b{
  display:block;
  font-size:1.1rem;
}
.analysis-next-action p{
  margin:4px 0 0;
}
.analysis-card-nav{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:12px 0;
}
.analysis-card-nav a{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:6px 10px;
  border:1px solid var(--theme-line,var(--line));
  border-radius:999px;
  background:var(--soft);
  color:var(--theme-text,var(--primary));
  font-weight:900;
  text-decoration:none;
}
.analysis-card-nav a:hover,
.analysis-card-nav a:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--soft);
}
.criteria-source{
  border:1px solid var(--line);
  background:#f8fafc;
  border-radius:14px;
  padding:10px 12px;
  margin:10px 0;
  display:grid;
  gap:6px;
}
.criteria-source p{
  margin:0;
}
.analysis-card{
  scroll-margin-top:120px;
}
#financial-history{
  scroll-margin-top:120px;
}
@media(max-width:560px){
  .stock-detail-hero .stock-detail-actions .btn,
  .stock-detail-actions .btn,
  .analysis-actions .btn{
    width:100%;
    text-align:center;
  }
  .analysis-card-nav{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .analysis-card-nav a{
    justify-content:center;
  }
}


/* v0.3.6a: ? help must open by click/tap modal, not hover tooltip */
.help,
.analysis-help{
  cursor:pointer;
}
.help::before,
.help::after,
.analysis-help::before,
.analysis-help::after{
  content:none!important;
  display:none!important;
}
.help:hover::before,
.help:hover::after,
.help:focus::before,
.help:focus::after,
.analysis-help:hover::before,
.analysis-help:hover::after,
.analysis-help:focus::before,
.analysis-help:focus::after{
  content:none!important;
  display:none!important;
}
.help-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(15,23,42,.48);
}
.help-modal[aria-hidden="false"]{
  display:flex!important;
}
.help-modal-panel{
  width:min(560px, calc(100vw - 32px));
  max-height:min(72vh, 640px);
  overflow:auto;
  background:#fff;
  color:var(--text,#111827);
  border-radius:20px;
  padding:22px 24px;
  box-shadow:0 24px 70px rgba(15,23,42,.25);
  position:relative;
}
.help-modal-close{
  position:absolute;
  right:12px;
  top:12px;
  width:36px;
  height:36px;
  border-radius:999px;
  border:0;
  background:#f3f4f6;
  color:#111827;
  font-size:22px;
  line-height:1;
  cursor:pointer;
}
#help-modal-title{
  margin:0 44px 14px 0;
}
#help-modal-body{
  white-space:pre-wrap;
  line-height:1.8;
  margin:0;
}
body.help-modal-open{
  overflow:hidden;
}


/* v0.3.7 expanded theme color choices */
.theme-section-title{
  margin:18px 0 8px;
  font-weight:950;
  color:var(--text);
}
.theme-choice-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:10px;
}
.theme-choice{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:16px;
  padding:10px;
  background:#fff;
  cursor:pointer;
}
.theme-choice:hover,
.theme-choice:focus-within{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--soft);
}
.theme-choice input{
  width:auto;
}
.theme-choice small{
  display:block;
  color:var(--muted);
  font-weight:700;
  margin-top:2px;
}
.theme-swatch{
  width:34px;
  height:34px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.9);
  box-shadow:0 0 0 1px var(--line),0 4px 12px rgba(16,24,40,.12);
  flex:0 0 auto;
}
.topbar{
  color:var(--theme-header-text,#fff)!important;
}
.topbar .brand a,
.topbar .brand span{
  color:var(--theme-header-text,#fff)!important;
}
.topbar .brand span{
  background:rgba(255,255,255,.18)!important;
}
.topbar .user-chip{
  color:var(--theme-header-text,#fff)!important;
}
.topbar .menu-toggle,
.topbar .quick-logout,
.topbar .menu-close-inside{
  color:var(--primary)!important;
}
@media(max-width:560px){
  .theme-choice-grid{
    grid-template-columns:1fr;
  }
}


/* v0.3.8 menu cleanup and task page integration */
.footer{
  line-height:1.8;
}
.task-list-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-bottom:8px;
}
.task-list-toolbar .btn{
  margin:0;
}
.task-list-table{
  min-width:860px;
  table-layout:fixed;
}
.task-list-table th:nth-child(1), .task-list-table td:nth-child(1){width:180px;}
.task-list-table th:nth-child(2), .task-list-table td:nth-child(2){width:120px;}
.task-list-table th:nth-child(3), .task-list-table td:nth-child(3){width:300px;}
.task-list-table th:nth-child(4), .task-list-table td:nth-child(4){width:90px;}
.task-list-table th:nth-child(5), .task-list-table td:nth-child(5){width:270px;}
.task-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.task-actions .btn,
.task-actions button{
  margin:0;
}
@media(max-width:560px){
  .task-list-toolbar .btn,
  .task-actions .btn,
  .task-actions button{
    width:100%;
    text-align:center;
  }
}


/* v0.3.8b user role consistency */
.user-role-note{
  border:1px solid var(--line);
  background:var(--soft);
  border-radius:14px;
  padding:10px 12px;
}

/* v0.3.11 log viewer */
.log-card-head{display:flex;gap:12px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;}
.log-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:12px 0 16px;}
.log-summary{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px 14px;text-decoration:none;color:var(--text);}
.log-summary span{font-size:1.45rem;font-weight:900;}
.log-summary-error{border-left:6px solid #b91c1c;background:#fff7f7;}
.log-summary-warning{border-left:6px solid #d97706;background:#fffbeb;}
.log-summary-info{border-left:6px solid #15803d;background:#f0fdf4;}
.app-log-table{table-layout:auto;}
.app-log-table th,.app-log-table td{vertical-align:top;white-space:normal;}
.log-row-error{background:#fff7f7;}
.log-row-warning{background:#fffbeb;}
.log-row-info{background:#f8fff9;}
.log-badge{display:inline-block;min-width:54px;text-align:center;border-radius:999px;padding:4px 10px;font-size:.82rem;font-weight:900;white-space:nowrap;}
.log-badge-error{background:#fee2e2;color:#991b1b;}
.log-badge-warning{background:#fef3c7;color:#92400e;}
.log-badge-info{background:#dcfce7;color:#166534;}
.log-context{max-width:520px;max-height:260px;overflow:auto;white-space:pre-wrap;word-break:break-word;background:#111827;color:#f9fafb;border-radius:12px;padding:10px;font-size:.85rem;}
.filter-actions{display:flex;gap:8px;align-items:end;flex-wrap:wrap;padding-top:31px;}
@media(max-width:680px){.filter-actions{padding-top:0}.log-context{max-width:80vw}.app-log-table th:nth-child(5),.app-log-table td:nth-child(5){min-width:150px}}

/* v0.3.12 usability renewal:迷わない導線・読みやすさ・スマホ最適化 */
:root{
  --surface:#ffffff;
  --surface-soft:#f8fafc;
  --info:#075985;
  --info-bg:#e0f2fe;
}
body{font-size:16px;}
.container{max-width:1180px;}
.topbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.quick-home,.quick-logout,.menu-toggle,.view-mode-btn{
  min-height:40px;
  border-radius:999px;
  border:1px solid #d0d5dd;
  padding:8px 12px;
  text-decoration:none;
  font-weight:900;
  cursor:pointer;
  line-height:1.2;
}
.quick-home{background:var(--primary);color:#fff!important;border-color:var(--primary);box-shadow:0 8px 18px rgba(31,111,235,.18);}
.quick-logout{background:#fff7f7;color:#991b1b!important;border-color:#fecaca;}
.view-mode-switch{display:inline-flex;gap:4px;padding:3px;border:1px solid #d0d5dd;border-radius:999px;background:#fff;}
.view-mode-btn{min-height:34px;padding:6px 10px;background:transparent;color:#344054;border:0;font-size:13px;}
.view-mode-btn.is-active{background:var(--soft);color:var(--theme-text);}
.nav-groups{grid-template-columns:minmax(330px,1.2fr) minmax(260px,.9fr) minmax(340px,1.25fr);}
.nav-groups-user{grid-template-columns:minmax(330px,1.3fr) minmax(260px,.8fr);}
.learn-menu{border-left:5px solid #0f766e;background:#f0fdfa;}
.primary-menu-button{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;box-shadow:0 10px 20px rgba(31,111,235,.18);}
.primary-menu-button .menu-sub{color:rgba(255,255,255,.88)!important;}
.page-back-tools{max-width:1180px;margin:10px auto 0;padding:0 14px;display:flex;gap:8px;flex-wrap:wrap;}
.page-back-tools .btn{padding:7px 11px;font-size:14px;}
.card{border-radius:20px;}
.card.hero{border:0;background:linear-gradient(135deg,#ffffff 0%,var(--soft) 100%);box-shadow:0 10px 28px rgba(16,24,40,.06);}
.hero h1{font-size:clamp(1.6rem,3.4vw,2.35rem);line-height:1.25;margin-bottom:.4rem;}
.hero p{font-size:1.03rem;max-width:900px;}
.home-flow,.guide-flow-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0;}
.flow-step,.guide-step-card{position:relative;border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px 14px 14px 50px;min-height:96px;}
.flow-step .step-num,.guide-step-card .step-num{position:absolute;left:14px;top:14px;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:var(--primary);color:#fff;font-weight:900;}
.flow-step b,.guide-step-card b{display:block;font-size:1.04rem;margin-bottom:4px;}
.next-action-card{border:2px solid var(--theme-line);background:linear-gradient(135deg,#fff,var(--soft));}
.next-action-card .btn{font-size:1.05rem;padding:12px 18px;}
.summary-strip{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:10px 0;}
.status-chip{display:inline-flex;gap:6px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 11px;font-weight:900;font-size:13px;}
.status-chip.ok{background:#f0fdf4;color:#166534;border-color:#bbf7d0;}
.status-chip.warn{background:#fffbeb;color:#92400e;border-color:#fed7aa;}
.status-chip.danger{background:#fff7f7;color:#991b1b;border-color:#fecaca;}
.status-chip.info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe;}
.usability-note{border-left:5px solid var(--primary);background:var(--soft);padding:12px 14px;border-radius:14px;}
.beginner-only{display:block;}
body.ui-mode-simple .beginner-only{display:none!important;}
body.ui-mode-simple .card{padding:15px;}
body.ui-mode-simple .small-note, body.ui-mode-simple .form-hint{font-size:.85rem;}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;}
.kpi-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:15px;}
.kpi-label{font-size:.88rem;color:var(--muted);font-weight:900;}
.kpi-value{font-size:1.65rem;font-weight:950;line-height:1.2;margin:6px 0;}
.stock-card-list{display:none;}
.stock-mobile-card{border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px;margin-bottom:10px;}
.stock-mobile-card h3{margin:.1rem 0 .35rem;}
.stock-card-meta{display:flex;gap:6px;flex-wrap:wrap;margin:.4rem 0;}
.action-buttons{display:flex;gap:6px;flex-wrap:wrap;align-items:center;}
.action-buttons .btn{margin:0;}
.analysis-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:10px;}
.analysis-plan-item{border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px;}
.analysis-plan-item.unavailable{background:#f8fafc;color:#667085;}
.analysis-plan-item .plan-axis{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:6px;}
.analysis-plan-item b{font-size:1.03rem;}
.analysis-card h3{display:flex;gap:6px;align-items:center;justify-content:space-between;}
.analysis-card .analysis-value{font-size:1.25rem;line-height:1.35;}
.table-tools{display:flex;gap:8px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin:8px 0 12px;}
.search-input{max-width:360px;}
.empty-state{border:2px dashed #cbd5e1;border-radius:18px;background:#f8fafc;padding:20px;text-align:center;}
td.actions-col,th.actions-col{min-width:220px;}
@media(max-width:900px){
  .nav-groups,.nav-groups-user{grid-template-columns:1fr;}
  .home-flow,.guide-flow-steps{grid-template-columns:1fr;}
}
@media(max-width:680px){
  body{font-size:15.5px;}
  .topbar-main{gap:10px;}
  .topbar-actions{width:100%;justify-content:flex-start;}
  .quick-home,.quick-logout,.menu-toggle{flex:1;text-align:center;}
  .view-mode-switch{width:100%;justify-content:center;}
  .view-mode-btn{flex:1;}
  .page-back-tools{padding:0 10px;}
  .page-back-tools .btn{flex:1;text-align:center;}
  .desktop-table-on-mobile{display:none;}
  .stock-card-list{display:block;}
  .responsive-card-table thead{display:none;}
  .responsive-card-table table,.responsive-card-table tbody,.responsive-card-table tr,.responsive-card-table td{display:block;width:100%;}
  .responsive-card-table tr{border:1px solid var(--line);border-radius:16px;background:#fff;margin:0 0 10px;padding:8px;}
  .responsive-card-table td{border:0;padding:7px 8px;white-space:normal;display:flex;justify-content:space-between;gap:12px;}
  .responsive-card-table td::before{content:attr(data-label);font-weight:900;color:var(--muted);min-width:7em;}
  .responsive-card-table td.actions-col{display:block;}
  .responsive-card-table td.actions-col::before{display:block;margin-bottom:6px;}
  .action-buttons .btn{width:100%;text-align:center;}
  .kpi-value{font-size:1.45rem;}
}
.pill.info{background:#dbeafe;color:#1d4ed8;}
