.typeahead-field, .typeahead-query {
    position: relative;
    /*width: 100%;*/
}

.typeahead-button, .typeahead-container, .typeahead-field, .typeahead-filter, .typeahead-query {
    position: relative;
}

/*
    .typeahead-container, .typeahead-field input, .typeahead-select {
        border: 1px solid #ccc;
        line-height: 1.42857143;
        padding: 6px 12px;
        height: 32px;
    }
    */

/*button, input, optgroup, select, textarea {
    color: inherit;
    font: inherit;
    margin: 0;
}
*/

.typeahead-list {
    font-family: "Open Sans",Arial,Helvetica,Sans-Serif;
}

button {
    overflow: visible;
}

button, select {
    text-transform: none;
}

button, html input[type=button], input[type=reset], input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer;
}

    button[disabled], html input[disabled] {
        cursor: default;
    }

    button::-moz-focus-inner, input::-moz-focus-inner {
        border: 0;
        padding: 0;
    }

input {
    line-height: normal;
}

.typeahead-container * {
    box-sizing: border-box;
}

.typeahead-container * {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
}

/*.typeahead-field input {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
}*/

.typeahead-query {
    z-index: 2;
}

.typeahead-filter button {
    min-width: 66px;
}

.typeahead-field {
    display: table;
    border-collapse: separate;
}

.typeahead-button {
    font-size: 0;
    white-space: nowrap;
    width: 1%;
    vertical-align: middle;
}

.typeahead-field > span {
    display: table-cell;
    vertical-align: top;
}

.typeahead-button button {
    border-top-right-radius: 2px;
    border-bottom-right-radius: 2px;
}

/*.typeahead-field input, .typeahead-select {
    display: block;
    width: 100%;
    font-size: 13px;
    color: #555;
    background: 0 0;
    border-radius: 2px 0 0 2px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075);
    box-shadow: inset 0 1px 1px rgba(0,0,0,.075);
    -webkit-transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
}*/

/*.typeahead-field input {
    -webkit-appearance: none;
    box-sizing: border-box;
}*/

.typeahead-container .typeahead-field input {
    background: #fff;
}

.typeahead-container.hint .typeahead-field input {
    background: 0 0;
}

    .typeahead-container.hint .typeahead-field input:last-child, .typeahead-hint {
        background: #fff;
    }

/*
.typeahead-container button {
    display: inline-block;
    margin-bottom: 0;
    font-weight: 400;
    text-align: center;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    background-color: #fff;
    white-space: nowrap;
    font-size: 13px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    color: #333;
    box-shadow: inset 0 -2px 0 rgba(0,0,0,.05);
    -moz-box-shadow: inset 0 -2px 0 rgba(0,0,0,.05);
    -webkit-box-shadow: inset 0 -2px 0 rgba(0,0,0,.05);
}

    .typeahead-container button:active, .typeahead-container button:focus {
        outline: dotted thin;
        outline: -webkit-focus-ring-color auto 5px;
        outline-offset: -2px;
    }

    .typeahead-container button:focus, .typeahead-container button:hover {
        color: #333;
        background-color: #e6e6e6;
        border-color: #adadad;
    }

    .typeahead-container button.active, .typeahead-container button:active {
        outline: 0;
        background-image: none;
        -webkit-box-shadow: inset 0 3px 5px rgba(0,0,0,.125);
        box-shadow: inset 0 3px 5px rgba(0,0,0,.125);
    }

    .typeahead-container button.disabled, .typeahead-container button[disabled], .typeahead-field input.disabled, .typeahead-field input[disabled] {
        cursor: not-allowed;
        pointer-events: none;
        opacity: .65;
        filter: alpha(opacity=65);
        -webkit-box-shadow: none;
        box-shadow: none;
        background-color: #fff;
        border-color: #ccc;
    }
*/

.typeahead-button button, .typeahead-filter button {
    margin-left: -1px;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
}

.typeahead-button, .typeahead-filter {
    z-index: 1;
}

    .typeahead-button:active, .typeahead-button:active button:active, .typeahead-button:focus, .typeahead-button:focus button:focus, .typeahead-button:hover, .typeahead-container.filter .typeahead-filter, .typeahead-filter:active, .typeahead-filter:focus, .typeahead-filter:hover {
        z-index: 1001;
    }

