div.contextmenu {
    padding:3px;
    border:1px solid #999;
    display:none;
    position:absolute;
    top:0;
    left:0;
    background-color:#fafafa;
    box-shadow:2px 2px 3px 0 rgba(0, 0, 0, 0.5);
    z-index:3000;
}
 
*html div.contextmenu {
    width:200px;
}
 
*+html div.contextmenu {
    width:200px;
}
 
    /* メニュータイトル見出し */
    div.contextmenu p.title {
        margin:0 0 3px;
        padding:5px 10px;
        border-bottom:1px solid #aaa;
        background-color:#eee;
    }
 
    div.contextmenu ul.menu-items {
        margin:0;
        padding:0;
    }
 
        div.contextmenu ul.menu-items li.menu-item {
            margin:0;
            padding:2px 0;
            list-style:none;
            position:relative;
        }
 
        /* 境界 */
        div.contextmenu ul.menu-items li.menu-item.divide {
            border-top:1px dashed #aaa;
        }
 
            /* ボタン */
            div.contextmenu ul.menu-items li.menu-item button {
                padding:3px 20px;
                border:1px solid transparent;
                border-radius:2px;
                width:100%;
                background:transparent;
                cursor:pointer;
                text-align:left;
                transition:border 0.2s ease 0s, background-color 0.2s ease 0s;
            }
            /* 選択値 */
            .selectvalue {
                background-color: lightgreen;
            }

            div .contextmenu ul.menu-items li.menu-item button:hover {
                border:1px solid #06d;
                background-color:#e6f1ff;
            }
 
            div.contextmenu ul.menu-items li.menu-item.disabled button,
            div.contextmenu ul.menu-items li.menu-item.disabled button:hover {
                border:1px solid transparent;
                background:transparent;
                cursor:default;
            }
 
            div.contextmenu ul.menu-items li.menu-item.sub-menu-open > button,
            div.contextmenu ul.menu-items li.menu-item.sub-menu-close > button {
                background-repeat:no-repeat;
                background-position:95% 50%;
            }
 
                div.contextmenu ul.menu-items li.menu-item button span.icon {
                    margin:0 5px 0 -16px;
                    vertical-align:middle;
                }
 
        /* サブメニュー */
        div.contextmenu ul.menu-items li.menu-item ul.sub-menu {
            padding:3px;
            border:1px solid #999;
            position:absolute;
            top:0;
            left:100%;
            display:none;
            background-color:#fafafa;
            box-shadow:2px 2px 3px 0 rgba(0, 0, 0, 0.5);
            min-width:150px;
        }

            div.contextmenu ul.menu-items li.menu-item.sub-menu-open ul.sub-menu {
                display: block;
                top: 0;
                left: 100%;
            }
 
/* メニュー表示 */
div.contextmenu.open {
    display:block;
}