.typeahead-dropdown, .typeahead-list {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    width: 100%;
    min-width: 160px;
    padding: 5px 0;
    margin: 2px 0 0;
    list-style: none;
    font-size: 13px;
    text-align: left;
    background-color: #fff;
    border: 1px solid #ccc;
    border: 1px solid rgba(0,0,0,.15);
    border-radius: 2px;
    -webkit-box-shadow: 0 6px 12px rgba(0,0,0,.175);
    box-shadow: 0 6px 12px rgba(0,0,0,.175);
    background-clip: padding-box;
}

.typeahead-result {
    margin: 0px;
    top: 78px;
    background: #FFF none repeat scroll 0% 0%;
    width: 549px;
    float: right;
    position: absolute;
    right: -1px;
}

    .typeahead-result.detached .typeahead-list {
        position: relative;
        z-index: 1041;
        top: auto;
        left: auto;
    }

.typeahead-dropdown {
    right: 0;
    left: auto;
    z-index: 1001;
}

.typeahead-list > li:first-child {
    border-top: none;
}

.typeahead-list > li {
    position: relative;
    border-top: solid 1px rgba(0,0,0,.15);
}

    .typeahead-dropdown > li > a, .typeahead-list > li > a {
        display: block;
        padding: 6px 20px;
        clear: both;
        font-weight: 400;
        line-height: 1.42857143;
        color: #333;
        white-space: nowrap;
        text-decoration: none;
    }

        .typeahead-dropdown > li.active > a, .typeahead-dropdown > li > a:focus, .typeahead-dropdown > li > a:hover, .typeahead-list > li.active > a, .typeahead-list > li > a:focus, .typeahead-list > li > a:hover {
            background-color: #ebebeb;
            color: #333;
        }

.typeahead-list.empty > li.active > a, .typeahead-list.empty > li > a:focus, .typeahead-list.empty > li > a:hover {
    background-color: transparent;
}

.typeahead-list.empty > li > a {
    cursor: default;
}

.typeahead-list > li.typeahead-group.active > a, .typeahead-list > li.typeahead-group > a, .typeahead-list > li.typeahead-group > a:focus, .typeahead-list > li.typeahead-group > a:hover {
    border-color: #9cb4c5;
    color: #305d8c;
    background-color: #d6dde7;
    cursor: default;
}

.typeahead-container.backdrop + .typeahead-backdrop, .typeahead-container.filter .typeahead-dropdown, .typeahead-container.result .typeahead-list {
    display: block !important;
}

.typeahead-container .typeahead-dropdown, .typeahead-container .typeahead-hint, .typeahead-container .typeahead-list, .typeahead-container + .typeahead-backdrop {
    display: none !important;
}

.typeahead-dropdown .divider {
    height: 1px;
    margin: 5px 0;
    overflow: hidden;
    background-color: #e5e5e5;
}

.typeahead-caret {
    display: inline-block;
    width: 0;
    height: 0;
    margin-left: 2px;
    vertical-align: middle;
    border-top: 4px solid;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
}

.typeahead-search-icon {
    min-width: 40px;
    height: 18px;
    font-size: 13px;
    display: block;
    background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAABH0lEQVR4nJ3SvyvFYRTH8deVkkJ3UUZJIbJ8bzJjMtyMym6w2Njs/gCDP0AGCyWjxYDF5GdJYpS6xaIUw/d8771dT7qc+vZ8vs95zvuc5zmnlGWZsG6sYBGjsXeNHWzjQ8JKARjCEUZSh3CJeTy3OjoicxF8hwX0oi/0HSZwiK4UYKUpeBoHeMdb6OnwTWI5BVgMvYZaovwa1kMvpQBjoY8TwVp84ylAO/YV62cKcBt65hfAbKwPKcBu6E2UE8Hl8MF+CrCFG/nwnKKKnviqONOYj6NWQDFIg/I+/3ikFnuUX6d+lY4mR4ZVnMvnoIYLbKCCp0h0otG5egXt2HAED+BFPmAP7bYR7jGHV/RjCjr/AICryFzB3n8ARSX3xc83qRk4q9rDNWcAAAAASUVORK5CYII=) center center no-repeat;
}
