/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
a { text-decoration: none;}
/*
 * 1. Corrects font family not being inherited in all browsers.
 * 2. Corrects font size not being inherited in all browsers.
 * 3. Addresses margins set differently in Firefox 4+, Safari 5, and Chrome
 */

button,
input,
select,
textarea {
    font-family: inherit; /* 1 */
    font-size: 100%; /* 2 */
    margin: 0; /* 3 */
    padding: 0;
}

/*
 * Addresses Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */

button,
input {
    line-height: normal;
}

/* Hide default number spinner controls */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
display: none;
}

/*
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Corrects inability to style clickable `input` types in iOS.
 * 3. Improves usability and consistency of cursor style between image-type
 *    `input` and others.
 */

button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button; /* 2 */
    cursor: pointer; /* 3 */
}

/*
 * Re-set default cursor for disabled elements.
 */

button[disabled],
input[disabled] {
    cursor: default;
}

/*
 * 1. Addresses box sizing set to `content-box` in IE 8/9.
 * 2. Removes excess padding in IE 8/9.
 */

input[type="checkbox"],
input[type="radio"] {
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
}

/*
 * 1. Addresses `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Addresses `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */

input[type="search"] {
    -webkit-appearance: none; /* 1 */
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; /* 2 */
    box-sizing: border-box;
}

/*
 * Removes inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

/*
 * Removes inner padding and border in Firefox 4+.
 */

button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0;
}

/*
** Markup free clearing
** Details: http://www.positioniseverything.net/easyclearing.html
*/
.cf:before,
.cf:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.cf:after {
    clear: both;
}
/* base styles */
.layer-osm path {
    fill: none;
}

/* IE/Edge needs these overrides for markers to show up */
.layer-osm path.oneway-marker-path          { fill: #000; }
.layer-osm path.sided-marker-natural-path   { fill: rgb(170, 170, 170); }
.layer-osm path.sided-marker-coastline-path { fill: #77dede; }
.layer-osm path.sided-marker-barrier-path   { fill: #ddd; }
.layer-osm path.sided-marker-man_made-path  { fill: #fff; }

/* IE/Edge rule for <use> marker style */
.layer-osm path.viewfield-marker-path {
    fill: #333;
    fill-opacity: 0.75;
    stroke: #fff;
    stroke-width: 0.5px;
    stroke-opacity: 0.75;
}
.fill-wireframe .layer-osm path.viewfield-marker-path {   /* IE/Edge rule for <use> marker style */
    fill: none;
}

/* the above fill: none rule affects paths in <use> shadow dom only in Firefox */
.layer-osm use.icon path { fill: #333; }                       /* FF svg Maki icons */
.layer-osm .turn use path { fill: #000; }                      /* FF turn restriction icons */
#turn-only-shape2, #turn-only-u-shape2 { fill: #7092ff; }      /* FF turn-only, turn-only-u */
#turn-no-shape2, #turn-no-u-shape2     { fill: #e06d5f; }      /* FF turn-no, turn-no-u */
#turn-yes-shape2, #turn-yes-u-shape2   { fill: #8cd05f; }      /* FF turn-yes, turn-yes-u */


/* No interactivity except what we specifically allow */
.data-layer.osm *,
.data-layer.notes *,
.data-layer.keepRight *,
.data-layer.improveOSM * {
    pointer-events: none;
}

.lasso #map {
    pointer-events: visibleStroke;
}


/* `.target` objects are interactive */
/* They can be picked up, clicked, hovered, or things can connect to them */
.qa_error.target,
.note.target,
.node.target,
.turn .target {
    pointer-events: fill;
    fill-opacity: 0.8;
    fill: currentColor;
    stroke: none;
}

.way.target {
    pointer-events: stroke;
    fill: none;
    stroke-width: 12;
    stroke-opacity: 0.8;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
}


/* `.target-nope` objects are explicitly forbidden to join to */
.surface:not(.nope-disabled) .node.target.target-nope,
.surface:not(.nope-disabled) .way.target.target-nope {
    cursor: not-allowed;
}


/* `.active` objects (currently being drawn or dragged) are not interactive */
/* This is important to allow the events to drop through to whatever is */
/* below them on the map, so you can still hover and connect to other things. */
.layer-osm .active {
    pointer-events: none !important;
}

/* points, notes & QA */

/* points, notes, markers */
g.qa_error .stroke,
g.note .stroke {
    stroke: #222;
    stroke-width: 1;
    fill: #222;
    opacity: 0.6;
}

g.qa_error.active .stroke,
g.note.active .stroke {
    stroke: #222;
    stroke-width: 1;
    fill: #222;
    opacity: 0.8;
}

g.point .stroke {
    stroke: #444;
    stroke-width: 1;
    fill: #fff;
}


g.qa_error .shadow,
g.point .shadow,
g.note .shadow {
    fill: none;
    stroke: #f6634f;
    stroke-width: 16;
    stroke-opacity: 0;
}

g.qa_error.hover:not(.selected) .shadow,
g.note.hover:not(.selected) .shadow,
g.point.related:not(.selected) .shadow,
g.point.hover:not(.selected) .shadow {
    stroke-opacity: 0.5;
}

g.qa_error.selected .shadow,
g.note.selected .shadow,
g.point.selected .shadow {
    stroke-opacity: 0.7;
}

/* g.note ellipse.stroke, */
g.point ellipse.stroke {
    display: none;
}
.mode-drag-note g.note.active ellipse.stroke,
.mode-drag-node g.point.active ellipse.stroke {
    display: block;
}


/* vertices and midpoints */
g.vertex .fill {
    fill: #000;
}
g.vertex .stroke {
    stroke: #666;
    stroke-width: 1;
    fill: white;
}
g.vertex.shared .stroke {
    fill: #bbb;
}
g.midpoint .fill {
    fill: #eee;
    stroke: #444;
    stroke-opacity: .6;
    opacity: .7;
}

g.vertex .shadow,
g.midpoint .shadow {
    stroke-width: 6;
    fill: #f6634f;
    fill-opacity: 0;
}

g.vertex.related:not(.selected) .shadow,
g.vertex.hover:not(.selected) .shadow,
g.midpoint.related:not(.selected) .shadow,
g.midpoint.hover:not(.selected) .shadow {
    fill-opacity: 0.5;
}

g.vertex.selected .shadow {
    fill-opacity: 0.7;
}


/* lines */
.preset-icon .icon.iD-other-line {
    color: #989898;
}
.preset-icon-container path.line.casing {
    stroke: #afafaf;
}

path.line {
    stroke-linecap: round;
    stroke-linejoin: round;
}

path.stroke {
    stroke: #000;
    stroke-width: 4;
}

path.shadow {
    stroke: #f6634f;
    stroke-width: 16;
    stroke-opacity: 0;
    stroke-linecap: round;
    stroke-linejoin: round;
}

path.shadow.related:not(.selected),
path.shadow.hover:not(.selected) {
    stroke-opacity: 0.4;
}

path.shadow.selected {
    stroke-opacity: 0.7;
}

path.line.stroke {
    stroke: #fff;
    stroke-width: 2;
}


/* Labels / Markers */
text {
    font-size: 10px;
    color: #222;
    opacity: 1;
}

.oneway .textpath.tag-waterway {
    fill: #002F35;
}

.onewaygroup path.oneway,
.viewfieldgroup path.viewfield,
.sidedgroup path.sided {
    stroke-width: 6px;
}

text.arealabel-halo,
text.linelabel-halo,
text.pointlabel-halo,
text.arealabel,
text.linelabel,
text.pointlabel {
    dominant-baseline: middle;
    text-anchor: middle;
    font-size: 12px;
    font-weight: bold;
    fill: #333;
    -webkit-transition: opacity 100ms linear;
    transition: opacity 100ms linear;
    -moz-transition: opacity 100ms linear;
}

/* Opera doesn't support dominant-baseline. See #715 */
/* Safari 10 seems to have regressed too */
.linelabel-halo .textpath,
.linelabel .textpath {
  baseline-shift: -33%;
  dominant-baseline: auto;
}

.labels-group.halo text {
    opacity: 0.7;
    stroke: #fff;
    stroke-width: 5px;
    stroke-miterlimit: 1;
}

text.nolabel {
    opacity: 0 !important;
}
text.point {
    font-size: 10px;
}

.icon.areaicon-halo {
    opacity: 0.6;
    stroke: #999;
    stroke-width: 2px;
    stroke-miterlimit: 1;
}
.icon.areaicon {
    fill: #222;
    opacity: 0.8;
}


/* Wikidata-tagged */
g.point.tag-wikidata path.stroke {
    stroke-width: 2px;
    stroke: #666;
    fill: #eee;
}
g.point.tag-wikidata .icon {
    color: #666;
}

/* Selected Members */
g.vertex.selected-member .shadow,
g.point.selected-member .shadow,
path.shadow.selected-member {
    stroke-opacity: 0.95;
    stroke: #FFDE70;
}

/* Highlighting */
g.point.highlighted .shadow,
path.shadow.highlighted {
    stroke-opacity: 0.95;
    stroke: #7092ff;
}
g.vertex.highlighted .shadow {
    stroke-width: 7;
    stroke-opacity: 0.95;
    stroke: #7092ff;
}

/* Turn Restrictions */
.points-group.turns g.turn rect,
.points-group.turns g.turn circle {
    fill: none;
}

/* Turn restriction paths and vertices */
.surface.tr .way.target,
.surface.tr path.shadow.selected,
.surface.tr path.shadow.related {
    stroke-width: 25px;
}

.surface.tr path.shadow.selected,
.surface.tr path.shadow.related,
.surface.tr g.vertex.selected .shadow,
.surface.tr g.vertex.related .shadow {
    stroke-opacity: 0.7;
    stroke: #777;
}
.surface.tr path.shadow.related.allow,
.surface.tr g.vertex.related.allow .shadow {
    stroke: #5b3;
}
.surface.tr path.shadow.related.restrict,
.surface.tr g.vertex.related.restrict .shadow {
    stroke: #d53;
}
.surface.tr path.shadow.related.only,
.surface.tr g.vertex.related.only .shadow {
    stroke: #68f;
}

/* Visual Diffs
------------------
`highlight-edited` - visual diff activated
`added` - entity was created by the user
`moved` - node has different coordinates
`geometry-edited` - way has different nodes
`segment-edited` - one or both adjacents nodes moved
`retagged` - some tagging change has occurred
*/

/* Vertex visual diffs */
.highlight-edited g.points g.node.vertex.added > circle.shadow,
.highlight-edited g.points g.node.vertex.retagged > circle.shadow,
.highlight-edited g.points g.node.vertex.moved > circle.shadow {
    fill-opacity: 0.8;
}
.highlight-edited g.points g.node.vertex.added > circle.shadow {
    fill: rgb(133, 255, 103);
}
.highlight-edited g.points g.node.vertex.retagged > circle.shadow {
    fill: #fcde5a;
}
.highlight-edited g.points g.node.vertex.moved > circle.shadow {
    fill: rgb(255, 126, 46);
}

/* Point visual diffs */
.highlight-edited g.points g.node.point.added > path.shadow,
.highlight-edited g.points g.node.point.retagged > path.shadow,
.highlight-edited g.points g.node.point.moved > path.shadow {
    stroke-opacity: 0.8;
    stroke-width: 10;
}
.highlight-edited g.points g.node.point.added > path.shadow {
    stroke: rgb(133, 255, 103);
}
.highlight-edited g.points g.node.point.retagged > path.shadow {
    stroke: #fcde5a;
}
.highlight-edited g.points g.node.point.moved > path.shadow {
    stroke: rgb(255, 126, 46);
}

/* Line/area segment visual diffs
- segments are rendered on top of the ways for convenience and to differentiate
  them from entire line diffs, so make them thin
*/
.highlight-edited g.lines > path.line.segment-edited,
.highlight-edited g.areas > path.area.segment-edited {
    stroke: rgb(255, 126, 46);
    stroke-dasharray: 10, 3;
    stroke-width: 1.5 !important;
    stroke-opacity: 1;
}

/* Entire line/area visual diffs */
.highlight-edited path.line.shadow.added,
.highlight-edited path.line.shadow.retagged,
.highlight-edited path.line.shadow.geometry-edited,
.highlight-edited path.area.shadow.added,
.highlight-edited path.area.shadow.retagged,
.highlight-edited path.area.shadow.geometry-edited {
    stroke-opacity: 0.6;
}
.highlight-edited.fill-wireframe path.line.shadow.added,
.highlight-edited.fill-wireframe path.line.shadow.retagged,
.highlight-edited.fill-wireframe path.line.shadow.geometry-edited,
.highlight-edited.fill-wireframe path.area.shadow.added,
.highlight-edited.fill-wireframe path.area.shadow.retagged,
.highlight-edited.fill-wireframe path.area.shadow.geometry-edited {
    stroke-width: 3;
}
.highlight-edited path.line.shadow.added,
.highlight-edited path.area.shadow.added {
    stroke: rgb(133, 255, 103);
}
.highlight-edited path.area.shadow.retagged,
.highlight-edited path.line.shadow.retagged {
    stroke: #fcde5a;
}
.highlight-edited path.line.shadow.geometry-edited,
.highlight-edited path.area.shadow.geometry-edited {
    stroke: rgb(255, 126, 46);
}

/* Default - light gray */
path.area.stroke {
    stroke: rgb(170, 170, 170);
    stroke-width: 1;
}
path.area.fill {
    stroke-width: 0;
    stroke: rgba(255, 255, 255, 0.3);
    fill: rgba(255, 255, 255, 0.3);
    fill-rule: evenodd;
}
.preset-icon-fill path.fill {
    stroke: rgb(170, 170, 170);
    fill: rgba(170, 170, 170, 0.3);
}

path.shadow.old-multipolygon,
path.stroke.old-multipolygon {
    stroke-dasharray: 100, 5;
    stroke-linecap: butt;
}


/* Green things */
path.stroke.tag-barrier-hedge,
path.stroke.tag-landuse-flowerbed,
path.stroke.tag-landuse-forest,
path.stroke.tag-landuse-grass,
path.stroke.tag-landuse-recreation_ground,
path.stroke.tag-landuse-village_green,
path.stroke.tag-leisure-garden,
path.stroke.tag-leisure-golf_course,
path.stroke.tag-leisure-nature_reserve,
path.stroke.tag-leisure-park,
path.stroke.tag-leisure-pitch,
path.stroke.tag-leisure-track,
path.stroke.tag-natural,
path.stroke.tag-natural-wood {
    stroke: rgb(140, 208, 95);
}
path.fill.tag-barrier-hedge,
path.fill.tag-landuse-flowerbed,
path.fill.tag-landuse-forest,
path.fill.tag-landuse-grass,
path.fill.tag-landuse-recreation_ground,
path.fill.tag-landuse-village_green,
path.fill.tag-leisure-garden,
path.fill.tag-leisure-golf_course,
path.fill.tag-leisure-nature_reserve,
path.fill.tag-leisure-park,
path.fill.tag-leisure-pitch,
path.fill.tag-leisure-track,
path.fill.tag-natural,
path.fill.tag-natural-wood {
    stroke: rgba(140, 208, 95, 0.3);
    fill: rgba(140, 208, 95, 0.3);
}
.pattern-color-forest,
.pattern-color-forest_broadleaved,
.pattern-color-forest_needleleaved,
.pattern-color-forest_leafless,
.pattern-color-wood,
.pattern-color-grass {
    fill: rgba(140, 208, 95, 0.3);
}


/* Blue things */
path.stroke.tag-amenity-fountain,
path.stroke.tag-leisure-swimming_pool,
path.stroke.tag-natural-bay,
path.stroke.tag-natural-water {
    stroke: rgb(119, 211, 222);
}
path.fill.tag-amenity-fountain,
path.fill.tag-leisure-swimming_pool,
path.fill.tag-natural-bay,
path.fill.tag-natural-water {
    stroke: rgba(119, 211, 222, 0.3);
    fill: rgba(119, 211, 222, 0.3);
}
.pattern-color-waves,
.pattern-color-water_standing,
.pattern-color-pond {
    fill: rgba(119, 211, 222, 0.3);
}


/* Yellow things */
path.stroke.tag-leisure-pitch.tag-sport-beachvolleyball,
path.stroke.tag-leisure-pitch.tag-sport-baseball,
path.stroke.tag-leisure-pitch.tag-sport-softball,
path.stroke.tag-leisure-track,
path.stroke.tag-natural-beach,
path.stroke.tag-natural-sand,
path.stroke.tag-natural-scrub,
path.stroke.tag-amenity-childcare,
path.stroke.tag-amenity-kindergarten,
path.stroke.tag-amenity-school,
path.stroke.tag-amenity-college,
path.stroke.tag-amenity-university,
path.stroke.tag-amenity-research_institute {
    stroke: rgba(255, 255, 148, 0.75);
}
path.fill.tag-leisure-pitch.tag-sport-beachvolleyball,
path.fill.tag-leisure-pitch.tag-sport-baseball,
path.fill.tag-leisure-pitch.tag-sport-softball,
path.fill.tag-leisure-track,
path.fill.tag-natural-beach,
path.fill.tag-natural-sand,
path.fill.tag-natural-scrub,
path.fill.tag-amenity-childcare,
path.fill.tag-amenity-kindergarten,
path.fill.tag-amenity-school,
path.fill.tag-amenity-college,
path.fill.tag-amenity-university,
path.fill.tag-amenity-research_institute {
    stroke: rgba(255, 255, 148, 0.25);
    fill: rgba(255, 255, 148, 0.25);
}
.preset-icon-fill path.area.stroke.tag-leisure-pitch.tag-sport-beachvolleyball,
.preset-icon-fill path.area.stroke.tag-leisure-pitch.tag-sport-baseball,
.preset-icon-fill path.area.stroke.tag-leisure-pitch.tag-sport-softball,
.preset-icon-fill path.area.stroke.tag-leisure-track,
.preset-icon-fill path.area.stroke.tag-natural-beach,
.preset-icon-fill path.area.stroke.tag-natural-sand,
.preset-icon-fill path.area.stroke.tag-natural-scrub,
.preset-icon-fill path.area.stroke.tag-amenity-childcare,
.preset-icon-fill path.area.stroke.tag-amenity-kindergarten,
.preset-icon-fill path.area.stroke.tag-amenity-school,
.preset-icon-fill path.area.stroke.tag-amenity-college,
.preset-icon-fill path.area.stroke.tag-amenity-university,
.preset-icon-fill path.area.stroke.tag-amenity-research_institute {
    stroke: rgb(232, 232, 0);
}
.pattern-color-beach,
.pattern-color-sand,
.pattern-color-scrub {
    fill: rgba(255, 255, 148, 0.2);
}


/* Gold things */
path.stroke.tag-landuse-residential,
path.stroke.tag-status-construction {
    stroke: rgb(196, 189, 25);
}
path.fill.tag-landuse-residential,
path.fill.tag-status-construction {
    stroke: rgba(196, 189, 25, 0.3);
    fill: rgba(196, 189, 25, 0.3);
}
.pattern-color-construction {
    fill: rgba(196, 189, 25, 0.3);
}


/* Orange things */
path.stroke.tag-landuse-retail,
path.stroke.tag-landuse-commercial,
path.stroke.tag-landuse-landfill,
path.stroke.tag-military,
path.stroke.tag-landuse-military {
    stroke: rgb(214, 136, 26);
}
path.fill.tag-landuse-retail,
path.fill.tag-landuse-commercial,
path.fill.tag-landuse-landfill,
path.fill.tag-military,
path.fill.tag-landuse-military {
    stroke: rgba(214, 136, 26, 0.3);
    fill: rgba(214, 136, 26, 0.3);
}
.pattern-color-landfill {
    fill: rgba(214, 136, 26, 0.3);
}


/* Pink things */
path.stroke.tag-landuse-industrial,
path.stroke.tag-power-plant {
    stroke: rgb(228, 164, 245);
}
path.fill.tag-landuse-industrial,
path.fill.tag-power-plant {
    stroke: rgba(228, 164, 245, 0.3);
    fill: rgba(228, 164, 245, 0.3);
}


/* Teal things */
path.stroke.tag-natural-wetland {
    stroke: rgb(153, 225, 170);
}
path.fill.tag-natural-wetland {
    stroke: rgba(153, 225, 170, 0.3);
    fill: rgba(153, 225, 170, 0.3);
}
.preset-icon-fill path.area.fill.tag-natural-wetland {
    fill: rgba(153, 225, 170, 0.2);
}
.pattern-color-wetland,
.pattern-color-wetland_marsh,
.pattern-color-wetland_swamp,
.pattern-color-wetland_bog,
.pattern-color-wetland_reedbed {
    fill: rgba(153, 225, 170, 0.3);
}


/* Light Green things */
path.stroke.tag-landuse-cemetery,
path.stroke.tag-landuse-farmland,
path.stroke.tag-landuse-grass.tag-golf-green,
path.stroke.tag-landuse-meadow,
path.stroke.tag-landuse-orchard,
path.stroke.tag-landuse-vineyard {
    stroke: rgb(191, 232, 63);
}
path.fill.tag-landuse-cemetery,
path.fill.tag-landuse-farmland,
path.fill.tag-landuse-grass.tag-golf-green,
path.fill.tag-landuse-meadow,
path.fill.tag-landuse-orchard,
path.fill.tag-landuse-vineyard {
    stroke: rgba(191, 232, 63, 0.3);
    fill: rgba(191, 232, 63, 0.3);
}
.preset-icon-fill path.area.fill.tag-landuse-cemetery,
.preset-icon-fill path.area.fill.tag-landuse-farmland,
.preset-icon-fill path.area.fill.tag-landuse-grass.tag-golf-green,
.preset-icon-fill path.area.fill.tag-landuse-meadow,
.preset-icon-fill path.area.fill.tag-landuse-orchard,
.preset-icon-fill path.area.fill.tag-landuse-vineyard {
    fill: rgba(191, 232, 63, 0.4);
}
.pattern-color-cemetery,
.pattern-color-cemetery_buddhist,
.pattern-color-cemetery_christian,
.pattern-color-cemetery_jewish,
.pattern-color-cemetery_muslim,
.pattern-color-farmland,
.pattern-color-golf_green,
.pattern-color-meadow,
.pattern-color-orchard,
.pattern-color-vineyard {
    fill: rgba(191, 232, 63, 0.3);
}


/* Tan things */
path.stroke.tag-landuse-farmyard {
    stroke: rgb(245, 220, 186);
}
path.fill.tag-landuse-farmyard {
    stroke: rgba(245, 220, 186, 0.3);
    fill: rgba(245, 220, 186, 0.3);
}
.preset-icon-fill path.area.stroke.tag-landuse-farmyard {
    stroke: rgb(226, 177, 111);
}
.pattern-color-farmyard {
    fill: rgba(245, 220, 186, 0.3);
}


/* Dark Gray things */
path.stroke.tag-amenity-parking,
path.stroke.tag-landuse-railway,
path.stroke.tag-landuse-quarry,
path.stroke.tag-leisure-pitch.tag-sport-basketball,
path.stroke.tag-leisure-pitch.tag-sport-skateboard,
path.stroke.tag-man_made-adit,
path.stroke.tag-man_made-groyne,
path.stroke.tag-man_made-breakwater,
path.stroke.tag-natural-bare_rock,
path.stroke.tag-natural-cave_entrance,
path.stroke.tag-natural-cliff,
path.stroke.tag-natural-rock,
path.stroke.tag-natural-scree,
path.stroke.tag-natural-stone,
path.stroke.tag-natural-shingle,
path.stroke.tag-waterway-dam,
path.stroke.tag-waterway-weir {
    stroke: rgb(170, 170, 170);
}
path.fill.tag-amenity-parking,
path.fill.tag-landuse-railway,
path.fill.tag-landuse-quarry,
path.fill.tag-leisure-pitch.tag-sport-basketball,
path.fill.tag-leisure-pitch.tag-sport-skateboard,
path.fill.tag-man_made-adit,
path.fill.tag-man_made-groyne,
path.fill.tag-man_made-breakwater,
path.fill.tag-natural-bare_rock,
path.fill.tag-natural-cliff,
path.fill.tag-natural-cave_entrance,
path.fill.tag-natural-rock,
path.fill.tag-natural-scree,
path.fill.tag-natural-stone,
path.fill.tag-natural-shingle,
path.fill.tag-waterway-dam,
path.fill.tag-waterway-weir {
    stroke: rgba(140, 140, 140, 0.5);
    fill: rgba(140, 140, 140, 0.5);
}
.pattern-color-quarry {
    fill: rgba(140, 140, 140, 0.5);
}


/* Light gray overrides */
path.stroke.tag-natural-cave_entrance,
path.stroke.tag-natural-glacier {
    stroke: rgb(170, 170, 170);
}
path.fill.tag-natural-cave_entrance,
path.fill.tag-natural-glacier {
    stroke: rgba(255, 255, 255, 0.3);
    fill: rgba(255, 255, 255, 0.3);
}
.preset-icon-fill path.fill.tag-natural-cave_entrance,
.preset-icon-fill path.fill.tag-natural-glacier {
    stroke: rgb(170, 170, 170);
    fill: rgba(170, 170, 170, 0.3);
}
preset-icon-container/* highways */

/* defaults */
.preset-icon .icon.tag-highway.other-line {
    color: #fff;
    fill: #777;
}
path.line.casing.tag-highway {
    stroke: #444;
}
path.line.stroke.tag-highway {
    stroke: #ccc;
}

/* wide highways */
path.line.shadow.tag-highway {
    stroke-width: 20;
}
path.line.casing.tag-highway {
    stroke-width: 10;
}
path.line.stroke.tag-highway {
    stroke-width: 8;
}
.low-zoom path.line.shadow.tag-highway {
    stroke-width: 16;
}
.low-zoom path.line.casing.tag-highway {
    stroke-width: 7;
}
.low-zoom path.line.stroke.tag-highway {
    stroke-width: 5;
}

.preset-icon .icon.tag-highway-motorway,
.preset-icon .icon.tag-highway-motorway_link {
    color: #CF2081;
    fill: #70372f;
}
path.line.stroke.tag-highway-motorway,
path.line.stroke.tag-highway-motorway_link,
path.line.stroke.tag-motorway {
    stroke: #CF2081;
}
path.line.casing.tag-highway-motorway,
path.line.casing.tag-highway-motorway_link,
path.line.casing.tag-motorway {
    stroke: #70372f;
}

.preset-icon .icon.tag-highway-trunk,
.preset-icon .icon.tag-highway-trunk_link {
    color: #DD2F22;
    fill: #70372f;
}
path.line.stroke.tag-highway-trunk,
path.line.stroke.tag-highway-trunk_link,
path.line.stroke.tag-trunk {
    stroke: #DD2F22;
}
path.line.casing.tag-highway-trunk,
path.line.casing.tag-highway-trunk_link,
path.line.casing.tag-trunk {
    stroke: #70372f;
}

.preset-icon .icon.tag-highway-primary,
.preset-icon .icon.tag-highway-primary_link {
    color: #F99806;
    fill: #70372f;
}
path.line.stroke.tag-highway-primary,
path.line.stroke.tag-highway-primary_link,
path.line.stroke.tag-primary {
    stroke: #F99806;
}
path.line.casing.tag-highway-primary,
path.line.casing.tag-highway-primary_link,
path.line.casing.tag-primary {
    stroke: #70372f;
}

.preset-icon .icon.tag-highway-secondary,
.preset-icon .icon.tag-highway-secondary_link {
    color: #F3F312;
    fill: #70372f;
}
path.line.stroke.tag-highway-secondary,
path.line.stroke.tag-highway-secondary_link,
path.line.stroke.tag-secondary {
    stroke: #F3F312;
}
path.line.casing.tag-highway-secondary,
path.line.casing.tag-highway-secondary_link,
path.line.casing.tag-secondary {
    stroke: #70372f;
}

.preset-icon .icon.tag-highway-tertiary,
.preset-icon .icon.tag-highway-tertiary_link {
    color: #FFF9B3;
    fill: #70372f;
}
path.line.stroke.tag-highway-tertiary,
path.line.stroke.tag-highway-tertiary_link,
path.line.stroke.tag-tertiary {
    stroke: #FFF9B3;
}
path.line.casing.tag-highway-tertiary,
path.line.casing.tag-highway-tertiary_link,
path.line.casing.tag-tertiary {
    stroke: #70372f;
}

.legacy-carto .preset-icon .icon.tag-highway-motorway,
.legacy-carto .preset-icon .icon.tag-highway-motorway_link {
    color: #58a9ed;
    fill: #2c5476;
}
.legacy-carto path.line.stroke.tag-highway-motorway,
.legacy-carto path.line.stroke.tag-highway-motorway_link,
.legacy-carto path.line.stroke.tag-motorway {
    stroke: #58a9ed;
}
.legacy-carto path.line.casing.tag-highway-motorway,
.legacy-carto path.line.casing.tag-highway-motorway_link,
.legacy-carto path.line.casing.tag-motorway {
    stroke: #2c5476;
}

.legacy-carto .preset-icon .icon.tag-highway-trunk,
.legacy-carto .preset-icon .icon.tag-highway-trunk_link {
    color: #8cd05f;
    fill: #46682f;
}
.legacy-carto path.line.stroke.tag-highway-trunk,
.legacy-carto path.line.stroke.tag-highway-trunk_link,
.legacy-carto path.line.stroke.tag-trunk {
    stroke: #8cd05f;
}
.legacy-carto path.line.casing.tag-highway-trunk,
.legacy-carto path.line.casing.tag-highway-trunk_link,
.legacy-carto path.line.casing.tag-trunk {
    stroke: #46682f;
}

.legacy-carto .preset-icon .icon.tag-highway-primary,
.legacy-carto .preset-icon .icon.tag-highway-primary_link {
    color: #e06d5f;
    fill: #70372f;
}
.legacy-carto path.line.stroke.tag-highway-primary,
.legacy-carto path.line.stroke.tag-highway-primary_link,
.legacy-carto path.line.stroke.tag-primary {
    stroke: #e06d5f;
}
.legacy-carto path.line.casing.tag-highway-primary,
.legacy-carto path.line.casing.tag-highway-primary_link,
.legacy-carto path.line.casing.tag-primary {
    stroke: #70372f;
}

.legacy-carto .preset-icon .icon.tag-highway-secondary,
.legacy-carto .preset-icon .icon.tag-highway-secondary_link {
    color: #eab056;
    fill: #75582b;
}
.legacy-carto path.line.stroke.tag-highway-secondary,
.legacy-carto path.line.stroke.tag-highway-secondary_link,
.legacy-carto path.line.stroke.tag-secondary {
    stroke: #eab056;
}
.legacy-carto path.line.casing.tag-highway-secondary,
.legacy-carto path.line.casing.tag-highway-secondary_link,
.legacy-carto path.line.casing.tag-secondary {
    stroke: #75582b;
}

.legacy-carto .preset-icon .icon.tag-highway-tertiary,
.legacy-carto .preset-icon .icon.tag-highway-tertiary_link {
    color: #ffff7e;
    fill: #7f7f3f;
}
.legacy-carto path.line.stroke.tag-highway-tertiary,
.legacy-carto path.line.stroke.tag-highway-tertiary_link,
.legacy-carto path.line.stroke.tag-tertiary {
    stroke: #ffff7e;
}
.legacy-carto path.line.casing.tag-highway-tertiary,
.legacy-carto path.line.casing.tag-highway-tertiary_link,
.legacy-carto path.line.casing.tag-tertiary {
    stroke: #7f7f3f;
}

.preset-icon .icon.tag-highway-residential {
    color: #fff;
    fill: #444;
}
path.line.stroke.tag-highway-residential,
path.line.stroke.tag-residential {
    stroke: #fff;
}
path.line.casing.tag-highway-residential,
path.line.casing.tag-residential {
    stroke: #444;
}

.preset-icon .icon.tag-highway-unclassified {
    color: #dca;
    fill: #444;
}
path.line.stroke.tag-highway-unclassified,
path.line.stroke.tag-unclassified {
    stroke: #dca;
}
path.line.casing.tag-highway-unclassified,
path.line.casing.tag-unclassified {
    stroke: #444;
}


/* narrow highways */
path.line.shadow.tag-highway-living_street,
path.line.shadow.tag-highway-bus_guideway,
path.line.shadow.tag-highway-service,
path.line.shadow.tag-highway-track,
path.line.shadow.tag-highway-road {
    stroke-width: 16;
}
path.line.casing.tag-highway-living_street,
path.line.casing.tag-highway-bus_guideway,
path.line.casing.tag-highway-service,
path.line.casing.tag-highway-track,
path.line.casing.tag-highway-road {
    stroke-width: 7;
}
path.line.stroke.tag-highway-living_street,
path.line.stroke.tag-highway-bus_guideway,
path.line.stroke.tag-highway-service,
path.line.stroke.tag-highway-track,
path.line.stroke.tag-highway-road {
    stroke-width: 5;
}

path.line.shadow.tag-highway-path,
path.line.shadow.tag-highway-footway,
path.line.shadow.tag-highway-cycleway,
path.line.shadow.tag-highway-bridleway,
path.line.shadow.tag-highway-corridor,
path.line.shadow.tag-highway-pedestrian,
path.line.shadow.tag-highway-steps {
    stroke-width: 16;
}
path.line.casing.tag-highway-path,
path.line.casing.tag-highway-footway,
path.line.casing.tag-highway-cycleway,
path.line.casing.tag-highway-bridleway,
path.line.casing.tag-highway-corridor,
path.line.casing.tag-highway-pedestrian,
path.line.casing.tag-highway-steps {
    stroke-width: 5;
}
path.line.stroke.tag-highway-path,
path.line.stroke.tag-highway-footway,
path.line.stroke.tag-highway-cycleway,
path.line.stroke.tag-highway-bridleway,
path.line.stroke.tag-highway-corridor,
path.line.stroke.tag-highway-pedestrian,
path.line.stroke.tag-highway-steps {
    stroke-width: 3;
}

.low-zoom path.line.shadow.tag-highway-living_street,
.low-zoom path.line.shadow.tag-highway-bus_guideway,
.low-zoom path.line.shadow.tag-highway-service,
.low-zoom path.line.shadow.tag-highway-track,
.low-zoom path.line.shadow.tag-highway-road {
    stroke-width: 12;
}
.low-zoom path.line.casing.tag-highway-living_street,
.low-zoom path.line.casing.tag-highway-bus_guideway,
.low-zoom path.line.casing.tag-highway-service,
.low-zoom path.line.casing.tag-highway-track,
.low-zoom path.line.casing.tag-highway-road {
    stroke-width: 5;
}
.low-zoom path.line.stroke.tag-highway-living_street,
.low-zoom path.line.stroke.tag-highway-bus_guideway,
.low-zoom path.line.stroke.tag-highway-service,
.low-zoom path.line.stroke.tag-highway-track,
.low-zoom path.line.stroke.tag-highway-road {
    stroke-width: 3;
}

.low-zoom path.line.shadow.tag-highway-path,
.low-zoom path.line.shadow.tag-highway-footway,
.low-zoom path.line.shadow.tag-highway-cycleway,
.low-zoom path.line.shadow.tag-highway-bridleway,
.low-zoom path.line.shadow.tag-highway-corridor,
.low-zoom path.line.shadow.tag-highway-pedestrian,
.low-zoom path.line.shadow.tag-highway-steps {
    stroke-width: 12;
}
.low-zoom path.line.casing.tag-highway-path,
.low-zoom path.line.casing.tag-highway-footway,
.low-zoom path.line.casing.tag-highway-cycleway,
.low-zoom path.line.casing.tag-highway-bridleway,
.low-zoom path.line.casing.tag-highway-corridor,
.low-zoom path.line.casing.tag-highway-pedestrian,
.low-zoom path.line.casing.tag-highway-steps {
    stroke-width: 3;
}
.low-zoom path.line.stroke.tag-highway-path,
.low-zoom path.line.stroke.tag-highway-footway,
.low-zoom path.line.stroke.tag-highway-cycleway,
.low-zoom path.line.stroke.tag-highway-bridleway,
.low-zoom path.line.stroke.tag-highway-corridor,
.low-zoom path.line.stroke.tag-highway-pedestrian,
.low-zoom path.line.stroke.tag-highway-steps {
    stroke-width: 1;
}

/* living streets */
.preset-icon .icon.tag-highway-living-street {
    color: #bbb;
    fill: #ddd;
}
path.line.stroke.tag-highway-living_street,
path.line.stroke.tag-living_street {
    stroke: #ccc;
}
path.line.casing.tag-highway-living_street,
path.line.casing.tag-living_street {
    stroke: #fff;
}

/* pedestrian streets and corridors */
.preset-icon .icon.tag-highway-corridor,
.preset-icon .icon.tag-highway-pedestrian {
    color: #8cd05f;
    fill: #fff;
}
path.line.stroke.tag-highway-corridor,
path.line.stroke.tag-highway-pedestrian,
path.line.stroke.tag-corridor,
path.line.stroke.tag-pedestrian {
    stroke: #fff;
    stroke-dasharray: 2, 8;
}
.low-zoom path.line.stroke.tag-highway-corridor,
.low-zoom path.line.stroke.tag-highway-pedestrian,
.low-zoom path.line.stroke.tag-corridor,
.low-zoom path.line.stroke.tag-pedestrian {
    stroke-dasharray: 1, 4;
}
path.line.casing.tag-highway-corridor,
path.line.casing.tag-highway-pedestrian,
path.line.casing.tag-corridor,
path.line.casing.tag-pedestrian,
path.line.casing.tag-highway-corridor.tag-unpaved,
path.line.casing.tag-highway-pedestrian.tag-unpaved,
path.line.casing.tag-corridor.tag-unpaved,
path.line.casing.tag-pedestrian.tag-unpaved {
    stroke: #8cd05f;
    stroke-linecap: round;
    stroke-dasharray: none;
}

/* unknown roads */
.preset-icon .icon.tag-highway-road {
    color: #9e9e9e;
    fill: #666;
}
path.line.stroke.tag-highway-road,
path.line.stroke.tag-road {
    stroke: #9e9e9e;
}
path.line.casing.tag-highway-road,
path.line.casing.tag-road {
    stroke: #666;
}

/* service roads */
.preset-icon .icon.tag-highway-service {
    color: #fff;
    fill: #666;
}
path.line.stroke.tag-highway-service,
path.line.stroke.tag-service {
    stroke: #fff;
}
path.line.casing.tag-highway-service,
path.line.casing.tag-service {
    stroke: #666;
}

/* special service roads and bus guideways */
/* with `service=* tag`  (e.g. parking_aisle, alley, drive-through) */
.preset-icon .icon.tag-highway-bus_guideway,
.preset-icon .icon.tag-highway-service.tag-service {
    color: #dca;
    fill: #666;
}
path.line.stroke.tag-highway-bus_guideway,
path.line.stroke.tag-highway-service.tag-service,
path.line.stroke.tag-service.tag-service {
    stroke: #dca;
}
path.line.casing.tag-highway-bus_guideway,
path.line.casing.tag-highway-service.tag-service,
path.line.casing.tag-service.tag-service {
    stroke: #666;
}

/* unmaintained track roads */
path.line.stroke.tag-highway-track,
path.line.stroke.tag-track {
    stroke: #c5b59f;
}
path.line.casing.tag-highway-track,
path.line.casing.tag-track {
    stroke: #746f6f;
}

/* paths */
path.line.stroke.tag-highway-path,
path.line.stroke.tag-highway-footway,
path.line.stroke.tag-highway-cycleway,
path.line.stroke.tag-highway-bridleway {
    stroke-linecap: butt;
    stroke-dasharray: 6, 6;
}
.low-zoom path.line.stroke.tag-highway-path,
.low-zoom path.line.stroke.tag-highway-footway,
.low-zoom path.line.stroke.tag-highway-cycleway,
.low-zoom path.line.stroke.tag-highway-bridleway {
    stroke-linecap: butt;
    stroke-dasharray: 3, 3;
}

/* style for features that should have highway=footway but don't yet */
path.line.stroke.tag-crossing,
path.line.stroke.tag-footway-access_aisle,
path.line.stroke.tag-public_transport-platform,
path.line.stroke.tag-highway-platform,
path.line.stroke.tag-railway-platform,
path.line.stroke.tag-man_made-pier {
    stroke: #dca;
}

path.line.casing.tag-highway-path,
path.line.casing.tag-highway-path.tag-unpaved,
path.line.casing.tag-highway-footway.tag-public_transport-platform,
path.line.casing.tag-highway-footway.tag-man_made-pier,
path.line.casing.tag-highway.tag-crossing,
path.line.casing.tag-highway.tag-footway-access_aisle {
    stroke: #dca;
    stroke-linecap: round;
    stroke-dasharray: none;
}
path.line.casing.tag-highway-footway,
path.line.casing.tag-highway-cycleway,
path.line.casing.tag-highway-bridleway,
path.line.casing.tag-highway-footway.tag-unpaved,
path.line.casing.tag-highway-cycleway.tag-unpaved,
path.line.casing.tag-highway-bridleway.tag-unpaved {
    stroke: #fff;
    stroke-linecap: round;
    stroke-dasharray: none;
}

.preset-icon .icon.tag-highway-path,
.preset-icon .icon.tag-highway-footway.tag-public_transport-platform,
.preset-icon .icon.tag-highway-footway.tag-man_made-pier {
    color: #988;
    fill: #dca;
}
path.line.stroke.tag-highway-path {
    stroke: #988;
}

/* footways */
.preset-icon .icon.tag-route-foot,
.preset-icon .icon.tag-route-hiking,
.preset-icon .icon.tag-highway-footway {
    color: #988;
    fill: #fff;
}
path.line.stroke.tag-highway-footway,
path.line.stroke.tag-highway_bus_stop,
.preset-icon-container path.casing.tag-highway-footway {
    stroke: #988;
}
.preset-icon .icon.tag-highway-footway.tag-footway-sidewalk {
    color: #d4b4b4;
}
path.stroke.tag-highway-footway.tag-footway-sidewalk,
.preset-icon-container path.casing.tag-highway-footway.tag-footway-sidewalk {
    stroke: #d4b4b4;
}
.preset-icon-container path.stroke.tag-highway-footway:not(.tag-crossing-marked):not(.tag-crossing-unmarked):not(.tag-footway-access_aisle):not(.tag-man_made-pier):not(.tag-public_transport-platform) {
    stroke: #fff;
}

/* cycleways */
.preset-icon .icon.tag-route-bicycle,
.preset-icon .icon.tag-highway-cycleway {
    color: #58a9ed;
    fill: #fff;
}
path.line.stroke.tag-highway-cycleway,
.preset-icon-container path.casing.tag-highway-cycleway {
    stroke: #58a9ed;
}
.preset-icon-container path.stroke.tag-highway-cycleway:not(.tag-crossing) {
    stroke: #fff;
}

/* bridleways */
.preset-icon .icon.tag-route-horse,
.preset-icon .icon.tag-highway-bridleway {
    color: #e06d5f;
    fill: #fff;
}
path.line.stroke.tag-highway-bridleway,
.preset-icon-container path.casing.tag-highway-bridleway {
    stroke: #e06d5f;
}
.preset-icon-container path.stroke.tag-highway-bridleway {
    stroke: #fff;
}

/* racetracks */
.preset-icon .icon.tag-leisure-track {
    color: rgb(229, 184, 43);
}
path.line.stroke.tag-leisure-track,
.preset-icon-container path.casing.tag-highway.tag-leisure-track {
    stroke: rgb(229, 184, 43);
}
.preset-icon-container path.line.stroke.tag-highway.tag-leisure-track {
    stroke: #fff;
}

/* steps */
.preset-icon .icon.tag-highway-steps {
    color: #81d25c;
    fill: #fff;
}
path.line.stroke.tag-highway-steps {
    stroke-linecap: butt;
    stroke-dasharray: 3, 3;
}
.low-zoom path.line.stroke.tag-highway-steps {
    stroke-dasharray: 2, 2;
}
path.line.casing.tag-highway-steps,
path.line.casing.tag-highway-steps.tag-unpaved {
    stroke: #fff;
    stroke-linecap: round;
    stroke-dasharray: none;
}
path.line.stroke.tag-highway-steps,
.preset-icon-container path.line.casing.tag-highway-steps {
    stroke: #81d25c;
}
.preset-icon-container path.line.stroke.tag-highway-steps {
    stroke: #fff;
}


/* crossings */
path.line.stroke.tag-highway.tag-crossing-unmarked {
    stroke-dasharray: 6, 4;
}
.low-zoom path.line.stroke.tag-highway.tag-crossing-unmarked {
    stroke-dasharray: 3, 2;
}
path.line.stroke.tag-highway.tag-crossing-marked {
    stroke-dasharray: 6, 3;
}
.low-zoom path.line.stroke.tag-highway.tag-crossing-marked {
    stroke-dasharray: 3, 1.5;
}
path.line.stroke.tag-highway-footway.tag-crossing-marked {
    stroke: #4c4444;
}
.preset-icon .icon.tag-highway-footway.tag-crossing-marked {
    color: #4c4444;
}
path.line.stroke.tag-highway-footway.tag-crossing-unmarked {
    stroke: #776a6a;
}
.preset-icon .icon.tag-highway-footway.tag-crossing-unmarked {
    color: #776a6a;
}
path.line.stroke.tag-highway-cycleway.tag-crossing-marked {
    stroke: #446077;
}
.preset-icon .icon.tag-highway-cycleway.tag-crossing-marked {
    color: #446077;
}

path.line.stroke.tag-highway.tag-footway-access_aisle {
    stroke-dasharray: 4, 2;
}
.low-zoom path.line.stroke.tag-highway.tag-footway-access_aisle,
.preset-icon-container path.stroke.tag-highway.tag-footway-access_aisle {
    stroke-dasharray: 2.5, 1.5;
}
path.line.stroke.tag-highway.tag-footway-access_aisle {
    stroke: #4c4444;
}
.preset-icon .icon.tag-highway.tag-footway-access_aisle {
    color: #4c4444;
}


/* highway midpoints */
g.midpoint.tag-highway-corridor .fill,
g.midpoint.tag-highway-pedestrian .fill,
g.midpoint.tag-highway-steps .fill,
g.midpoint.tag-highway-path .fill,
g.midpoint.tag-highway-footway .fill,
g.midpoint.tag-highway-cycleway .fill,
g.midpoint.tag-highway-bridleway .fill {
    fill: #fff;
    stroke: #333;
    stroke-opacity: .8;
    opacity: .8;
}
/* aeroways */

/* areas */
path.area.stroke.tag-aeroway,
.low-zoom path.area.stroke.tag-aeroway {
    stroke: #fff;
    stroke-dasharray: none;
    stroke-width: 1;
}
path.area.fill.tag-aeroway-runway {
    stroke: rgba(0, 0, 0, 0.6);
    fill: rgba(0, 0, 0, 0.6);
}

/* lines */
/* narrow aeroways (taxiway) */
path.line.shadow.tag-aeroway-taxiway,
path.line.shadow.tag-taxiway {
    stroke-width: 16;
}
path.line.casing.tag-aeroway-taxiway,
path.line.casing.tag-taxiway {
    stroke-width: 7;
}
path.line.stroke.tag-aeroway-taxiway,
path.line.stroke.tag-taxiway {
    stroke-width: 5;
}
.low-zoom path.line.shadow.tag-aeroway-taxiway,
.low-zoom path.line.shadow.tag-taxiway {
    stroke-width: 12;
}
.low-zoom path.line.casing.tag-aeroway-taxiway,
.low-zoom path.line.casing.tag-taxiway {
    stroke-width: 5;
}
.low-zoom path.line.stroke.tag-aeroway-taxiway,
.low-zoom path.line.stroke.tag-taxiway {
    stroke-width: 3;
}

.preset-icon .icon.tag-aeroway-taxiway,
.preset-icon .icon.tag-taxiway {
    color: #ff0;
    fill: #666;
}
path.line.stroke.tag-aeroway-taxiway,
path.line.stroke.tag-taxiway {
    stroke: #ff0;
}
path.line.casing.tag-aeroway-taxiway,
path.line.casing.tag-taxiway {
    stroke: #666;
}

/* wide aeroways (runway) */
.preset-icon .icon.tag-aeroway-runway,
.preset-icon .icon.tag-runway {
    color: #444;
    fill: #000;
}
path.line.shadow.tag-aeroway-runway {
    stroke-width: 20;
}
path.line.casing.tag-aeroway-runway {
    stroke-width: 10;
    stroke: #000;
    stroke-linecap: square;
}
path.line.stroke.tag-aeroway-runway {
    stroke: #fff;
    stroke-width: 2;
    stroke-linecap: butt;
    stroke-dasharray: 24, 48;
}
.low-zoom path.line.shadow.tag-aeroway-runway {
    stroke-width: 16;
}
.low-zoom path.line.casing.tag-aeroway-runway {
    stroke-width: 7;
}
.low-zoom path.line.stroke.tag-aeroway-runway {
    stroke-width: 2;
    stroke-dasharray: 12, 24;
}
.preset-icon-container path.line.stroke.tag-aeroway-runway {
    stroke-dasharray: 0, 14, 8, 14;
}
/* railways */

/* defaults */
.preset-icon .icon.tag-railway.other-line {
    color: #fff;
    fill: #777;
}
.preset-icon .icon.tag-railway {
    color: #555;
    fill: #eee;
}

/* lines */
/* narrow widths */
path.line.shadow.tag-railway {
    stroke-width: 16;
}
path.line.casing.tag-railway {
    stroke-width: 7;
}
path.line.stroke.tag-railway {
    stroke-width: 2;
    stroke-linecap: butt;
    stroke-dasharray: 12,12;
}
.low-zoom path.line.shadow.tag-railway {
    stroke-width: 12;
}
.low-zoom path.line.casing.tag-railway {
    stroke-width: 5;
}
.low-zoom path.line.stroke.tag-railway {
    stroke-width: 2;
    stroke-dasharray: 6,6;
}
.preset-icon-container path.line.stroke.tag-railway:not(.tag-status) {
    stroke-dasharray: 6;
}

path.line.casing.tag-railway.tag-railway-platform {
    stroke-width: 0;
}
path.line.stroke.tag-railway.tag-railway-platform {
    stroke-dasharray: none;
}

/* styles */
path.line.casing.tag-railway {
    stroke: #555;
}
path.line.stroke.tag-railway {
    stroke: #eee;
}


.preset-icon .icon.tag-railway-disused,
.preset-icon .icon.tag-railway-abandoned {
    color: #999;
    fill: #eee;
}
path.line.casing.tag-railway-disused,
path.line.casing.tag-railway-abandoned {
    stroke: #999;
}
path.line.stroke.tag-railway-disused,
path.line.stroke.tag-railway-abandoned {
    stroke: #eee;
}


path.line.casing.tag-railway-subway {
    stroke: #222;
}
path.line.stroke.tag-railway-subway {
    stroke: #bbb;
}
/* waterways */

/* defaults */
.preset-icon .icon.tag-waterway.other-line {
    color: #7dd;
    fill: #7dd;
}
.preset-icon .icon.tag-type-waterway:not(.tag-waterway-dam),
.preset-icon .icon.tag-waterway:not(.tag-waterway-dam) {
    color: #7dd;
    fill: #fff;
}


/* areas */
path.area.stroke.tag-waterway-dock,
path.area.stroke.tag-waterway-boatyard,
path.area.stroke.tag-waterway-fuel {
    stroke: white;
    stroke-width: 1;
}
path.area.casing.tag-waterway-dock,
path.area.casing.tag-waterway-boatyard,
path.area.casing.tag-waterway-fuel {
    stroke: none;
}
path.area.fill.tag-waterway-dock,
path.area.fill.tag-waterway-boatyard,
path.area.fill.tag-waterway-fuel {
    stroke: rgba(255, 255, 255, 0.3);
    fill: rgba(255, 255, 255, 0.3);
}

/* lines */
path.line.fill.tag-waterway:not(.tag-waterway-dam) {
    stroke: rgba(119, 211, 222, 0.3);
    fill: rgba(119, 211, 222, 0.3);
}
path.line.casing.tag-waterway:not(.tag-waterway-dam) {
    stroke: #444;
}
path.line.stroke.tag-waterway:not(.tag-waterway-dam) {
    stroke: #7dd;
}


/* narrow waterways (default) */
path.line.shadow.tag-waterway {
    stroke-width: 16;
}
path.line.casing.tag-waterway {
    stroke-width: 7;
}
path.line.stroke.tag-waterway {
    stroke-width: 5;
}

.low-zoom path.line.shadow.tag-waterway {
    stroke-width: 12;
}
.low-zoom path.line.casing.tag-waterway {
    stroke-width: 5;
}
.low-zoom path.line.stroke.tag-waterway {
    stroke-width: 3;
}


/* wide waterways (river) */
path.line.shadow.tag-waterway-river {
    stroke-width: 20;
}
path.line.casing.tag-waterway-river {
    stroke-width: 10;
}
path.line.stroke.tag-waterway-river {
    stroke-width: 8;
}

.low-zoom path.line.shadow.tag-waterway-river {
    stroke-width: 16;
}
.low-zoom path.line.casing.tag-waterway-river {
    stroke-width: 7;
}
.low-zoom path.line.stroke.tag-waterway-river {
    stroke-width: 5;
}


/* ditch */
.preset-icon .icon.tag-waterway-ditch {
    color: #39a;
}
path.line.stroke.tag-waterway-ditch {
    stroke: #39a;
}

/* narrow width miscellanous things */
path.line.shadow.tag-aerialway,
path.line.shadow.tag-attraction-summer_toboggan,
path.line.shadow.tag-attraction-water_slide,
path.line.shadow.tag-golf-cartpath,
path.line.shadow.tag-man_made-pipeline,
path.line.shadow.tag-natural-tree_row,
path.line.shadow.tag-piste {
    stroke-width: 16;
}
path.line.casing.tag-aerialway,
path.line.casing.tag-attraction-summer_toboggan,
path.line.casing.tag-attraction-water_slide,
path.line.casing.tag-golf-cartpath,
path.line.casing.tag-man_made-pipeline,
path.line.casing.tag-natural-tree_row,
path.line.casing.tag-piste {
    stroke-width: 7;
}
path.line.stroke.tag-aerialway,
path.line.stroke.tag-attraction-summer_toboggan,
path.line.stroke.tag-attraction-water_slide,
path.line.stroke.tag-golf-cartpath,
path.line.stroke.tag-man_made-pipeline,
path.line.stroke.tag-natural-tree_row,
path.line.stroke.tag-piste {
    stroke-width: 5;
}

.low-zoom path.line.shadow.tag-aerialway,
.low-zoom path.line.shadow.tag-attraction-summer_toboggan,
.low-zoom path.line.shadow.tag-attraction-water_slide,
.low-zoom path.line.shadow.tag-golf-cartpath,
.low-zoom path.line.shadow.tag-man_made-pipeline,
.low-zoom path.line.shadow.tag-natural-tree_row,
.low-zoom path.line.shadow.tag-piste {
    stroke-width: 12;
}
.low-zoom path.line.casing.tag-aerialway,
.low-zoom path.line.casing.tag-attraction-summer_toboggan,
.low-zoom path.line.casing.tag-attraction-water_slide,
.low-zoom path.line.casing.tag-golf-cartpath,
.low-zoom path.line.casing.tag-man_made-pipeline,
.low-zoom path.line.casing.tag-natural-tree_row,
.low-zoom path.line.casing.tag-piste {
    stroke-width: 5;
}
.low-zoom path.line.stroke.tag-aerialway,
.low-zoom path.line.stroke.tag-attraction-summer_toboggan,
.low-zoom path.line.stroke.tag-attraction-water_slide,
.low-zoom path.line.stroke.tag-golf-cartpath,
.low-zoom path.line.stroke.tag-man_made-pipeline,
.low-zoom path.line.stroke.tag-natural-tree_row,
.low-zoom path.line.stroke.tag-piste {
    stroke-width: 3;
}


/* ferry routes  */
.preset-icon .icon.tag-route-ferry {
    color: #58a9ed;
    fill: #fff;
}
path.line.shadow.tag-route-ferry {
    stroke-width: 16;
}
path.line.stroke.tag-route-ferry {
    stroke-width: 3;
    stroke-linecap: butt;
    stroke-dasharray: 12,8;
}
.low-zoom path.line.shadow.tag-route-ferry {
    stroke-width: 12;
}
.low-zoom path.line.stroke.tag-route-ferry,
.preset-icon-container path.line.stroke.tag-route-ferry {
    stroke-width: 2;
    stroke-dasharray: 6,4;
}
path.line.stroke.tag-route-ferry {
    stroke: #58a9ed;
}
path.line.casing.tag-route-ferry {
    stroke: none;
}


/* aerialways */
path.line.stroke.tag-aerialway {
    stroke: #c55;
}
path.line.casing.tag-aerialway {
    stroke: #444;
}


/* pistes */
path.line.stroke.tag-piste {
    stroke: #a9d;
}
path.line.casing.tag-piste {
    stroke: #444;
}


/* Attractions */
path.line.stroke.tag-attraction-summer_toboggan {
    stroke: #9e9e9e;
}
path.line.casing.tag-attraction-summer_toboggan {
    stroke: #666;
}

path.line.stroke.tag-attraction-water_slide {
    stroke: #aae0cb;
}
path.line.casing.tag-attraction-water_slide {
    stroke: #3d6c71;
}


/* golf cartpaths (like service roads) */
.preset-icon .icon.tag-golf-cartpath {
    color: #dca;
    fill: #666;
}
path.line.stroke.tag-golf-cartpath {
    stroke: #dca;
}
path.line.casing.tag-golf-cartpath {
    stroke: #666;
}


/* power and pipeline */
.preset-icon .icon.tag-man_made-pipeline,
.preset-icon .icon.tag-power {
    color: #939393;
    fill: #939393;
}


/* power */
path.line.stroke.tag-power {
    stroke: #939393;
    stroke-width: 2;
}
path.line.casing.tag-power {
    stroke: none;
}


/* pipeline */
path.line.stroke.tag-man_made-pipeline {
    stroke: #cbd0d8;
    stroke-linecap: butt;
    stroke-dasharray: 80, 1.25;
}
path.line.casing.tag-man_made-pipeline {
    stroke: #666;
}
.low-zoom path.line.stroke.tag-man_made-pipeline {
    stroke-dasharray: 40, 1;
}
.preset-icon-container path.line.stroke.tag-man_made-pipeline {
    stroke-dasharray: 19, 1;
}


/* boundaries */
path.line.stroke.tag-boundary {
    stroke: #fff;
    stroke-width: 2;
    stroke-linecap: butt;
    stroke-dasharray: 20, 5, 5, 5;
}
path.line.casing.tag-boundary {
    stroke: #82b5fe;
    stroke-width: 6;
}

path.line.casing.tag-boundary-protected_area,
path.line.casing.tag-boundary-national_park {
    stroke: #b0e298;
}


/* barriers and similar */
path.line.stroke.tag-barrier:not(.tag-barrier-hedge):not(.tag-waterway) {
    stroke: #ddd;
}
.preset-icon-container path.line.stroke.tag-barrier:not(.tag-barrier-hedge) {
    stroke: rgb(170, 170, 170);
}
path.line.casing.tag-natural,
path.line.casing.tag-barrier:not(.tag-waterway),
path.line.casing.tag-man_made-groyne,
path.line.casing.tag-man_made-breakwater {
    stroke: none;
}
path.line.stroke.tag-barrier:not(.tag-waterway),
path.line.stroke.tag-man_made-groyne,
path.line.stroke.tag-man_made-breakwater {
    stroke-width: 3px;
    stroke-linecap: round;
    stroke-dasharray: 15, 5, 1, 5;
}
.low-zoom path.line.stroke.tag-barrier:not(.tag-waterway),
.low-zoom path.line.stroke.tag-man_made-groyne,
.low-zoom path.line.stroke.tag-man_made-breakwater {
    stroke-width: 2px;
    stroke-linecap: butt;
    stroke-dasharray: 8, 2, 2, 2;
}
.preset-icon-container path.line.stroke.tag-barrier,
.preset-icon-container path.line.stroke.tag-man_made-groyne,
.preset-icon-container path.line.stroke.tag-man_made-breakwater {
    stroke-dasharray: 1, 4, 6, 4;
}
path.line.stroke.tag-barrier.tag-barrier-wall,
path.line.stroke.tag-barrier.tag-barrier-retaining_wall,
path.line.stroke.tag-barrier.tag-barrier-city_wall {
    stroke-linecap: butt;
    stroke-dasharray: 16, 3, 9, 3;
}
.low-zoom path.line.stroke.tag-barrier.tag-barrier-wall,
.low-zoom path.line.stroke.tag-barrier.tag-barrier-retaining_wall,
.low-zoom path.line.stroke.tag-barrier.tag-barrier-city_wall,
.preset-icon-container path.line.stroke.tag-barrier.tag-barrier-wall,
.preset-icon-container path.line.stroke.tag-barrier.tag-barrier-retaining_wall,
.preset-icon-container path.line.stroke.tag-barrier.tag-barrier-city_wall {
    stroke-dasharray: 8, 1, 4, 1;
}


/* bridges */
path.line.casing.tag-bridge {
    stroke-opacity: 0.6;
    stroke: #000 !important;
    stroke-linecap: butt;
    stroke-dasharray: none;
}
path.line.shadow.tag-bridge {
    stroke-width: 24;
}
path.line.casing.tag-bridge {
    stroke-width: 16;
}
.low-zoom path.line.shadow.tag-bridge {
    stroke-width: 16;
}
.low-zoom path.line.casing.tag-bridge {
    stroke-width: 10;
}

path.line.shadow.tag-railway.tag-bridge,
path.line.shadow.tag-highway-living_street.tag-bridge,
path.line.shadow.tag-highway-path.tag-bridge,
path.line.shadow.tag-highway-corridor.tag-bridge,
path.line.shadow.tag-highway-pedestrian.tag-bridge,
path.line.shadow.tag-highway-service.tag-bridge,
path.line.shadow.tag-highway-track.tag-bridge,
path.line.shadow.tag-highway-steps.tag-bridge,
path.line.shadow.tag-highway-footway.tag-bridge,
path.line.shadow.tag-highway-cycleway.tag-bridge,
path.line.shadow.tag-highway-bridleway.tag-bridge {
    stroke-width: 18;
}
path.line.casing.tag-railway.tag-bridge,
path.line.casing.tag-highway-living_street.tag-bridge,
path.line.casing.tag-highway-path.tag-bridge,
path.line.casing.tag-highway-corridor.tag-bridge,
path.line.casing.tag-highway-pedestrian.tag-bridge,
path.line.casing.tag-highway-service.tag-bridge,
path.line.casing.tag-highway-track.tag-bridge,
path.line.casing.tag-highway-steps.tag-bridge,
path.line.casing.tag-highway-footway.tag-bridge,
path.line.casing.tag-highway-cycleway.tag-bridge,
path.line.casing.tag-highway-bridleway.tag-bridge {
    stroke-width: 10;
}

.low-zoom path.line.shadow.tag-railway.tag-bridge,
.low-zoom path.line.shadow.tag-highway-living_street.tag-bridge,
.low-zoom path.line.shadow.tag-highway-path.tag-bridge,
.low-zoom path.line.shadow.tag-highway-corridor.tag-bridge,
.low-zoom path.line.shadow.tag-highway-pedestrian.tag-bridge,
.low-zoom path.line.shadow.tag-highway-service.tag-bridge,
.low-zoom path.line.shadow.tag-highway-track.tag-bridge,
.low-zoom path.line.shadow.tag-highway-steps.tag-bridge,
.low-zoom path.line.shadow.tag-highway-footway.tag-bridge,
.low-zoom path.line.shadow.tag-highway-cycleway.tag-bridge,
.low-zoom path.line.shadow.tag-highway-bridleway.tag-bridge {
    stroke-width: 14;
}
.low-zoom path.line.casing.tag-railway.tag-bridge,
.low-zoom path.line.casing.tag-highway-living_street.tag-bridge,
.low-zoom path.line.casing.tag-highway-path.tag-bridge,
.low-zoom path.line.casing.tag-highway-corridor.tag-bridge,
.low-zoom path.line.casing.tag-highway-pedestrian.tag-bridge,
.low-zoom path.line.casing.tag-highway-service.tag-bridge,
.low-zoom path.line.casing.tag-highway-track.tag-bridge,
.low-zoom path.line.casing.tag-highway-steps.tag-bridge,
.low-zoom path.line.casing.tag-highway-footway.tag-bridge,
.low-zoom path.line.casing.tag-highway-cycleway.tag-bridge,
.low-zoom path.line.casing.tag-highway-bridleway.tag-bridge {
    stroke-width: 6;
}


/* tunnels */
path.line.stroke.tag-tunnel,
path.line.stroke.tag-location-underground,
path.line.stroke.tag-location-underwater {
    stroke-opacity: 0.3;
}
path.line.casing.tag-tunnel,
path.line.casing.tag-location-underground,
path.line.stroke.tag-location-underwater {
    stroke-opacity: 0.5;
    stroke-linecap: butt;
    stroke-dasharray: none;
}


/* embankments / cuttings */
path.line.shadow.tag-embankment,
path.line.shadow.tag-cutting {
    stroke-width: 28;
}
path.line.casing.tag-embankment,
path.line.casing.tag-cutting {
    stroke-opacity: 0.5;
    stroke: #000;
    stroke-width: 22;
    stroke-dasharray: 2, 4;
    stroke-linecap: butt;
}

.low-zoom path.line.shadow.tag-embankment,
.low-zoom path.line.shadow.tag-cutting {
    stroke-width: 14;
}
.low-zoom path.line.casing.tag-embankment,
.low-zoom path.line.casing.tag-cutting {
    stroke-width: 10;
}


/* Surface - unpaved */
path.line.casing.tag-unpaved {
    stroke: #ccc;
    stroke-linecap: butt;
    stroke-dasharray: 4, 3;
}
.low-zoom path.line.casing.tag-unpaved {
    stroke-dasharray: 3, 2;
}
path.line.casing.tag-bridge.tag-unpaved {
    stroke: #000;
    stroke-dasharray: 4, 3;
}
.low-zoom path.line.casing.tag-bridge.tag-unpaved {
    stroke: #000;
    stroke-dasharray: 3, 2;
}


/* Status (e.g. proposed, abandoned) */
path.area.stroke.tag-status,
path.line.stroke.tag-status,
path.area.casing.tag-status,
path.line.casing.tag-status {
    stroke-linecap: butt;
    stroke-dasharray: 7, 3;
}
.low-zoom path.area.stroke.tag-status,
.low-zoom path.line.stroke.tag-status,
.low-zoom path.area.casing.tag-status,
.low-zoom path.line.casing.tag-status {
    stroke-dasharray: 5, 2;
}

/* Road Closed Status */
.preset-icon .icon.tag-highway.tag-status-construction {
    color: #fc6c14;
    fill: #fff;
}
path.line.shadow.tag-highway.tag-status.tag-status-construction {
    stroke-width: 20;
}
path.line.casing.tag-highway.tag-status.tag-status-construction {
    stroke-width: 10;
    stroke-linecap: butt;
    stroke-dasharray: none
}
path.line.stroke.tag-highway.tag-status.tag-status-construction {
    stroke-width: 8;
    stroke-linecap: butt;
    stroke-dasharray: 10, 10;
}
path.line.casing.tag-highway.tag-status.tag-status-construction,
.preset-icon-container path.line.stroke.tag-highway.tag-status.tag-status-construction {
    stroke: #fff;
}
path.line.stroke.tag-highway.tag-status.tag-status-construction,
.preset-icon-container path.line.casing.tag-highway.tag-status.tag-status-construction {
    stroke: #fc6c14;
}
.low-zoom path.line.shadow.tag-highway.tag-status.tag-status-construction {
    stroke-width: 16;
}
.low-zoom path.line.casing.tag-highway.tag-status.tag-status-construction {
    stroke-width: 7;
}
.low-zoom path.line.stroke.tag-highway.tag-status.tag-status-construction {
    stroke-width: 5;
    stroke-dasharray: 8, 8;
}


/* Buildings */
path.stroke.tag-building {
    stroke: rgb(224, 110, 95);
}
path.fill.tag-building {
    stroke: rgba(224, 110, 95, 0.3);
    fill: rgba(224, 110, 95, 0.3);
}
/* Cursors */

.nope,
.nope * {
    cursor: not-allowed !important;
}

.map-in-map,
#map {
    cursor: auto; /* Opera */
    cursor: url(img/cursor-grab.png) 9 9, auto; /* FF */
}

.mode-browse .point,
.mode-select .point {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-point.png), pointer; /* FF */
}

.mode-select .vertex,
.mode-browse .vertex {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-vertex.png), pointer; /* FF */
}

.mode-browse .line,
.mode-select .line {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-line.png), pointer; /* FF */
}

.mode-select .area,
.mode-browse .area {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-area.png), pointer; /* FF */
}

.mode-select .midpoint,
.mode-browse .midpoint {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-split.png), pointer; /* FF */
}

.mode-select .behavior-multiselect .point,
.mode-select .behavior-multiselect .vertex,
.mode-select .behavior-multiselect .line,
.mode-select .behavior-multiselect .area {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-add.png), pointer; /* FF */
}

.mode-select .behavior-multiselect .selected {
    cursor: pointer; /* Opera */
    cursor: url(img/cursor-select-remove.png), pointer; /* FF */
}

.mode-add-preset #map,
.mode-draw-line #map,
.mode-draw-area #map,
.mode-add-line  #map,
.mode-add-area  #map,
.mode-drag-node #map,
.mode-drag-note #map {
    cursor: crosshair; /* Opera */
    cursor: url(img/cursor-draw.png) 9 9, crosshair; /* FF */
}

.mode-draw-line .way.target,
.mode-draw-area .way.target,
.mode-add-line  .way.target,
.mode-add-area  .way.target,
.mode-drag-node .way.target {
    cursor: crosshair; /* Opera */
    cursor: url(img/cursor-draw-connect-line.png) 9 9, crosshair; /* FF */
}

.mode-draw-line .vertex.target,
.mode-draw-area .vertex.target,
.mode-add-line  .vertex.target,
.mode-add-area  .vertex.target,
.mode-drag-node .vertex.target {
    cursor: crosshair; /* Opera */
    cursor: url(img/cursor-draw-connect-vertex.png) 9 9, crosshair; /* FF */
}

.mode-add-point #map,
.mode-add-note #map,
.mode-browse.lasso #map,
.mode-browse.lasso .way,
.mode-browse.lasso .vertex,
.mode-browse.lasso .midpoint,
.mode-select.lasso #map,
.mode-select.lasso .way,
.mode-select.lasso .vertex,
.mode-select.lasso .midpoint {
    cursor: crosshair; /* Opera */
    cursor: url(img/cursor-draw.png) 9 9, crosshair; /* FF */
}

.mode-browse .note,
.mode-browse .qa_error,
.mode-select .note,
.mode-select .qa_error,
.turn rect,
.turn circle {
    cursor: pointer;
}
/* photo viewer div */
#photoviewer {
    position: relative;
    flex-shrink: 0;
    margin-bottom: 10px;
    width: 330px;
    height: 250px;
    padding: 5px;
    background-color: #fff;
}
[dir='ltr'] #photoviewer {
    margin-left: 10px;
    margin-right: 2px;
}
[dir='rtl'] #photoviewer {
    margin-right: 10px;
    margin-left: 2px;
}

@media screen and (min-width: 1600px) {
    #photoviewer {
        width: 490px;
        height: 370px;
    }
}

#photoviewer button.thumb-hide {
    border-radius: 0;
    padding: 5px;
    position: absolute;
    right: 5px;
    top: 5px;
    z-index: 50;
}

#photoviewer button.resize-handle-xy {
    border-radius: 0;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 49;
    cursor: nesw-resize;
    height: 25px;
    width: 25px;
}

#photoviewer button.resize-handle-x {
    border-radius: 0;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 48;
    cursor: ew-resize;
    height: auto;
    width: 6px;
}

#photoviewer button.resize-handle-y {
    border-radius: 0;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 48;
    cursor: ns-resize;
    height: 6px;
    width: 100%;
}


.photo-wrapper,
.photo-wrapper img {
    width: 100%;
    height: 100%;
    overflow: hidden;
    object-fit: cover;
}

.photo-wrapper .photo-attribution {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    font-size: 10px;
    text-align: right;
    line-height: 1.1em;
    padding: 4px 2px;
    z-index: 10;
}

.photo-attribution a,
.photo-attribution a:visited,
.photo-attribution span {
    padding: 4px 2px;
    color: #fff;
}

/* markers and sequences */
.viewfield-group {
    pointer-events: none;
}
.mode-browse .viewfield-group,
.mode-select .viewfield-group {
    pointer-events: visible;
    cursor: pointer;
}

.viewfield-group.currentView * {
    fill: #ffee00 !important;
}
.viewfield-group.hovered * {
    fill: #eebb00 !important;
}

.viewfield-group circle {
    stroke: #555;
    stroke-width: 1;
    stroke-opacity: 0.4;
    fill-opacity: 0.4;
}
.viewfield-group.highlighted circle {
    stroke: #222;
    stroke-opacity: 0.9;
    fill-opacity: 0.9;
}
.viewfield-group.highlighted.hovered circle {
    stroke: #222;
    stroke-width: 2;
    stroke-opacity: 0.9;
    fill-opacity: 0.9;
}
.viewfield-group.highlighted.currentView circle {
    stroke: #222;
    stroke-width: 2;
    stroke-opacity: 1;
    fill-opacity: 1;
}

.viewfield-group .viewfield {
    stroke-width: 0;
    stroke: #222;
    fill-opacity: 0.4;
}
.viewfield-group.highlighted .viewfield {
    stroke-width: 1;
    fill-opacity: 0.8;
}
.viewfield-group.highlighted.hovered .viewfield {
    stroke-width: 1;
    fill-opacity: 0.8;
}
.viewfield-group.highlighted.currentView .viewfield {
    stroke-width: 1;
    fill-opacity: 0.9;
}

.viewfield-group.currentView .viewfield-scale {
    transform: scale(2,2);
}

.sequence {
    fill: none;
    stroke-width: 2;
    stroke-opacity: 0.4;
}
.sequence.highlighted,
.sequence.currentView {
    stroke-width: 4;
    stroke-opacity: 1;
}


/* Streetside Image Layer */
.layer-streetside-images {
    pointer-events: none;
}
.layer-streetside-images .viewfield-group * {
    fill: #0fffc4;
}
.layer-streetside-images .sequence {
    stroke: #0fffc4;
    stroke-opacity: 0.85;  /* bump opacity - only one per road */
}


/* Mapillary Image Layer */
.layer-mapillary {
    pointer-events: none;
}
.layer-mapillary .viewfield-group * {
    fill: #55ff22;
}
.layer-mapillary .sequence {
    stroke: #55ff22;
}


/* Mapillary Traffic Signs and Map Features Layers */
.layer-mapillary-detections {
    pointer-events: none;
}
.layer-mapillary-detections .icon-detected {
    outline: 2px solid transparent;
    pointer-events: visible;
    cursor: pointer;
    opacity: 0.75;
}
.layer-mapillary-detections .icon-detected rect {
    fill: none;
}
.layer-mapillary-detections .icon-detected:hover rect {
    outline: 3px solid rgba(255, 238, 0, 0.6);
}
.layer-mapillary-detections .icon-detected.currentView rect {
    outline: 3px solid rgba(255, 238, 0, 1);
}
.layer-mapillary-detections .icon-detected:hover,
.layer-mapillary-detections .icon-detected.currentView {
    opacity: 1;
}


/* OpenStreetCam Image Layer */
.layer-openstreetcam {
    pointer-events: none;
}
.layer-openstreetcam .viewfield-group * {
    fill: #20c4ff;
}
.layer-openstreetcam .sequence {
    stroke: #20c4ff;
}


/* Streetside Viewer (pannellum) */
.ms-wrapper .photo-attribution .image-link {
    display: block;
}
.ms-wrapper .photo-attribution .attribution-row {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
    padding: 0 5px;
}
.ms-wrapper .photo-attribution .image-view-link {
    text-align: left;
    margin: 0 5px;
}
.ms-wrapper .photo-attribution .image-report-link {
    text-align: right;
}

.ms-wrapper .photo-attribution a:active,
.ms-wrapper .photo-attribution a:hover {
    color: #0fffc4;
}

.ms-wrapper .pnlm-compass.pnlm-control {
    width: 26px;
    height: 26px;
    left: 4px;
    top: 60px;
    background-size: contain;
    background-repeat: no-repeat no-repeat;
}

label.streetside-hires {
    cursor: pointer;
}
.streetside-hires span {
    margin-top: 2px;
}
.streetside-hires input[type="checkbox"] {
    float: left;
    width: 12px;
    height: 12px;
    margin: 0 5px;
}


/* Mapillary viewer */
#mly .domRenderer .TagSymbol {
    font-size: 10px;
    background-color: rgba(0,0,0,0.4);
    padding: 0 4px;
    border-radius: 4px;
    top: -25px;
}
#mly .domRenderer .Attribution {
    /* we will roll our own to avoid async update issues like #4526 */
    display: none;
}

.mly-wrapper .photo-attribution a:active,
.mly-wrapper .photo-attribution a:hover {
    color: #35af6d;
}

.mly-wrapper .mapillary-js-dom {
    z-index: 9;
}


/* OpenStreetCam viewer */
.osc-wrapper {
    position: relative;
    background-color: #000;
    background-image: url(img/loader-black.gif);
    background-position: center;
    background-repeat: no-repeat;
}

.osc-wrapper .photo-attribution a:active,
.osc-wrapper .photo-attribution a:hover {
    color: #20c4ff;
}

.osc-image-wrap {
    width: 100%;
    height: 100%;
    transform-origin:0 0;
    -ms-transform-origin:0 0;
    -webkit-transform-origin:0 0;
    -moz-transform-origin:0 0;
    -o-transform-origin:0 0;
}


/* photo-controls (step forward, back, rotate) */
.photo-controls-wrap {
    text-align: center;
    position: absolute;
    top: 10px;
    width: 100%;
    z-index: 10;
}

.photo-controls {
    display: inline-block;
    z-index: 10;
}

.photo-controls button,
.photo-controls button:focus {
    height: 18px;
    width: 18px;
    background: rgba(0,0,0,0.65);
    color: #eee;
    border-radius: 0;
}
.photo-controls button:first-of-type {
    border-radius: 3px 0 0 3px;
}
.photo-controls button:last-of-type {
    border-radius: 0 3px 3px 0;
}
.photo-controls button:hover,
.photo-controls button:active {
    background: rgba(0,0,0,0.85);
    color: #fff;
}

/* OSM Notes and KeepRight Layers */

.error-header-icon .qa_error-fill,
.layer-keepRight .qa_error .qa_error-fill,
.layer-improveOSM .qa_error .qa_error-fill {
    stroke: #333;
    stroke-width: 1.3px;  /* NOTE: likely a better way to scale the icon stroke */
}

.note-header-icon .note-fill,
.layer-notes .note .note-fill {
    color: #f30;
    stroke: #333;
    stroke-width: 40px;
}
.note-header-icon.new .note-fill,
.layer-notes .note.new .note-fill {
    color: #fe0;
    stroke: #333;
    stroke-width: 40px;
}
.note-header-icon.closed .note-fill,
.layer-notes .note.closed .note-fill {
    color: #5d0;
    stroke: #333;
    stroke-width: 40px;
}

/* slight adjustments to preset icon for note icons */
.note-header-icon .preset-icon-28 {
    top: 18px;
}
.note-header-icon .note-icon-annotation {
    position: absolute;
    top: 22px;
    left: 22px;
    margin: auto;
}
.note-header-icon .note-icon-annotation .icon {
    width: 15px;
    height: 15px;
}

/* adjustment for error icon */

.error-header-icon .preset-icon-28 {
    top: auto;
    left: auto;
}

.error-header-icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Keep Right Errors
------------------------------------------------------- */
.keepRight.error_type-20,     /* multiple nodes on same spot */
.keepRight.error_type-40,     /* impossible oneways */
.keepRight.error_type-210,    /* self intersecting ways */
.keepRight.error_type-270,    /* unusual motorway connection */
.keepRight.error_type-310,    /* roundabout issues */
.keepRight.error_type-320,    /* improper _link */
.keepRight.error_type-350 {   /* improper bridge tag */
    color: #ff9;
}

.keepRight.error_type-50 {    /* almost junctions */
    color: #88f;
}

.keepRight.error_type-60,     /* deprecated tags */
.keepRight.error_type-70,     /* tagging issues */
.keepRight.error_type-90,     /* motorway without ref */
.keepRight.error_type-100,    /* place of worship without religion */
.keepRight.error_type-110,    /* poi without name */
.keepRight.error_type-150,    /* railway crossing without tag */
.keepRight.error_type-220,    /* misspelled tag */
.keepRight.error_type-380 {   /* non-physical sport tag */
    color: #5d0;
}

.keepRight.error_type-130 {   /* disconnected ways */
    color: #fa3;
}

.keepRight.error_type-170 {   /* FIXME tag */
    color: #ff0;
}

.keepRight.error_type-190 {   /* intersection without junction */
    color: #f33;
}

.keepRight.error_type-200 {   /* overlapping ways */
    color: #fdbf6f;
}

.keepRight.error_type-160,    /* railway layer conflict */
.keepRight.error_type-230 {   /* layer conflict */
    color: #b60;
}

.keepRight.error_type-280 {   /* boundary issues */
    color: #5f47a0;
}

.keepRight.error_type-180,    /* relation without type */
.keepRight.error_type-290 {   /* turn restriction issues */
    color: #ace;
}

.keepRight.error_type-300,    /* missing maxspeed */
.keepRight.error_type-390 {   /* missing tracktype */
    color: #090;
}

.keepRight.error_type-360,    /* language unknown */
.keepRight.error_type-370,    /* doubled places */
.keepRight.error_type-410 {   /* website issues */
    color: #f9b;
}

.keepRight.error_type-120,    /* way without nodes */
.keepRight.error_type-400 {   /* geometry / turn angles */
    color: #c35;
}

/* ImproveOSM Errors
------------------------------------------------------- */

.improveOSM.error_type-ow {   /* missing one way */
    color: #1E90FF;
}

.improveOSM.error_type-mr-road {   /* missing road */
    color: #B452CD;
}
.improveOSM.error_type-mr-path {   /* missing path */
    color: #A0522D;
}
.improveOSM.error_type-mr-parking {   /* missing parking */
    color: #EEEE00;
}
.improveOSM.error_type-mr-both {   /* missing road+parking */
    color: #FFA500;
}

.improveOSM.error_type-tr {   /* missing turn restriction */
    color: #EC1C24;
}


/* Custom Map Data (geojson, gpx, kml, vector tile) */
.layer-mapdata {
    pointer-events: none;
}

.layer-mapdata path.shadow {
    pointer-events: stroke;
    stroke: #f6634f;
    stroke-width: 16;
    stroke-opacity: 0;
    fill: none;
}
.layer-mapdata path.MultiPoint.shadow,
.layer-mapdata path.Point.shadow {
    pointer-events: fill;
    fill: #f6634f;
    fill-opacity: 0;
}
.layer-mapdata path.shadow.hover:not(.selected) {
    stroke-opacity: 0.4;
}
.layer-mapdata path.shadow.selected {
    stroke-opacity: 0.7;
}

.layer-mapdata path.stroke {
    stroke: #ff26d4;
    stroke-width: 2;
    fill: none;
}

.layer-mapdata path.fill {
    stroke-width: 0;
    stroke-opacity: 0.3;
    stroke: #ff26d4;
    fill: #ff26d4;
    fill-opacity: 0.3;
    fill-rule: evenodd;
}

.layer-mapdata text.label-halo,
.layer-mapdata text.label {
    font-size: 10px;
    font-weight: bold;
    dominant-baseline: middle;
}
.layer-mapdata text.label {
    fill: #ff26d4;
}
.layer-mapdata text.label.hover,
.layer-mapdata text.label.selected {
    fill: #f6634f;
}
.layer-mapdata text.label-halo {
    opacity: 0.7;
    stroke: #000;
    stroke-width: 5px;
    stroke-miterlimit: 1;
}
/* Fill Styles */

.low-zoom.fill-wireframe path.stroke,
.fill-wireframe path.stroke {
    stroke-width: 1 !important;
    stroke-opacity: 0.5 !important;
    stroke-dasharray: none !important;
    fill: none !important;
}
.low-zoom.fill-wireframe .layer-mapdata path.stroke,
.fill-wireframe .layer-mapdata path.stroke {
    stroke-width: 2 !important;
    stroke-opacity: 1 !important;
}

.low-zoom.fill-wireframe path.shadow,
.fill-wireframe path.shadow {
    stroke-width: 12;
}

.fill-wireframe path.shadow.related:not(.selected),
.fill-wireframe path.shadow.hover:not(.selected) {
    stroke-opacity: 0.4;
}
.fill-wireframe path.shadow.selected {
    stroke-opacity: 0.6;
}

.fill-wireframe .point,
.fill-wireframe .areaicon,
.fill-wireframe .areaicon-halo,
.fill-wireframe path.casing,
.fill-wireframe path.fill,
.fill-wireframe path.oneway {
    display: none !important;
}

.fill-partial path.area.fill {
    fill-opacity: 0;
    stroke-width: 60px;
    pointer-events: none;
}
.fill-partial path.area.fill.tag-building_part {
    stroke-width: 40px;
}
.fill-partial path.area.fill.tag-indoor {
    stroke-width: 20px;
}
.mode-browse .fill-partial path.area.fill,
.mode-select .fill-partial path.area.fill {
    pointer-events: visibleStroke;
}
/* Basics
------------------------------------------------------- */
/*
  Opera misbehaves when the window is resized vertically unless 100% width + height are
  applied to both html and body. https://gist.github.com/jfirebaugh/bd225bcfdd3a633850c4
*/
html, body {
    width: 100%;
    height: 100%;
}

body {
    font: normal 12px/1.6667 "-apple-system", BlinkMacSystemFont,
        "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell",
        "Fira Sans", "Droid Sans", "Helvetica Neue", "Arial",
        sans-serif;
    margin: 0;
    padding: 0;
    color: #333;
    overflow: hidden;
    -ms-user-select: none;
    -ms-content-zooming: none;
}

.unsupported {
    text-align: center;
    vertical-align: middle;
    padding-top: 100px;
    font-size: 15px;
}

.id-container {
    height: 100%;
    width: 100%;
}

#content {
    position: relative;
    overflow: hidden;
    height: 100%;
}

#content.active {
    -webkit-filter: none !important;
    filter: none !important;
    -webkit-duration: 200ms;
    transition-duration: 200ms;
}

#content.inactive {
    -webkit-filter: grayscale(80%) brightness(80%);
    filter: grayscale(80%) brightness(80%);
    -webkit-duration: 200ms;
    transition-duration: 200ms;
}

#defs {
    /* Can't be display: none or the clippaths are ignored. */
    position: absolute;
    width: 0;
    height: 0;
}

div, textarea, label, input, form, span, ul, li, ol, a, button, h1, h2, h3, h4, h5, p, img {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

a, button, input, textarea {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    -webkit-touch-callout: none;
}

ul li {
    list-style: none;
}

a,
button,
.radial-menu-item {
    cursor: pointer;
}

h2 {
    font-size: 25px;
    line-height: 1.25;
    font-weight: bold;
    margin-bottom: 20px;
}

h3:last-child,
h2:last-child,
h4:last-child { margin-bottom: 0;}

h3 {
    font-size: 16px;
    line-height: 1.25;
    font-weight: bold;
    margin-bottom: 10px;
}
h4, h5 {
    font-size: 12px;
    font-weight: bold;
    padding-bottom: 10px;
}

:focus {
    outline-color: transparent;
    outline-style: none;
}

::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #aaa;
    opacity: 1; /* Firefox */
}
:-ms-input-placeholder { /* Internet Explorer 10-11 */
    color: #aaa;
}
::-ms-input-placeholder { /* Microsoft Edge */
    color: #aaa;
}

p {
    font-size: 12px;
    margin: 0;
    padding: 0;
}
p:last-child {
    padding-bottom: 0;
}
em {
    font-style: italic;
}
strong {
    font-weight: bold;
}
a:visited, a {
    color: #7092ff;
}
a:hover {
    color: #597be7;
}
kbd {
    display: inline-block;
    text-align: center;
    padding: 3px 5px;
    font-size: 11px;
    line-height: 12px;
    min-width: 12px;
    vertical-align: baseline;
    background-color: #fcfcfc;
    border: solid 1px #ccc;
    margin: 0 2px;
    border-bottom-color: #bbb;
    border-radius: 3px;
    box-shadow: inset 0 -1px 0 #bbb;
}

/* Forms
------------------------------------------------------- */
textarea  {
    resize: vertical;
    font:normal 12px/20px "-apple-system", BlinkMacSystemFont,
        "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell",
        "Fira Sans", "Droid Sans", "Helvetica Neue", "Arial",
        sans-serif;
}

textarea,
input[type=text],
input[type=search],
input[type=number],
input[type=url],
input[type=tel],
input[type=email] {
    background-color: #fff;
    color: #333;
    border: 1px solid #ccc;
    padding: 5px 20px 5px 10px;
    height: 30px;
    border-radius: 4px;
    text-overflow: ellipsis;
}
[dir='rtl'] textarea,
[dir='rtl'] input[type=text],
[dir='rtl'] input[type=search],
[dir='rtl'] input[type=number],
[dir='rtl'] input[type=url],
[dir='rtl'] input[type=tel],
[dir='rtl'] input[type=email] {
    padding: 5px 10px 5px 20px;
}

textarea:focus,
input:focus {
    background-color: #f1f1f1;
}

textarea.disabled,
input.disabled {
    color: #777;
    background-color: #eee;
    cursor: not-allowed;
}

input[type="checkbox"],
input[type="radio"] {
    float: left;
    width: 14px;
    height: 14px;
    margin-right: 5px;
    margin-top: 3px;
    cursor: pointer;
}
[dir='rtl'] input[type="checkbox"],
[dir='rtl'] input[type="radio"] {
    float: right;
    margin-left: 5px;
    margin-right: 0;
}

/* tables */
table {
    background-color: #fff;
    border-collapse: collapse;
    width: 100%;
    border-spacing: 0;
}
table th {
    text-align: left;
}
table.tags, table.tags td, table.tags th {
    border: 1px solid #ccc;
    padding: 4px;
}

::-ms-clear {
   display: none;
}

/* Grid
------------------------------------------------------- */
.col6  { float: left; width: 50.0000%; max-width: 600px; }
.col12 { float: left; width: 100.0000%; }


/* Utility Classes
------------------------------------------------------- */
.fillL {
    background: #fff;
    color: #333;
}
.fillL2 {
    background: #f6f6f6;
    color: #333;
}
.fillL3 {
    background: #ececec;
    color: #333;
}
.fillD {
    background: rgba(0,0,0,.5);
    color: #fff;
}
.fillD2 {
    background: rgba(0,0,0,.75);
    color: #fff;
}

.fl { float: left;}
.fr { float: right;}
.al { left: 0; }
.ar { right: 0; }

input.hide,
textarea.hide,
div.hide,
form.hide,
button.hide,
a.hide,
ul.hide,
li.hide {
    display: none;
}

.deemphasize {
    color: #a9a9a9;
}
.content {
    box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.25);
}
.loading {
    background: url(img/loader_bg.gif);
    background-size: 5px 5px;
}


/* Buttons
------------------------------------------------------- */
button {
    text-align: center;
    line-height: 20px;
    border: 0;
    background: #fff;
    font-weight: bold;
    color: #333;
    font-size: 12px;
    display: inline-block;
    height: 40px;
    border-radius: 4px;
}

button:focus,
button:hover {
    background-color: #ececec;
}
button.active {
    background: #7092ff;
}
button.disabled {
    background-color: rgba(255,255,255,.25);
    color: rgba(0,0,0,.4);
    cursor: not-allowed;
}

.joined > * {
    border-radius: 0;
    border-right: 1px solid rgba(0,0,0,.5);
}
[dir='rtl'] .joined > * {
    border-left: 1px solid rgba(0,0,0,.5);
    border-right: none;
}

.fillL .joined > * {
    border-right: 1px solid #fff;
}
.joined > *:first-child {
    border-radius: 4px 0 0 4px;
}
[dir='rtl'] .joined > *:first-child {
    border-radius: 0 4px 4px 0;
}
.joined > *:last-child {
    border-right-width: 0;
    border-radius: 0 4px 4px 0;
}
[dir='rtl'] .joined > *.bar-button:last-child {
    border-radius: 4px 0 0 4px;
}


/* Action buttons */
button.action {
    background: #7092ff;
    color: #fff;
}
button.action:focus,
button.action:hover {
    background: #597be7;
}
button.secondary-action {
    background: #ececec;
}
button.secondary-action:focus,
button.secondary-action:hover {
    background: #cccccc;
}

button.action.disabled,
button.action.disabled:hover,
button[disabled].action,
button[disabled].action:hover {
    background: #cccccc;
    color: #888;
    cursor: not-allowed;
}


/* Icons
------------------------------------------------------- */
.icon {
    vertical-align: top;
    width: 20px;
    height: 20px;
}

.icon.inline {
    vertical-align: text-top;
    width: 14px;
    height: 14px;
    margin: 0px 3px;
}

.icon.pre-text {
    margin-right: 5px;
}
[dir='rtl'] .icon.pre-text {
    margin-left: 5px;
    margin-right: 0;
}

.icon.pre-text.user-icon {
    margin-left: 5px;
    margin-right: 5px;
}

.icon.light {
    color: #fff;
}
.icon.created {
    color: #00ca07;
}
.icon.modified {
    color: #666;
}
.icon.deleted {
    color: #ea0000;
}

.user-icon {
    max-height: 20px;
    max-width: 20px;
    height: auto;
    width: auto;
    border-radius: 3px;
}

.icon-annotation {
    color: #333;
}

.notification-badge {
    display: block;
    position: absolute;
    width: 10px;
    height: 10px;
    right: 7px;
    top: 9px;
}

.notification-badge.hide {
    display: none;
}


/* Toolbar / Persistent UI Elements
------------------------------------------------------- */
#bar-wrap {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    z-index: 101;
}
#bar {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    padding: 10px 0 0 0;
    overflow-x: auto;
    overflow-y: hidden;
    height: 100%;
    width: 100%;

    /* hide scrollbar but allow scrolling */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE, Edge */
}
#bar::-webkit-scrollbar {
    display: none; /* Chrome, Safari, Opera */
}
#bar .toolbar-item {
    display: flex;
    flex: 0 1 auto;
    flex-flow: column wrap;
    justify-content: center;
}
#bar .toolbar-item .item-content {
    display: flex;
    flex: 0 1 auto;
    flex-flow: row nowrap;
    justify-content: center;
    height: 40px;
    width: auto;
    margin: 0 5px;
}
[dir='ltr'] #bar .toolbar-item:last-child .item-content,
[dir='rtl'] #bar .toolbar-item:first-child .item-content {
    margin-right: 10px;
}
[dir='ltr'] #bar .toolbar-item:first-child .item-content,
[dir='rtl'] #bar .toolbar-item:last-child .item-content {
    margin-left: 10px;
}
#bar .toolbar-item .item-label {
    text-align: center;
    font-size: 11px;
    white-space: nowrap;
    margin: 1px 2px 2px 2px;
}
#bar .toolbar-item.spacer {
    width: 100%;
    flex-grow: 2;
}
#bar .toolbar-item:first-child {
    justify-content: flex-start;
}
#bar .toolbar-item:last-child {
    justify-content: flex-end;
}
#bar .toolbar-item:empty:not(.spacer) {
    display: none;
}
button.bar-button {
    flex: 0 0 auto;
    flex-flow: row nowrap;
    align-items: center;
    padding: 0 10px;
    min-width: 30px;
    white-space: nowrap;
    display: flex;
}
button.bar-button .icon {
    flex: 0 0 20px;
}
button.bar-button .label {
    flex: 0 1 auto;
    padding: 0 5px;
}

button.bar-button.dragging {
    opacity: 0.75;
    z-index: 200;
}
button.bar-button.dragging .tooltip {
    display: none;
}
button.bar-button.dragging.removing {
    cursor: url(img/cursor-select-remove.png), pointer;
}

button.save .count {
    display: inline-block;
    min-width: 32px;
    text-align: center;
}

.help-wrap svg.icon.pre-text.add-note,
button.add-note svg.icon {
    height: 15px;
    width: 15px;
    color: rgba(0,0,0,0.25);
    stroke: #333;
    stroke-width: 60px;
    margin-top: 3px;
}
button.add-note svg.icon {
    margin-left: unset;
    margin-right: 4px;
}
[dir='rtl'] button.add-note svg.icon {
    margin-left: 4px;
    margin-right: unset;
}
.help-wrap svg.icon.pre-text.add-note {
    margin-left: 3px;
    margin-right: 3px;
}

.spinner {
    opacity: .5;
    position: absolute;
    right: 4px;
    bottom: 26px;
}
.spinner img {
    height: 20px;
    width: 20px;
    background: transparent;
    border-radius: 100%;
}
[dir='rtl'] .spinner img {
    -moz-transform: scaleX(-1);
    -o-transform: scaleX(-1);
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
    filter: FlipH;
    -ms-filter: "FlipH";
}


#bar.narrow .spinner,
#bar.narrow button.bar-button .label {
    display: none;
}
#bar.narrow button .count {
    border-left-width: 0;
    border-right-width: 0;
}

[dir='ltr'] .undo-redo button:first-of-type {
    margin-right: 1px;
}
[dir='rtl'] .undo-redo button:first-of-type {
    margin-left: 1px;
}

/* Header for modals / panes
------------------------------------------------------- */
.header {
    border-bottom: 1px solid #ccc;
    height: 60px;
    position: relative;
}

.header h3 {
    text-align: center;
    margin-bottom: 0;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    padding: 20px;
}

.header button,
.modal > button {
    border-radius: 0;
    width: 40px;
    text-align: center;
    overflow: hidden;
}

.header button {
    position: relative;
    height: 100%;
}

.field-help-title button.close,
.sidebar-component .header button.data-editor-close,
.sidebar-component .header button.note-editor-close,
.sidebar-component .header button.error-editor-close,
.entity-editor-pane .header button.preset-close,
.preset-list-pane .header button.preset-choose {
    position: absolute;
    right: 0;
    top: 0;
}
[dir='rtl'] .field-help-title button.close,
[dir='rtl'] .sidebar-component .header button.data-editor-close,
[dir='rtl'] .sidebar-component .header button.note-editor-close,
[dir='rtl'] .sidebar-component .header button.error-editor-close,
[dir='rtl'] .entity-editor-pane .header button.preset-close,
[dir='rtl'] .preset-list-pane .header button.preset-choose {
    left: 0;
    right: auto;
}

.entity-editor-pane .header button.preset-choose {
    position: absolute;
    left: 0;
    top: 0;
}
[dir='rtl'] .entity-editor-pane .header button.preset-choose {
    left: auto;
    right: 0;
}

.preset-choose {
    font-size: 16px;
    line-height: 1.25;
    font-weight: bold;
}

.modal > button {
    position: absolute;
    right: 0;
    top: 0;
    height: 59px;
    z-index: 50;
}
[dir='rtl'] .modal > button {
    left: 0;
    right: unset;
}

.footer {
    position: absolute;
    bottom: 0;
    margin: 0;
    padding: 5px 20px 5px 20px;
    border-top: 1px solid #ccc;
    background-color: #f6f6f6;
    width: 100%;
    z-index: 1;
    flex-wrap: wrap;
    justify-content: space-between;
    list-style: none;
    display: flex;
}

.footer > a {
    justify-content: center;
}

.header-container {
    display: flex;
    justify-content: space-between;
}

.header-block-outer {
    width: 20%;
}

.header-block-close {
    display: flex;
    justify-content: flex-end;
}

/* Hide/Toggle collapsable sections (aka Disclosure)
------------------------------------------------------- */
.hide-toggle .icon.pre-text {
    vertical-align: text-top;
    width: 16px;
    height: 16px;
    margin-left: -3px;
}
[dir='rtl'] .hide-toggle .icon.pre-text {
    margin-left: 0;
    margin-right: -3px;
}

a:visited.hide-toggle,
a.hide-toggle {
    display: inline-block;
    font-size: 14px;
    font-weight: bold;
    padding-bottom: 5px;
}


/* Sidebar / Inspector
------------------------------------------------------- */
#sidebar {
    position: relative;
    float: left;
    height: 100%;
    z-index: 10;
    background: #f6f6f6;
    -ms-user-select: element;
    border: 0px solid #ccc;
    border-right-width: 1px;
}
[dir='rtl'] #sidebar {
    float: right;
    border-right-width: 0px;
    border-left-width: 1px;
}

#sidebar-resizer {
    position: absolute;
    top: 0;
    right: -6px;
    height: 100%;
    width: 6px;
    cursor: col-resize;
}
[dir='rtl'] #sidebar-resizer {
    right: auto;
    left: -6px;
}

#sidebar.collapsed #sidebar-resizer {
    /* make target wider to avoid the user accidentally resizing window */
    width: 10px;
    right: -10px;
}
[dir='rtl'] #sidebar.collapsed #sidebar-resizer {
    left: -10px;
}

.sidebar-component {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.sidebar-component .body {
    width: 100%;
    overflow: auto;
    top: 60px;
    bottom: 0;
    position: absolute;
}

.panewrap {
    position: absolute;
    width: 200%;
    height: 100%;
    right: -100%;
}

.pane {
    position: absolute;
    width: 50%;
    top: 0;
    bottom: 30px;
}

.pane:first-child {
    left: 0;
}

.pane:last-child {
    right: 0;
}

.inspector-wrap {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
}

.inspector-hidden {
    display: none;
}

.inspector-body {
    overflow-y: scroll;
    overflow-x: hidden;
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
}

.feature-list-pane .inspector-body,
.preset-list-pane .inspector-body {
    top: 120px;
}
.entity-editor-pane .inspector-body,
.selection-list-pane .inspector-body {
    top: 60px;
}

.inspector-inner {
    padding: 20px 20px 5px 20px;
    position: relative;
}

#sidebar .search-header .icon {
    display: block;
    position: absolute;
    left: 10px;
    top: 80px;
    pointer-events: none;
}
[dir='rtl'] #sidebar .search-header .icon {
    left: auto;
    right: 10px;
}

#sidebar .search-header input {
    position: absolute;
    top: 60px;
    height: 60px;
    width: 100%;
    padding: 5px 10px;
    border-radius: 0;
    border-width: 0;
    border-bottom-width: 1px;
    text-indent: 30px;
    font-size: 18px;
    font-weight: bold;
}


/* Feature List / Search Results
------------------------------------------------------- */
.feature-list  {
    width: 100%;
}
.no-results-item,
.geocode-item,
.feature-list-item {
    width: 100%;
    position: relative;
    border-bottom: 1px solid #ccc;
    border-radius: 0;
}

.geocode-item {
    width: 50%;
    background-color: #ccc;
    left: 25%;
    margin-top: 30px;
    border-radius: 2px;
}

[dir='rtl'] .geocode-item {
    left: -25%;
}

.geocode-item:hover {
    background-color: #aaa;
}

.feature-list-item {
    background-color: #fff;
    font-weight: bold;
    height: 40px;
    line-height: 20px;
}
.feature-list-item:hover {
    background-color: #ececec;
}
.feature-list-item button {
    background: transparent;
}
.feature-list-item .label {
    text-align: left;
    padding: 10px 10px;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    border-left: 1px solid rgba(0, 0, 0, .1);
}
[dir='rtl'] .feature-list-item .label {
    text-align: right;
}

.feature-list-item .label .icon {
    opacity: .5;
}
.feature-list-item .close {
    float: right;
    padding: 10px;
}
.feature-list-item .close .icon {
    opacity: 1;
}
.feature-list-item .entity-type {
    color: #7092ff;
}
.feature-list-item:hover .entity-type {
    color: #597be7;
}
.feature-list-item .entity-name {
    font-weight: normal;
    color: #666;
    padding-left: 10px;
}
[dir='rtl'] .feature-list-item .entity-name {
    padding-left: 0;
    padding-right: 10px;
}


/* Preset List and Icons
------------------------------------------------------- */
.preset-list  {
    width: 100%;
    padding: 20px 20px 10px 20px;
    border-bottom: 1px solid #ccc;
}

.preset-list-item {
    margin-bottom: 10px;
    position: static;
}

.preset-list-button-wrap {
    height: 62px;
    display: flex;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.preset-list-button {
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
}

.preset-list.filtered .preset-list-item:first-child .preset-list-button {
    background: #ececec;
}

.preset-icon-container {
    position: relative;
    width: 60px;
    height: 60px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}
.preset-icon-container.small {
    width: 40px;
    height: 40px;
    flex: 0 0 auto;
}
.preset-icon-container img.image-icon {
    width: 50px;
    height: 50px;
    object-fit: contain;
    border-radius: 2px;
    z-index: 2;
    visibility: hidden;
}
.preset-icon-container.showing-img img.image-icon {
    visibility: visible;
}
.preset-icon-container.showing-img *:not(.image-icon) {
    visibility: hidden;
}

.preset-icon-point-border path {
    stroke: #333;
    stroke-width: 1.2;
    fill: transparent;
}

.preset-icon-line {
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    height: 100%;
}
.preset-icon-container path {
    cursor: inherit;
}
.preset-icon-container circle.vertex {
    fill: #fff;
    stroke: rgba(0, 0, 0, 0.25);
}
.preset-icon-fill circle.midpoint {
    fill: transparent;
    stroke: rgba(0, 0, 0, 0.25);
}
/* use a consistent stroke width */
.preset-icon-container path.line.stroke {
    stroke-width: 2 !important;
}
.preset-icon-container path.line.casing {
    stroke-width: 4 !important;
}

.preset-icon-fill {
    margin: auto;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}
.preset-icon-container svg,
.preset-icon-container svg > * {
    cursor: inherit !important;
}
.preset-icon-fill path.area.stroke {
    fill: transparent;
}

.preset-icon-fill-vertex circle {
    stroke-width: 1.5px;
    stroke: #333;
    fill: #efefef;
    backface-visibility: hidden;
}

.preset-icon {
    width: 100%;
    height:100%;
    position: absolute;
    z-index: 1;
}
.preset-icon .icon {
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    transform: scale(0.48);
}
.preset-icon-container.small .preset-icon.point-geom .icon {
    transform: translateY(-7%) scale(0.27);
}
.preset-icon-container.small .preset-icon.point-geom.preset-icon-iD .icon {
    transform: translateY(-9%) scale(0.5);
}
.preset-icon.framed .icon {
    transform: scale(0.4);
}
.preset-icon.framed.line-geom .icon,
.preset-icon.framed.route-geom .icon {
    top: 20%;
    transform: translateY(-30%) scale(0.4);
}
.preset-icon-iD .icon {
    transform: scale(1);
}
.preset-icon-iD.framed .icon {
    transform: scale(0.74);
}
.preset-icon-iD.framed.line-geom .icon,
.preset-icon-iD.framed.route-geom .icon {
    transform: translateY(-30%) scale(0.74);
}
.preset-icon-container.fallback .preset-icon .icon {
    transform: scale(0.5) !important;
}

.preset-list-button .label {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    background-color: #f6f6f6;
    text-align: left;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    padding: 5px 10px;
    left: 60px;
    border-left: 1px solid rgba(0, 0, 0, .1);
}
[dir='rtl'] .preset-list-button .label {
    text-align: right;
    left: 0;
    right: 60px;
    border-left: none;
    border-right: 1px solid rgba(0, 0, 0, .1);
}
[dir='ltr'] .category .preset-list-button .label {
    border-radius: 0px 4px 4px 0px;
}
[dir='rtl'] .category .preset-list-button .label {
    border-radius: 4px 0px 0px 4px;
}

.preset-list-button .label-inner {
    width: 100%;
}
.preset-list-button .label-inner .namepart {
    height: 17px;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}
.preset-list-button .label-inner .namepart:nth-child(2) {
    font-weight: normal;
}

.preset-list-button:hover .label,
.preset-list-button:focus .label,
.preset-list-button.disabled,
.preset-list-button.disabled .label {
    background-color: #ececec;
}

.preset-list-item button.tag-reference-button {
    height: 100%;
    width: 32px;
    flex: 0 0 auto;
    background: #f6f6f6;
}
[dir='ltr'] .preset-list-item button.tag-reference-button {
    border-left: 1px solid #ccc;
}
[dir='rtl'] .preset-list-item button.tag-reference-button {
    border-right: 1px solid #ccc;
}
[dir='ltr'] .preset-list-item button:last-child {
    border-radius: 0 4px 4px 0;
}
[dir='rtl'] .preset-list-item button:last-child {
    border-radius: 4px 0 0 4px;
}

.preset-list-item button.tag-reference-button:hover {
    background: #f1f1f1;
}
.preset-list-item button.tag-reference-button .icon {
    opacity: .5;
}


.current .preset-list-button,
.current .preset-list-button .label {
    background-color: #e8ebff;
}

.category .preset-list-button:after,
.category .preset-list-button:before {
    content: "";
    position: absolute;
    top: -5px;
    left: -1px; right: -1px;
    border: 1px solid #ccc;
    border-bottom: none;
    border-radius: 6px 6px 0 0;
    height: 6px;
}

.category .preset-list-button:before {
    top: -3px;
}

.subgrid .preset-list {
    padding: 10px;
    margin-top: 0;
    border: 0;
    border-radius: 8px;
    width: -webkit-calc(100% + 20px);
    margin-left: -10px;
}
.subgrid .preset-list > *:last-child {
    margin-bottom: 0;
}

.subgrid .arrow {
    border: solid rgba(0, 0, 0, 0);
    border-width: 10px;
    border-bottom-color: #ececec;
    width: 0;
    height: 0;
    margin-left: 50%;
    margin-left: -webkit-calc(50% - 10px);
}


/* Quick links
------------------------------------------------------- */
.quick-links {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-end;
    padding: 0 20px;
}
.quick-link {
    margin: 0 5px;
}

.data-editor .quick-links,
.error-editor .quick-links,
.note-editor .quick-links {
    padding: 5px 0 0 0;
}


/* Entity/Preset Editor
------------------------------------------------------- */
.entity-issues,
.preset-editor {
    overflow: hidden;
    padding: 10px 0px 5px 0px;
}
.entity-issues a.hide-toggle,
.preset-editor a.hide-toggle {
    margin: 0 20px 5px 20px;
}
.entity-issues .disclosure-wrap-entity_issues,
.preset-editor .form-fields-container {
    padding: 10px;
    margin: 0 10px 10px 10px;
    border-radius: 8px;
    background: #ececec;
}
.entity-issues .disclosure-wrap-entity_issues:empty,
.preset-editor .form-fields-container:empty {
    display: none;
}
.entity-editor-pane .preset-list-item {
    margin-bottom: 0;
}

/*
    The parts of a field:
    - `.form-field` is a `div` wraps the entire thing
    - `.field-label` is a `label` that wraps the top part, it contains;
       - `span` classed `label-text`
       - 0..n buttons for "remove", "modified", "tag reference"
    - `.form-field-input-wrap` is a `label` or `div` that wraps the bottom part, it contains;
       - usually an `input`
       - sometimes some buttons (translate, increment, decrement)
       - or could just be a `div` with anything really
    - `.tag-reference-body` at the bottom (usually hidden)

   .------------------.                             -
   |  Name        | i |  <- .field-label        |
   +------------------+                               |
   |  Starbucks   | + |  <- .form-field-input-wrap     >  .form-field
   '------------------'                               |
     tag reference       <- .tag-reference-body      |
                                                    -
*/

.form-field {
    display: flex;
    flex-flow: row wrap;
    margin-bottom: 10px;
    width: 100%;
    -webkit-transition: margin-bottom 200ms;
       -moz-transition: margin-bottom 200ms;
         -o-transition: margin-bottom 200ms;
            transition: margin-bottom 200ms;
}

.form-field.nowrap,
.wrap-form-field:last-child .form-field {
    margin-bottom: 0;
}

/* A `label` element that wraps the top section */
.field-label {
    display: flex;
    flex-flow: row nowrap;
    flex: 1 1 100%;
    height: 30px;
    position: relative;
    font-weight: bold;
    color: #333;
    background: #f6f6f6;
    border: 1px solid #ccc;
    border-radius: 4px 4px 0 0;
    overflow: hidden;
}
.field-label .label-text {
    flex: 1 1 auto;
    padding: 5px 0 5px 10px;
}
[dir='rtl'] .field-label .label-text {
    padding: 5px 10px 5px 0;
}

.label-text .label-textannotation svg.icon {
    margin: 0 8px;
    color: #333;
    opacity: 0.5;
    width: 14px;
    height: 14px;
    vertical-align: text-top;
}

.field-label button {
    flex: 0 0 32px;
    border-left: 1px solid #ccc;
    width: 32px;
    height: 100%;
    border-radius: 0;
    background: #f6f6f6;
}
[dir='rtl'] .field-label button {
    border-left: none;
    border-right: 1px solid #ccc;
}
.field-label button:hover {
    background: #f1f1f1;
}
.field-label .icon {
    opacity: .5;
}

.field-label .modified-icon,
.field-label .remove-icon,
.field-label .remove-icon-multilingual {
    display: none;
}
.modified:not(.locked) .field-label .modified-icon,
.present:not(.locked) .field-label .remove-icon,
.present:not(.locked) .field-label .remove-icon-multilingual {
    display: inline-block;
}

/* A `div` element that wraps the bottom section */
.form-field-input-wrap {
    display: flex;
    flex-flow: row nowrap;
    width: 100%;
    flex: 1 1 auto;
    min-height: 30px;
    border-top: 0;
    border-radius: 0 0 4px 4px;
}
.nowrap .form-field-input-wrap {
    border-radius: 0;
}


.form-field-input-wrap > input,
.form-field-input-wrap > label,
.form-field-input-wrap > textarea,
.form-field-input-wrap > ul.chiplist {
    flex: 1 1 auto;
    min-height: 30px;
    border: 1px solid #ccc;
    border-top: 0;
    border-radius: 0;
    overflow: hidden;
    position: relative;
}
.form-field-input-wrap > textarea {
    height: 65px;
    border-radius: 0 0 4px 4px;
    overflow: auto;
}

/* Buttons inside fields */
.form-field-button {
    flex: 0 0 auto;
    height: 30px;
    width: 32px;
    position: relative;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 0;
    border-top-width: 0;
    border-left-width: 0;
    vertical-align: top;
}
[dir='rtl'] .form-field-button {
    border-left-width: 1px;
    border-right-width: 0;
}
.form-field-button:hover {
    background-color: #f1f1f1;
}
.form-field-button .icon {
    fill: #333;
    opacity: .5;
}


/* round corners of first/last child elements */
.form-field-input-wrap > button:last-of-type {
    border-bottom-right-radius: 4px;
}
[dir='rtl'] .form-field-input-wrap > button:last-of-type {
    border-bottom-left-radius: 4px;
}


/* Field - Access, Cycleway
------------------------------------------------------- */
.form-field-input-access,
.form-field-input-cycleway {
    flex: 1 1 auto;
    display: flex;
    flex-flow: row wrap;
}

/* Field - lists with labeled input items
------------------------------------------------------- */
.form-field ul.rows {
    flex: 1 1 auto;
    border: 1px solid #ccc;
    border-top: 0;
    border-radius: 0 0 4px 4px;
    overflow: hidden;
    width: 100%;
}
.form-field ul.rows li {
    border-top: 1px solid #ccc;
}
.form-field ul.rows li:first-child {
    border-top: 0;
}
.form-field ul.rows li {
    display: flex;
    flex-flow: row nowrap;
}
.form-field ul.rows li.labeled-input > span,
.form-field ul.rows li.labeled-input > div {
    flex: 1 1 auto;
    width: 100%;
    border-radius: 0;
}
.form-field ul.rows li input {
    border-radius: 0;
    border-width: 0;
    width: 100%;
}
.form-field ul.rows li button {
    border-width: 0;
}
[dir='ltr'] .form-field ul.rows li.labeled-input input,
[dir='ltr'] .form-field ul.rows li button {
    border-left-width: 1px;
}
[dir='rtl'] .form-field ul.rows li.labeled-input input,
[dir='rtl'] .form-field ul.rows li button {
    border-right-width: 1px;
}


/* Field - Structure
------------------------------------------------------- */
.structure-extras-wrap {
    width: 100%;
    padding: 10px 10px;
    background: #fff;
    border: 1px solid #ccc;
    border-top: 0px;
    border-radius: 0 0 4px 4px;
}
.structure-extras-wrap > ul.rows {
    border: 1px solid #ccc;
    border-radius: 4px;
}


/* Field - Combo / Multicombo
------------------------------------------------------- */
.form-field-input-combo > input:only-of-type {
    border-radius: 0 0 4px 4px;
}
.form-field-input-combo.empty-combobox input,
.form-field-input-multicombo .empty-combobox input {
    padding-right: 10px;
    padding-left: 10px;
}
.form-field-input-combo.empty-combobox .combobox-caret,
.form-field-input-multicombo .empty-combobox .combobox-caret {
    display: none;
}

.form-field-input-multicombo ul.chiplist {
    padding: 5px 8px 5px 8px;
    background: #fff;
    display: block;
    border-radius: 0 0 4px 4px;
    width: 100%;
}

.form-field-input-multicombo li {
    display: inline-flex;
    flex-flow: row nowrap;
    align-items: center;
    margin-bottom: 3px;
    margin-top: 3px;
    border-radius: 4px;
}
[dir='ltr'] .form-field-input-multicombo li {
    margin-right: 6px;
}
[dir='rtl'] .form-field-input-multicombo li {
    margin-left: 6px;
}

.form-field-input-multicombo li.chip {
    background-color: #eff2f7;
    border: 1px solid #ccd5e3;
    line-height: 25px;
    max-width: 100%;
}
[dir='ltr'] .form-field-input-multicombo li.chip {
    padding: 2px 0px 2px 5px;
}
[dir='rtl'] .form-field-input-multicombo li.chip {
    padding: 2px 5px 2px 0px;
}
.form-field-input-multicombo li.chip.draggable {
    cursor: grab;
}
.form-field-input-multicombo li.chip.dragging {
    opacity: 0.75;
    z-index: 3000;
    cursor: grabbing;
}

.form-field-input-multicombo li.chip span {
    display: block;
    flex: 1 1 auto;
    overflow: hidden;
    word-wrap: break-word;
}

.form-field-input-multicombo a {
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    padding: 0px 5px 0px 5px;
    margin: 0;
    cursor: pointer;
    color: #a6b4ce;
    display: block;
    text-align: center;
    flex: 0 0 auto;
}

.form-field-input-multicombo .input-wrap {
    border: 1px solid #ddd;
    width: 100px;
    height: 31px;
}
.form-field-input-multicombo input {
    border: none;
    width: 100%;
    height: 100%;
}

.form-field-input-multicombo input:focus {
    border-radius: 4px !important;
}

.form-field-input-multicombo .full-line-chips li.chip {
    width: 100%;
}
.form-field-input-multicombo .full-line-chips .input-wrap {
    width: auto;
}


/* Field - Text / Numeric
------------------------------------------------------- */
.form-field-input-text > input:only-of-type,
.form-field-input-tel > input:only-of-type,
.form-field-input-email > input:only-of-type,
.form-field-input-url > input:only-of-type {
    border-radius: 0 0 4px 4px;
}
.form-field-input-number > input:only-of-type {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .form-field-input-number > input:only-of-type {
    border-radius: 0 0 4px 0;
}
.form-field-input-number > button:last-of-type {
    border-radius: 0 0 4px 0;
}
[dir='rtl'] .form-field-input-number > button:last-of-type {
    border-radius: 0 0 0 4px;
}

[dir='ltr'] .form-field-input-identifier > input:last-child,
[dir='rtl'] .form-field-input-identifier > input:first-child,
[dir='ltr'] .form-field-input-identifier > button {
    border-bottom-right-radius: 4px;
}
[dir='ltr'] .form-field-input-identifier > input:first-child,
[dir='rtl'] .form-field-input-identifier > input:last-child,
[dir='rtl'] .form-field-input-identifier > button {
    border-bottom-left-radius: 4px;
}

/* draw the up/down on the buttons */
.form-field-input-number button.decrement::after,
.form-field-input-number button.increment::after {
    content: "";
    height: 0; width: 0;
    position: absolute;
    left: 0; right: 0; bottom: 0; top: 0;
    margin: auto;
}
.form-field-input-number button.decrement::after {
    border-top: 5px solid #ccc;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
}
.form-field-input-number button.increment::after {
    border-bottom: 5px solid #ccc;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
}


/* Field - Checkbox
------------------------------------------------------- */
.form-field-input-check {
    display: flex;
    align-items: center;
    background: #fff;
    padding: 5px 10px;
    color: #7092ff;
    border: 1px solid #ccc;
    border-top: 0;
    cursor: pointer;
}
.form-field-input-check > input[type="checkbox"] {
    flex: 0 1 auto;
    min-height: 20px;
    width: 20px;
    margin-top: 0;
}
.form-field-input-check > span {
    flex: 1 1 auto;
}
.form-field-input-check > .reverser.button {
    flex: 0 1 auto;
    background-color: #eff2f7;
    border: 1px solid #ccd5e3;
    border-radius: 2px;
    padding: 0px 8px;
}
[dir='ltr'] .form-field-input-check > .reverser.button {
    padding-right: 2px;
}
[dir='rtl'] .form-field-input-check > .reverser.button {
    padding-left: 2px;
}
.form-field-input-check > .reverser.button.hide {
    display: none;
}

.form-field-input-check:hover {
    background: #f1f1f1;
}
.form-field-input-check .set {
    color: inherit;
}
.form-field-input-check label:not(.set) input[type="checkbox"] {
    opacity: .5;
}


/* Field - Radio button
------------------------------------------------------- */
.form-field-input-radio {
    flex: 1 1 auto;
    display: flex;
    flex-flow: row wrap;
}
.form-field-input-radio > label {
    flex: 1 1 auto;
    display: flex;
    flex-flow: row nowrap;
    width: 100%;
    padding: 5px 10px;
    height: 30px;
    background-color: #fff;
    color: #7092ff;
    cursor: pointer;
}
.form-field-input-radio > label:last-child {
    border-radius: 0 0 4px 4px;
}
.form-field-input-radio > label:hover {
    background-color: #ececec;
}
.form-field-input-radio > label.active {
    background-color: #e8ebff;
}
.form-field-input-radio > label:not(:last-of-type) {
    border-bottom: 1px solid #ccc;
}
.form-field-input-radio > label > input[type="radio"] {
    flex: 0 1 auto;
    width: 20px;
}
.form-field-input-radio > label > span {
    flex: 1 1 auto;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

/* Hide placeholder for radio buttons if another is active, or not in hover state */
.form-field-input-radio label.active ~ .placeholder,
.form-field-input-radio .placeholder {
    padding: 0;
    opacity: 0;
    width: 0;
    line-height: 0;
    display: block;
    overflow: hidden;
}


/* Field - Maxspeed
------------------------------------------------------- */
.form-field-input-maxspeed > input:first-of-type {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .form-field-input-maxspeed > input:first-of-type {
    border-radius: 0 0 4px 0;
}
.form-field-input-maxspeed > input:last-of-type {  /* unit field */
    flex: 0 1 80px;
    width: 80px;
    border-left: 0;
    border-radius: 0 0 4px 0;
}
[dir='rtl'] .form-field-input-maxspeed > input:last-of-type {
    border-right: 0;
    border-radius: 0 0 0 4px;
}


/* Field - Localized Name
------------------------------------------------------- */
.form-field-input-localized > input.localized-main {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .form-field-input-localized > input.localized-main {
    border-radius: 0 0 4px 0;
}
.form-field-input-localized > button.localized-add {
    border-radius: 0 0 4px 0;
}
[dir='rtl'] .form-field-input-localized > button.localized-add {
    border-radius: 0 0 0 4px;
}

.form-field-input-localized button.localized-add.disabled,
.form-field-input-localized input.localized-main.disabled,
.form-field-input-localized input.localized-lang.disabled,
.form-field-input-localized input.localized-value.disabled {
    color: #777;
    background-color: #eee;
    cursor: not-allowed;
}

/* nested subfields for name in different languages */
.localized-multilingual {
    padding: 0 10px;
    flex-basis: 100%;
}
.localized-multilingual .entry {
    position: relative;
    overflow: hidden;
}

/* draws a little line connecting the multilingual field up to the name field */
.localized-multilingual .entry::before {
    content: "";
    display: block;
    position: absolute;
    background: #ccc;
    height: 11px;
    width: 1px;
    left: 0;
    right: 0;
    top: -11px;
    margin: auto;
}

.localized-multilingual .entry .localized-lang {
    border-radius: 0;
    border-top-width: 0;
    width: 100%;
}
.localized-multilingual .entry .localized-value {
    border-top-width: 0;
    border-radius: 0 0 4px 4px;
    width: 100%;
}


/* Field - Address
------------------------------------------------------- */
.form-field-input-address {
    flex: 1 1 auto;
    display: flex;
    flex-flow: row wrap;
    border: 1px solid #ccc;
    border-top: 0px;
}

.addr-row {
    flex: 1 1 auto;
    display: flex;
    width: 100%;
    min-height: 30px;
}

.addr-row > input {
    flex: 1 1 auto;
    border-radius: 0;
    border-right: 0;
    border-bottom: 0;
}
[dir='rtl'] .addr-row input {
    border-right: 1px solid #ccc;
    border-left: 0;
}

.addr-row:first-of-type input {
    border-top: 0;
}
.addr-row input:first-of-type {
    border-left: 0;
}
[dir='rtl'] .addr-row input:first-of-type {
    border-right: 0;
}
.addr-row:last-of-type input:first-of-type {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .addr-row:last-of-type input:first-of-type {
    border-radius: 0 0 4px 0;
}
.addr-row:last-of-type input:last-of-type {
    border-radius: 0 0 4px 0;
}
[dir='rtl'] .addr-row:last-of-type input:last-of-type {
    border-radius: 0 0 0 4px;
}


/* Field - Wikipedia
------------------------------------------------------- */
.form-field-input-wikipedia {
    display: flex;
    flex-flow: row wrap;
    flex: 1 1 auto;
}

.wiki-lang-container,
.wiki-title-container {
    display: flex;
    flex-flow: row nowrap;
    flex: 1 1 auto;
    width: 100%;
}

.wiki-lang-container > input.wiki-lang,
.wiki-title-container > input.wiki-title {
    flex: 1 1 auto;
    border-top: 0;
    border-radius: 0;
}
.wiki-title-container > input.wiki-title {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .wiki-title-container > input.wiki-title {
    border-radius: 0 0 4px 0;
}
.wiki-title-container > button.wiki-link,
.form-field-wikidata ul.rows li:last-child button.form-field-button:last-child {
    border-radius: 0 0 4px 0;
}
[dir='rtl'] .wiki-title-container > button.wiki-link,
[dir='rtl'] .form-field-wikidata ul.rows li:last-child button.form-field-button:last-child {
    border-radius: 0 0 0 4px;
}


/* Field - Restriction Editor
------------------------------------------------------- */
.form-field-input-restrictions {
    display: block;
    border: 1px solid #ccc;
    border-top: 0;
    border-radius: 0 0 4px 4px;
}

.form-field-input-restrictions .restriction-controls-container {
    background-color: #fff;
    width: 100%;
    padding: 5px;
    border-top: 1px solid #ccc;
    border-radius: 0 0 4px 4px;
}

.restriction-controls-container .restriction-controls {
    display: table;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.restriction-controls .restriction-control {
    display: table-row;
    padding: 5px 10px;
    height: 25px;
}

.restriction-control input,
.restriction-control span {
    display: table-cell;
    text-align: start;
    padding: 0px 5px;
}

.restriction-control span.restriction-control-label {
    text-align: end;
}

.restriction-control input {
    width: 60px;
    padding: 0;
    margin: 0px 5px;
    vertical-align: middle;
}

.form-field-input-restrictions .restriction-container {
    position: relative;
    height: 370px;
}
/* zero width space, so container takes up space */
.form-field-input-restrictions .restriction-container:after {
    content: '\200b';
}

.form-field-input-restrictions svg.surface {
    width: 100%;
    height: 100%;
}

.restriction-container .restriction-help {
    z-index: 1;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    padding: 2px 6px;
    background-color: rgba(255, 255, 255, .8);
    color: #888;
    text-align: center;
    pointer-events: none;

    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.restriction-help span {
    margin: 2px;
}

.restriction-help .qualifier {
    color: #666;
    font-weight: bold;
}
.restriction-help .qualifier.allow {
    color: #8b5;
}
.restriction-help .qualifier.restrict {
    color: #d53;
}
.restriction-help .qualifier.only {
    color: #78f;
}


/* Field - Changeset Comment
------------------------------------------------------- */
.form-field-comment:not(.present) #preset-input-comment {
    border-color: rgb(230, 100, 100);
}
.form-field-comment:not(.present) .field-label {
    border-color: rgb(230, 100, 100);
    background: rgba(230, 100, 100, 0.2);
}
.form-field-comment:not(.present) button {
    border-color: rgb(230, 100, 100);
}


/* Field - Combobox
------------------------------------------------------- */
div.combobox {
    z-index: 9999;
    display: none;
    box-shadow: 0 4px 10px 1px rgba(0,0,0,.2);
    margin-top: -1px;
    background: #fff;
    max-height: 245px;
    overflow-y: auto;
    overflow-x: hidden;
    border: 1px solid #ccc;
    border-radius: 0 0 4px 4px;
}

.combobox a {
    display: block;
    padding: 5px 10px;
    border-top: 1px solid #ccc;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

.combobox a.selected,
.combobox a:hover {
    background: #ececec;
}

.combobox a:first-child {
    border-top: 0;
    padding: 4px 10px;
}

.combobox-caret {
    display: inline-block;
    position: relative;
    height: 30px;
    width: 30px !important;
    margin-left: -30px;
    vertical-align: top;
    cursor: pointer;
}
[dir='rtl'] .combobox-caret {
  margin-left: 0;
  margin-right: -30px;
}

.combobox-caret::after {
    content: "";
    height: 0; width: 0;
    position: absolute;
    left: 0; right: 0; bottom: 0; top: 0;
    margin: auto;
    border-top: 5px solid #ccc;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
}


/* Field Help
------------------------------------------------------- */
.field-help-body {
    display: block;
    position: absolute;
    top: 0;
    left: 20px;
    right: 20px;
    margin: 5px;
    padding: 8px;
    border: 1px solid #ccc;
    border-top: 0;
    border-radius: 0 0 4px 4px;
    z-index: 20;
    background: rgba(255,255,255,0.95);
    box-shadow: 0 0 30px 5px rgba(0,0,0,.4);
}

.field-help-title h2 {
    padding: 10px;
    margin-bottom: 0px;
    font-size: 17px;
}
.field-help-title button {
    width: 45px;
    height: 55px;
    border-radius: 0;
}

.field-help-nav {
    font-size: 13px;
    font-weight: bold;
    margin-bottom: 10px;
}
.field-help-nav-item {
    display: inline-block;
    padding: 5px 10px;
    cursor: pointer;
    color: #666;
}
.field-help-nav-item.active {
    color: #7092ff;
    border-bottom: 2px solid;
}
.field-help-nav-item:hover {
    color: #597be7;
    background-color: #efefef;
}

.field-help-content {
    padding: 10px;
    overflow-y: auto;
    overflow-x: hidden;
}
.field-help-content h3 {
    font-size: 12px;
    margin-bottom: 5px;
}
.field-help-content p {
    margin-bottom: 15px;
}
.field-help-content ul li {
    list-style: inside;
    margin-bottom: 5px;
}

.field-help-content .field-help-image {
    width: 100%;
    margin-bottom: 15px;
}

.field-help-content svg.turn {
    width: 40px;
    height: 20px;
}
.field-help-content svg.shadow {
    opacity: 0.7;
    width: 60px;
    height: 20px;
}
.field-help-content svg.from {
    color: #777;
}
.field-help-content svg.allow {
    color: #5b3;
}
.field-help-content svg.restrict {
    color: #d53;
}
.field-help-content svg.only {
    color: #68f;
}

.field-help-content p.from_shadow,
.field-help-content p.allow_shadow,
.field-help-content p.restrict_shadow,
.field-help-content p.allow_turn,
.field-help-content p.restrict_turn {
    margin-bottom: 5px;
}


/* More Fields dropdown
------------------------------------------------------- */
.more-fields {
    padding: 0 20px 20px 20px;
    font-weight: bold;
}
.changeset-editor .more-fields {
    padding: 15px 20px 0 20px;
}

.more-fields label {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
}

.more-fields input {
    margin-left: 10px;
    flex: 1 1 50%;
}
[dir='rtl'] .more-fields input {
    margin-left: auto;
    margin-right: 10px;
}

.form-field-input-wrap .label {
    height: 30px;
    background: #f6f6f6;
    padding: 5px 10px;
}


/* Raw Tag Editor
------------------------------------------------------- */
.raw-tag-options {
    display: flex;
    flex-flow: row nowrap;
    flex-direction: row-reverse;
    margin-top: -25px;
    padding: 0 3px;
}
button.raw-tag-option {
    flex: 0 0 20px;
    height: 20px;
    width: 20px;
    background: #aaa;
    color: #eee;
    margin: 0 3px;
}
button.raw-tag-option:focus,
button.raw-tag-option:hover,
button.raw-tag-option.active {
    color: #fff;
    background: #597be7;
}
button.raw-tag-option.selected {
    color: #fff;
    background: #7092ff;
}
button.raw-tag-option svg.icon {
    width: 14px;
    height: 14px;
    vertical-align: text-bottom;
}
[dir='ltr'] button.raw-tag-option-list {
    -moz-transform: scaleX(-1);
    -o-transform: scaleX(-1);
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
    filter: FlipH;
    -ms-filter: "FlipH";
}


.tag-text {
    width: 100%;
    height: 100%;
    font-family: monospace;
    white-space: pre;
}

.tag-text,
.tag-list {
    margin-top: 10px;
}
.tag-row {
    width: 100%;
    position: relative;
}
.tag-row .inner-wrap {
    display: flex;
    flex-flow: row nowrap;
    width: 100%;
    position: relative;
}
.tag-row .key-wrap,
.tag-row .value-wrap {
    flex: 1 1 50%;
}

.tag-text.readonly,
.tag-row.readonly,
.tag-row.readonly input.key,
.tag-row.readonly input.value,
.tag-row.readonly button.remove {
    color: #777;
    background-color: #eee;
    cursor: not-allowed;
}

.tag-row input {
    height: 31px;
    border: 0;
    border-radius: 0;
    border-bottom: 1px solid #ccc;
    border-left: 1px solid #ccc;
    width: 100%;
}
[dir='rtl'] .tag-row input {
    border-left: none;
    border-right: 1px solid #ccc;
}


.tag-row input.key {
    font-weight: bold;
    background-color: #f6f6f6;
}

.tag-row input.value {
    border-right: 1px solid #ccc;
}
[dir='rtl'] .tag-row input.value {
    border-left: 1px solid #ccc;
}

.tag-row:first-child input.key {
    border-top: 1px solid #ccc;
    border-top-left-radius: 4px;
}
[dir='rtl'] .tag-row:first-child input.key {
    border-top-left-radius: 0;
    border-top-right-radius: 4px;
}

.tag-row:first-child input.value {
    border-top: 1px solid #ccc;
}
.tag-row button {
    flex: 0 0 32px;
    height: 31px;
    width: 32px;
    border: 1px solid #ccc;
    border-top-width: 0;
    border-left-width: 0;
}
[dir='rtl'] .tag-row button {
    border-left-width: 1px;
    border-right-width: 0;
}

.tag-row button:hover {
    background: #f1f1f1;
}
.tag-row button .icon {
    opacity: .5;
}
.tag-row:first-child button {
    border-top-width: 1px;
}

.tag-row:first-child .tag-reference-button {
    border-top-right-radius: 4px;
}
[dir='rtl'] .tag-row:first-child .tag-reference-button {
    border-top-left-radius: 4px;
    border-top-right-radius: 0;
}

.tag-row:last-child .tag-reference-button {
    border-bottom-right-radius: 4px;
}
[dir='rtl'] .tag-row:last-child .tag-reference-button {
    border-bottom-left-radius: 4px;
    border-bottom-right-radius: 0;
}

.tag-row .tag-reference-button {
    border-radius: 0;
}
[dir='rtl'] .tag-row .tag-reference-button {
    border-left-width: 1px;
    border-right-width: 0;
}

/* Tag reference */
.tag-reference-loading {
    background-color: #f5f5f5;
}
.tag-reference-loading .icon {
    background-image: url(img/mini-loader.gif);
    background-position: 0 0;
}

.tag-reference-body {
    flex: 1 1 auto;
    width: 100%;
    overflow: hidden;
    display: none;
    padding-top: 10px;
}
.tag-reference-body.expanded {
    padding-bottom: 10px;
    display: inline-block;
}
.tag-reference-description {

}
.tag-reference-link {
    display: block;
}

img.tag-reference-wiki-image {
    float: right;
    width: 33.3333%;
    border-radius: 4px;
    margin: 0 0 0 5px;
}
[dir='rtl'] img.tag-reference-wiki-image {
    float: left;
    margin: 0 5px 0 0;
}

.preset-list .tag-reference-body {
    position: relative;
    width: 100%;
}
.raw-tag-editor .tag-reference-body {
    width: 100%;
}
.raw-tag-editor .tag-row.readonly .tag-reference-body {
    background: #f6f6f6;
    color: #333;
}
.raw-tag-editor .tag-row:not(:last-child) .tag-reference-body.expanded {
    border-bottom: 1px solid #ccc;
}
.raw-tag-editor .tag-row.readonly .tag-reference-body.expanded {
    border-top: 1px solid #ccc;
}


/* Raw Member / Membership Editor
------------------------------------------------------- */

.raw-member-editor .member-list,
.raw-membership-editor .member-list {
    padding-top: 10px;
}
.raw-member-editor .member-list li,
.raw-membership-editor .member-list li {
    position: relative;
    border-radius: 4px;
    margin: 0;
    padding-bottom: 10px;
}
.raw-member-editor .member-row .member-entity-name,
.raw-membership-editor .member-row .member-entity-name {
    font-weight: normal;
    padding-left: 10px;
}

[dir='rtl'] .raw-member-editor .member-row .member-entity-name,
[dir='rtl'] .raw-membership-editor .member-row .member-entity-name {
    padding-left:0;
    padding-right: 10px;
}

.form-field-input-member > input.member-role {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .form-field-input-member > input.member-role {
    border-radius: 0 0 4px 0;
}

.member-incomplete .form-field-input-member > input.member-role,
[dir='rtl'] .member-incomplete .form-field-input-member > input.member-role {
    border-radius: 0 0 4px 4px;
}

.member-incomplete .member-delete {
    display: none;
}

.member-row-new .member-entity-input {
    flex: 1 1 100%;
    border-radius: 4px 4px 0 0;
    border: 0;
}

.raw-member-editor .member-row.dragging {
    opacity: 0.75;
    z-index: 3000;
    /*
    -webkit-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.3);
    -moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.3);
    box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.3);
    */
}

/* preserve extra space at bottom of inspector to allow for dropdown options - #5280 */
.raw-membership-editor.inspector-inner {
    margin-bottom: 150px;
}

/* hidden field to prevent user from tabbing out of the sidebar */
input.key-trap {
    height: 0px;
    width: 0px;
    padding: 0px;
    border: 1px solid rgba(0,0,0,0);
}


/* add tag, add relation buttons */
.add-row {
    display: flex;
    width: 100%;
    flex-flow: row nowrap;
}
.add-row .add-tag,
.add-row .add-relation,
.add-row .space-value {
    flex: 1 1 50%;
}
.add-row .space-buttons {
    flex: 0 0 62px;
}
.add-row button {
    height: 30px;
    background: rgba(0,0,0,.5);
}
.add-row button:focus,
.add-row button:hover {
    background: rgba(0,0,0,.8);
}

.add-tag {
    border-radius: 0 0 4px 4px;
}
.add-relation {
    margin-top: 10px;
    border-radius: 4px;
}


/* OSM Note / KeepRight Editors
------------------------------------------------------- */
.note-header,
.error-header {
    background-color: #f6f6f6;
    border-radius: 5px;
    border: 1px solid #ccc;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
}

.note-header-icon,
.error-header-icon {
    background-color: #fff;
    padding: 10px;
    flex: 0 0 62px;
    position: relative;
    width: 60px;
    height: 60px;
    border-right: 1px solid #ccc;
    border-radius: 5px 0 0 5px;
}
[dir='rtl'] .note-header-icon,
[dir='rtl'] .error-header-icon {
    border-right: unset;
    border-left: 1px solid #ccc;
    border-radius: 0 5px 5px 0;
}

.note-header-icon .icon-wrap,
.error-header-icon .icon-wrap {
    position: absolute;
    top: 0px;
}
.preset-icon-28 {
    position: absolute;
    top: 16px;
    left: 16px;
    margin: auto;
}
.preset-icon-28 .icon {
    width: 28px;
    height: 28px;
}

.note-header-label,
.error-header-label {
    background-color: #f6f6f6;
    padding: 0 15px;
    flex: 1 1 100%;
    font-size: 14px;
    font-weight: bold;
    border-radius: 0 5px 5px 0;
}
[dir='rtl'] .note-header-label,
[dir='rtl'] .error-header-label {
    border-radius: 5px 0 0 5px;
}

.note-category {
    margin: 20px 0px;
}

.comments-container {
    background: #ececec;
    padding: 1px 10px;
    border-radius: 8px;
    margin-top: 20px;
}

.comment {
    background-color: #fff;
    border-radius: 5px;
    border: 1px solid #ccc;
    margin: 10px auto;
    display: flex;
    flex-flow: row nowrap;
}
.comment-avatar {
    padding: 10px;
    flex: 0 0 62px;
}
.comment-avatar .icon.comment-avatar-icon {
    width: 40px;
    height: 40px;
    object-fit: cover;
    border: 1px solid #ccc;
    border-radius: 20px;
}
.comment-main {
    padding: 10px 10px 10px 0;
    flex: 1 1 100%;
    flex-flow: column nowrap;
    overflow: hidden;
    overflow-wrap: break-word;
}
[dir='rtl'] .comment-main {
    padding: 10px 0 10px 10px;
}

.comment-metadata {
    flex-flow: row nowrap;
    justify-content: space-between;
}
.comment-author {
    font-weight: bold;
    color: #333;
}
.comment-date {
    color: #aaa;
}
.comment-text {
    color: #333;
    margin-top: 10px;
    overflow-y: auto;
    max-height: 250px;
}
.comment-text::-webkit-scrollbar {
    border-left: none;
}

.note-save,
.error-save {
    padding-top: 20px;
}

.error-details {
    padding: 10px;
}
.error-details-container {
    background: #ececec;
    padding: 10px;
    margin-top: 20px;
    border-radius: 4px;
    border: 1px solid #ccc;
}
.error-details-description {
    margin-bottom: 10px;
}
.error-details-description-text::first-letter {
    text-transform: capitalize;
}
[dir='rtl'] .error-details-description-text::first-letter {
    text-transform: none;  /* #5877 */
}

.note-save .new-comment-input,
.error-save .new-comment-input {
    width: 100%;
    height: 100px;
    max-height: 300px;
    min-height: 100px;
}

.note-save .detail-section,
.error-save .detail-section {
    margin: 10px 0;
}

.note-report {
    float: right;
}


/* Custom Data Editor
------------------------------------------------------- */
.data-header {
    background-color: #f6f6f6;
    border-radius: 5px;
    border: 1px solid #ccc;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
}

.data-header-icon {
    background-color: #fff;
    padding: 10px;
    flex: 0 0 62px;
    position: relative;
    width: 60px;
    height: 60px;
    border-right: 1px solid #ccc;
    border-radius: 5px 0 0 5px;
}
[dir='rtl'] .data-header-icon {
    border-right: unset;
    border-left: 1px solid #ccc;
    border-radius: 0 5px 5px 0;
}

.data-header-icon .icon-wrap {
    position: absolute;
    top: 0px;
}

.data-header-label {
    background-color: #f6f6f6;
    padding: 0 15px;
    flex: 1 1 100%;
    font-size: 14px;
    font-weight: bold;
    border-radius: 0 5px 5px 0;
}
[dir='rtl'] .data-header-label {
    border-radius: 5px 0 0 5px;
}

/* custom data editor - no info/delete buttons */
.data-editor.raw-tag-editor .tag-row button {
    display: none;
}
.data-editor.raw-tag-editor .tag-row .key-wrap,
.data-editor.raw-tag-editor .tag-row .value-wrap {
    width: 50%;
}


/* Map Controls
------------------------------------------------------- */
.map-controls {
    right: 0;
    top: 141px;
    width: 40px;
    position: absolute;
    z-index: 100;
}
[dir='rtl'] .map-controls {
    left: 0;
    right: auto;
}

.map-control > button {
    position: relative;
    width: 40px;
    background: rgba(0,0,0,.5);
    border-radius: 0;
}

.map-control > button:not(.disabled):hover,
.map-control > button:not(.disabled):focus {
    background: rgba(0, 0, 0, .8);
}

.map-control > button.active,
.map-control > button.active:hover {
    background: #7092ff;
}

.map-control > button.disabled .icon {
    color: rgba(255, 255, 255, 0.5);
}


/* Fullscreen Button (disabled)
------------------------------------------------------- */
div.full-screen {
    display: inline-block;
    width: 40px;
    margin-right: 10px;
    display: none;
}

div.full-screen .tooltip {
    min-width: 160px;
}

div.full-screen > button, div.full-screen > button.active {
    width: 40px;
    height: 40px;
    background: transparent;
}

div.full-screen > button:hover {
    background-color: rgba(0, 0, 0, .8);
}


/* Zoom Buttons
------------------------------------------------------- */
.zoombuttons > button.zoom-in {
    border-radius: 4px 0 0 0;
}
[dir='rtl'] .zoombuttons > button.zoom-in {
    border-radius: 0 4px 0 0;
}


/* Geolocate Button
------------------------------------------------------- */
.geolocate-control {
    margin-bottom: 10px;
}
.geolocate-control > button {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .geolocate-control > button {
    border-radius: 0 0 4px 0;
}


/* Background / Map Data / Help Pane buttons
------------------------------------------------------- */
.background-control > button {
    border-radius: 4px 0 0 0;
}
[dir='rtl'] .background-control > button {
    border-radius: 0 4px 0 0;
}

.help-control > button {
    border-radius: 0 0 0 4px;
}
[dir='rtl'] .help-control > button {
    border-radius: 0 0 4px 0;
}


/* Background / Map Data Settings
------------------------------------------------------- */
.map-data-control,
.background-control {
    position: relative;
}

.imagery-faq {
    margin-bottom: 10px;
    white-space: nowrap;
}

.layer-list, .controls-list {
    margin-bottom: 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.layer-list > li {
    height: 30px;
    background-color: #fff;
    color: #7092ff;
    position: relative;
    display: flex;
}

.layer-list:empty {
    display: none;
}

.layer-list > li:first-child {
    border-radius: 3px 3px 0 0;
}
.layer-list > li:last-child {
    border-radius: 0 0 3px 3px;
}
.layer-list > li:only-child {
    border-radius: 3px;
}
.layer-list li:not(:last-child) {
    border-bottom: 1px solid #ccc;
}
.layer-list li:hover {
    background-color: #ececec;
}

.layer-list li.active button,
.layer-list li.switch button,
.layer-list li.active,
.layer-list li.switch {
    background: #e8ebff;
}

.layer-list li.best > div.best {
    padding: 5px;
    flex: 0 0 auto;
}

[dir='rtl'] .list-item-data-browse svg {
    transform: rotateY(180deg);
}

/* make sure tooltip fits in map-control panel */
/* if too wide, placement will be wrong the first time it displays */
.layer-list li.best .popover-inner {
    max-width: 160px;
}

.layer-list label {
    padding: 5px 10px;
    cursor: pointer;
    flex: 1 1 auto;
}

[dir='ltr'] .layer-list .indented label {
    padding-left: 24px;
}
[dir='rtl'] .layer-list .indented label {
    padding-right: 24px;
}

.layer-list label > span {
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.map-data-pane .layer-list button,
.background-pane .layer-list button {
    height: 100%;
    border-left: 1px solid #ccc;
    border-radius: 0;
    padding-left: 4px;
    padding-right: 4px;
}
[dir='rtl'] .map-data-pane .layer-list button,
[dir='rtl'] .background-pane .layer-list button {
    border-left: none;
    border-right: 1px solid #ccc;
}

.map-data-pane .layer-list button .icon,
.background-pane .layer-list button .icon {
    opacity: 0.5;
}

.map-data-pane .layer-list button:last-of-type,
.background-pane .layer-list button:last-of-type {
    border-radius: 0 3px 3px 0;
}
[dir='rtl'] .map-data-pane .layer-list button:last-of-type,
[dir='rtl'] .background-pane .layer-list button:last-of-type {
    border-radius: 3px 0 0 3px;
}

.map-data-pane .vectortile-container .vectortile-header {
    padding-bottom: 5px;
}
.map-data-pane .vectortile-container .vectortile-footer {
    padding-bottom: 10px;
}


/* Issues
------------------------------------------------------- */
.issue {
    overflow: hidden;
}
.issue .issue-label,
.issue-label .issue-text {
    width: 100%;
    display: flex;
    flex-flow: row nowrap;
    cursor: pointer;
}

.issue-text .issue-icon {
    flex: 0 0 auto;
    padding: 5px 7px;
}
.issue-text .issue-message {
    flex: 1 1 auto;
    padding: 5px 0;
}
.issue-label .issue-autofix {
    flex: 0 0 auto;
    padding: 5px 8px;
}
.issue-label .issue-info-button {
    height: unset;
    width: 32px;
    flex: 0 0 auto;
    border-left: 1px solid #ccc;
    background-color: rgba(0,0,0,0);
}
[dir='rtl'] .issue-label .issue-info-button {
    border-left: 0;
    border-right: 1px solid #ccc;
}
.issue-container .issue-label .issue-info-button .icon {
    opacity: 0.5;
}
.issue-container.active .issue-label .issue-info-button .icon {
    opacity: 0.7;
}
.issue-label .issue-info-button:last-child {
    border-radius: 0 4px 4px 0;
}
[dir='rtl'] .issue-label .issue-info-button:last-child {
    border-radius: 4px 0 0 4px;
}

button.autofix.action {
    flex: 0 0 20px;
    height: 20px;
    width: 20px;
    background: #7092ff;
    color: #fff;
}
button.autofix.action:focus,
button.autofix.action:hover,
button.autofix.action.active {
    background: #597be7;
}

/* fix all */
.autofix-all {
    display: flex;
    flex-flow: row nowrap;
    flex-direction: row-reverse;
    margin-top: -25px;
    padding-bottom: 5px;
}
.autofix-all-link-text {
    padding: 0;
}
.autofix-all-link-icon svg {
    margin: 0 9px;
    background: currentColor;
    border-radius: 4px;
}
.autofix-all-link-icon svg use {
    color: #fff;
}

/* warning styles */
.warnings-list,
.warnings-list *,
.issue-container.active .issue.severity-warning,
.issue-container.active .issue.severity-warning * {
    border-color: #fb2;
}

.warnings-list .issue.severity-warning .issue-label,
.issue.severity-warning .issue-fix-list,
.mode-save .warning-section {
    background: #ffc;
}

.issue-container.active .issue.severity-warning .issue-label {
    background: #ffa;
}

.warnings-list .issue.severity-warning .issue-label:hover,
.issue.severity-warning .issue-fix-item.actionable:hover {
    background: #ff8;
}

.issue.severity-warning .issue-icon {
    color: #f90;
}

.issue.severity-warning .issue-fix-item.actionable,
.issue-container.active .issue.severity-warning .issue-info-button {
    color: #b15500;
    fill: #b15500;
    /*color: #7092ff;*/
    /*fill: #7092ff;*/
}
.issue.severity-warning .issue-fix-item.actionable:hover,
.issue-container.active .issue.severity-warning .issue-info-button:hover {
    color: #7f3d00;
    fill: #7f3d00;
    /*color: #597be7;*/
    /*fill: #597be7;*/
}

.notification-badge.warning {
    color: #ffdf5c;
}


/* error styles */
.errors-list,
.errors-list *,
.issue-container.active .issue.severity-error,
.issue-container.active .issue.severity-error * {
    border-color: #f77;
}

.errors-list .issue.severity-error .issue-label,
.issue.severity-error .issue-fix-list,
.mode-save .error-section {
    background: #ffd6d6;
}

.issue-container.active .issue.severity-error .issue-label {
    background: #ffc6c6;
}

.errors-list .issue.severity-error .issue-label:hover,
.issue.severity-error .issue-fix-item.actionable:hover {
    background: #ffb6b6;
}

.issue.severity-error .issue-icon {
    color: #dd1400;
}

.issue.severity-error .issue-fix-item.actionable,
.issue-container.active .issue.severity-error .issue-info-button {
    color: #b91201;
    fill: #b91201;
    /*color: #7092ff;*/
    /*fill: #7092ff;*/
}
.issue.severity-error .issue-fix-item.actionable:hover,
.issue-container.active .issue.severity-error .issue-info-button:hover {
    color: #840c00;
    fill: #840c00;
    /*color: #597be7;*/
    /*fill: #597be7;*/
}

.notification-badge.error {
    color: #ff0c05;
}


/* Issues Pane */
.issues-options-container {
    display: table;
}
.issues-option {
    display: table-row;
}
.issues-option-title {
    display: table-cell;
    font-weight: bold;
    padding-right: 10px;
}
[dir='rtl'] .issues-option-title {
    padding-right: 0;
    padding-left: 10px;
}
.issues-option label {
    display: table-cell;
    padding: 0 10px;
}

.layer-list.issues-list li.issue {
    border-color: inherit;    /* override .layer-list styles */
    color: inherit;
    height: unset;
}

.layer-list.issue-rules-list,
.layer-list.issues-list,
.layer-list.layer-feature-list {
    margin-bottom: 0;
}
.section-footer {
    display: flex;
    flex-flow: row nowrap;
    flex-direction: row-reverse;
    height: 30px;
}
.section-footer a {
    padding: 5px;
}

.issues-none .box {
    border-radius: 4px;
    border: 1px solid #72d979;
    background: #c6ffca;
    padding: 5px !important;
    display: flex;
}
.issues-none .icon {
    color: #05ac10;
}

input.square-degrees-input {
    padding: 2px !important; /* important needed for rtl */
    width: 40px;
    height: unset;
    text-align: center;
    background: rgba(0,0,0,0);
    color: currentColor;
}


/* Entity Issues List */
.entity-issues .issue-container .issue {
    border-radius: 4px;
    border: 1px solid #ccc;
    background: #f6f6f6;
}
.entity-issues .issue-container:not(.active) .issue-text:hover,
.entity-issues .issue-container:not(.active) .issue-info-button:hover {
    background: #f1f1f1;
}
.entity-issues .issue .issue-label .issue-text {
    padding-right: 10px;
}
[dir='rtl'] .entity-issues .issue .issue-label .issue-text {
    padding-right: unset;
    padding-left: 10px;
}

.entity-issues .issue-container.active .issue-label .issue-text {
    font-weight: bold;
}
.entity-issues .issue-container:not(:last-of-type) {
    margin-bottom: 5px;
}
.entity-issues .issue-container.active:not(:first-of-type) {
    margin-top: 10px;
}
.entity-issues .issue-container.active:not(:last-of-type) {
    margin-bottom: 10px;
}

/* fixes */
.entity-issues .issue-fix-list {
    border-top: 1px solid;
    border-color: inherit;
}
.entity-issues .issue-container.active .issue-fix-list:empty {
    display: none;
}

li.issue-fix-item {
    padding: 2px 10px 2px 20px;
}
[dir='rtl'] li.issue-fix-item {
    padding: 2px 20px 2px 10px;
}
li.issue-fix-item:first-of-type {
    padding-top: 5px;
}
li.issue-fix-item:last-of-type {
    padding-bottom: 5px;
}

li.issue-fix-item .fix-message {
    padding: 0 10px;
}

li.issue-fix-item.actionable {
    cursor: pointer;
}
li.issue-fix-item:not(.actionable) .fix-icon {
    color: #555;
    fill: #555;
}

.issue-container:not(.active) ul.issue-fix-list {
    display: none;
}

.issue-info {
    flex: 1 1 auto;
    width: 100%;
    overflow: hidden;
    display: none;
    padding: 10px 0;
}
.issue-info.expanded {
    display: inline-block;
}

.issue-info .issue-reference {
    margin-bottom: 10px;
}
.issue-info .tagDiff-table {
    min-width: 60%;
    width: unset;
    border: 1px solid #ccc;
}
.issue-info .tagDiff-row {
    border: 1px solid #ccc;
}
.issue-info .tagDiff-cell {
    padding: 2px 10px;
    font-family: monospace;
    font-size: 10px;
    border: 1px solid #ccc;
}
.issue-info .tagDiff-cell-add {
    background: #dfd;
}
.issue-info .tagDiff-cell-remove {
    background: #fdd;
}


/* Background - Display Options Sliders
------------------------------------------------------- */
.display-options-container {
    padding: 10px;
}

.display-control h5 {
    padding-bottom: 0;
    padding-top: 10px;
}

.display-control h5 span {
    margin: 5px;
}

.display-control .display-option-input {
    height: 20px;
    width: 155px;
}

.display-control button {
    height: 30px;
    width: 30px;
    margin-left: 5px;
    margin-right: 0px;
    vertical-align: text-bottom;
    border-radius: 4px;
}
[dir='rtl'] .display-control button {
    margin-left: 0px;
    margin-right: 5px;
}


/* Background - Adjust Alignment
------------------------------------------------------- */
.background-pane .nudge-container {
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 10px;
}

.nudge-container .nudge-instructions {
    padding-bottom: 15px;
}

.nudge-container .nudge-outer-rect {
    background-color: #eee;
    border: 1px solid #ccc;
    border-radius: 2px;
    padding: 20px 0;
    width: 70%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    margin-top: 20px;
    cursor: move;
}

.nudge-container .nudge-inner-rect {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 2px;
    width: 65%;
    min-height: 20px;
}

.nudge-container .nudge::after {
    content: '';
    display: block;
    position: absolute;
    margin: auto;
    left: 0; right: 0; top: 0; bottom: 0;
    height: 0;
    width: 0;
}

.nudge-container input {
    width: 100%;
    height: 20px;
    text-align: center;
    border: 0;
}

.nudge-container input.error {
    border: 1px solid #ff7878;
    border-radius: 2px;
    background: #ffb;
}

.nudge-container input:focus {
    background-color: transparent;
}

.nudge-container button {
    float: left;
    display: block;
    width: 20%;
    position: relative;
    background-color: transparent;
}

.nudge-container button.right {
    top: -50px;
    right: -85%;
}

.nudge-container button.left {
    top: -50px;
    right: 45%;
}

.nudge-container button.top {
    left: 20%;
    top: -104px;
}

.nudge-container button.bottom {
    left: -20%;
}

.nudge-container button.nudge-reset {
    right: -10px;
}

.nudge-surface {
   position: absolute;
   z-index: 5000;
   left: 0;
   top: 0;
   width: 100%;
   height: 100%;
   background-color: transparent;
   cursor: move;
}

.background-pane .nudge.right::after {
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid #222;
}

.background-pane .nudge.left::after {
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-right: 5px solid #222;
}

.background-pane .nudge.top::after {
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    border-bottom: 5px solid #222;
}

.background-pane .nudge.bottom::after {
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    border-top: 5px solid #222;
}


/* Side Panes - Background / Map Data / Help
------------------------------------------------------- */
.map-panes {
    flex: 0 1 auto;
    position: relative;
    height: 100%;
}
.map-pane {
    position: relative;
    top: 0;
    width: 400px;
    height: 100%;
    padding-bottom: 60px;
    overflow: hidden;
    z-index: 10;
}

.map-pane.help-wrap {
    width: 600px;
}

.pane-heading {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    border-bottom: 1px solid #ccc;
    height: 60px;
}

.pane-heading h2 {
    margin: 14px 20px;
}

.pane-heading button {
    width: 40px;
    height: 100%;
    border-radius: 0;
}

.pane-content {
    height: 100%;
    padding: 10px 40px 20px 20px;
    overflow-x: hidden;
    overflow-y: scroll;
    position: relative;
}
[dir='rtl'] .pane-content {
    padding: 10px 20px 20px 40px;
}

.pane-content > div {
    padding-bottom: 15px;
}


/* Help
------------------------------------------------------- */
.help-wrap p {
    font-size: 15px;
    margin-bottom: 20px;
}

.help-wrap .left-content .body p code {
    padding: 3px 4px;
    font-size: 12px;
    color: #555;
    vertical-align: baseline;
    background-color: #f6f6f6;
    border: solid 1px #ccc;
    margin: 0 2px;
    border-bottom-color: #bbb;
    border-radius: 3px;
    box-shadow: inset 0 -1px 0 #bbb;
}

.help-wrap .left-content .icon.pre-text {
    vertical-align: text-top;
    margin-right: 0;
    margin-left: 0;
    display: inline-block;
}

.help-wrap .toc {
    width: 40%;
    float: right;
    margin-left: 20px;
    margin-bottom: 20px;
    padding-left: 5px;
}

.help-wrap .toc li a,
.help-wrap .nav a {
    display: block;
    border: 1px solid #ccc;
    padding: 5px 10px;
}

.help-wrap .toc li a {
    border-bottom: 0;
}

.help-wrap .toc li a:hover,
.help-wrap .nav a:hover {
    background: #ececec;
}

.help-wrap .toc li a.selected {
    background: #e8ebff;
}

.help-wrap .toc li:first-child a {
    border-radius: 4px 4px 0 0;
}

.help-wrap .toc li:nth-last-child(3) a {
    border-bottom: 1px solid #ccc;
    border-radius: 0 0 4px 4px
}

.help-wrap .toc li.shortcuts a,
.help-wrap .toc li.walkthrough a {
    overflow: hidden;
    margin-top: 10px;
    border-bottom: 1px solid #ccc;
    border-radius: 4px;
}

.help-wrap .toc li.walkthrough a {
    text-align: center;
}

.help-wrap .nav {
    position: relative;
    padding-bottom: 30px;
}

.help-wrap .nav a {
    float: left;
    width: 50%;
    text-align: center;
}

.help-wrap .nav a:first-child {
    border-radius: 4px 0 0 4px;
}

.help-wrap .nav a:last-child:not(:only-child) {
    border-radius: 0 4px 4px 0;
    border-left: 0;
}

.help-wrap .nav a:only-child {
    width: 100%;
    border-radius: 4px;
}


/* Inspector (hover styles)
------------------------------------------------------- */
.inspector-hover .entity-issues .issue-container .issue .issue-label,
.inspector-hover .form-field-input-wrap .label,
.inspector-hover .form-field-input-multicombo .chiplist,
.inspector-hover .form-field-button,
.inspector-hover .structure-extras-wrap,
.inspector-hover .comments-container .comment,
.inspector-hover button,
.inspector-hover input,
.inspector-hover textarea,
.inspector-hover label {
    background: #ececec;
}
.inspector-hover .preset-list-button,
.inspector-hover .tag-row input {
    background: #f6f6f6;
}

.inspector-hover a,
.inspector-hover .form-field-input-multicombo .chip,
.inspector-hover .form-field-input-check span,
.inspector-hover .entity-issues .issue .icon {
    color: #666;
}

.inspector-hover .form-field-input-multicombo .chip {
    background: #eee;
    border: 1px solid #ccc;
}

/* no scrollbars */
.inspector-hover div {
    overflow-x: hidden;
    overflow-y: hidden;
}

/* hide and remove from layout */
.inspector-hidden,
.inspector-hover .preset-list-button-wrap .tag-reference-button,
.inspector-hover label input[type="checkbox"],
.inspector-hover label input[type="radio"],
.inspector-hover .form-field-input-multicombo .input-wrap,
.inspector-hover .form-field-input-radio label,
.inspector-hover .form-field-input-radio label span,
.inspector-hover .form-field-input-radio label.remove .icon,
.inspector-hover .inspector-inner .add-row,
.inspector-hover .entity-issues .issue-container .issue-fix-list,
.inspector-hover .entity-issues .issue-container .issue-info-button {
    display: none;
}

/* hide but preserve in layout */
.inspector-hover .combobox-caret,
.inspector-hover .header button,
.inspector-hover .quick-links,
.inspector-hover .form-field-input-multicombo .chip .remove,
.inspector-hover .hide-toggle:before,
.inspector-hover .more-fields,
.inspector-hover .field-label button,
.inspector-hover .tag-row button,
.inspector-hover .footer * {
    opacity: 0;
}

/* Unstyle the active entity issue on hover */
.inspector-hover .entity-issues .issue-container.active {
    margin-top: 1px;
    margin-bottom: 1px;
}
.inspector-hover .entity-issues .issue-container * {
    border-color: #ccc !important;
}
.inspector-hover .entity-issues .issue-container.active .issue-label {
    border-bottom: 0;
}
.inspector-hover .entity-issues .issue-container.active .issue-label .issue-text {
    font-weight: normal;
}


/* Styles for raw tag inspector on hover */
.inspector-hover .tag-row .key-wrap,
.inspector-hover .tag-row .value-wrap {
    height: 31px;
}

.inspector-hover .tag-row:first-child input.value {
    border-top-right-radius: 4px;
}
[dir='rtl'] .inspector-hover .tag-row:first-child input.value {
    border-top-right-radius: 0;
    border-top-left-radius: 4px;
}

.inspector-hover .tag-row:last-child input.value {
    border-bottom-right-radius: 4px;
}
[dir='rtl'] .inspector-hover .tag-row:last-child input.value {
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 4px;
}

.inspector-hover .tag-row:last-child input.key {
    border-bottom-left-radius: 4px;
}
[dir='rtl'] .inspector-hover .tag-row:last-child input.key {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 4px;
}

.inspector-hover .more-fields {
    max-height: 0;
    margin-bottom: -10px;
}

/* Unstyle button fields */
.inspector-hover .form-field-input-radio label.active,
.inspector-hover .entity-editor-pane a.hide-toggle {
    opacity: 1;
    background-color: transparent;
    color: #666;
    padding-left: 0;
    border-width: 0;
}
.inspector-hover .form-field-input-radio button.active {
    padding-left: 10px;
}

/* Show placeholder on hover for radio buttons */
.inspector-hover .form-field-input-radio {
    border: 1px solid #ccc;
    border-top: 0;
    border-radius: 0 0 4px 4px;
}
.inspector-hover .form-field-input-radio .placeholder {
    opacity: 1;
    color: #666;
    padding: 5px 10px;
    line-height: 20px;
    width: 100%;
    border: 0;
}
.inspector-hover .form-field-input-radio .structure-extras-wrap {
    border: 0;
}


/* Raster Background Tiles
------------------------------------------------------- */
img.tile {
    position: absolute;
    transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    -webkit-transform-origin: 0 0;
    -moz-transform-origin: 0 0;
    -o-transform-origin: 0 0;

    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;

    opacity: 0;

    -webkit-transition: opacity 200ms linear;
    -moz-transition: opacity 200ms linear;
    transition: opacity 200ms linear;
}

img.tile-loaded {
    opacity: 1;
}

img.tile-removing {
    opacity: 0;
}

.tile-label-debug {
    font-size: 10px;
    background: rgba(0, 0, 0, 0.7);
    color: #fff;
    position: absolute;
    text-align: center;
    padding: 5px;
    border-radius: 3px;
    z-index: 2;
    margin-left: -70px;
    margin-top: -20px;

    transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    -webkit-transform-origin: 0 0;
    -moz-transform-origin: 0 0;
    -o-transform-origin: 0 0;

    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

img.tile-debug {
    outline: 1px solid red;
}


/* Map
------------------------------------------------------- */
#map {
    position: relative;
    overflow: hidden;
    height: 100%;
    background: #000;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

#supersurface {
    transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    -webkit-transform-origin: 0 0;
    -moz-transform-origin: 0 0;
    -o-transform-origin: 0 0;
}

#supersurface, .layer {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}


/* Map-In-Map
------------------------------------------------------- */
.map-in-map {
    position: absolute;
    overflow: hidden;
    top: 10px;
    width: 200px;
    height: 150px;
    z-index: 5;
    background: #000;
    border: #aaa 1px solid;
    box-shadow: 0 0 2em black;
}
[dir='ltr'] .map-in-map {
    left: 10px;
}
[dir='rtl'] .map-in-map {
    right: 10px;
}

.map-in-map-tiles {
    transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    -webkit-transform-origin: 0 0;
    -moz-transform-origin: 0 0;
    -o-transform-origin: 0 0;

    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.map-in-map-viewport,
.map-in-map-data {
    top: 0;
    left: 0;
    overflow: hidden;
    height: 100%;
    width: 100%;
}

.map-in-map-viewport {
    position: absolute;
}

.map-in-map-data {
    position: relative;
    z-index: 10;
}

.map-in-map-bbox {
    fill: none;
    stroke: rgba(255, 255, 0, 0.75);
    stroke-width: 1;
    shape-rendering: crispEdges;
}

.map-in-map-bbox.thick {
    stroke-width: 5;
}


/* Debug Data
------------------------------------------------------- */
.debug {
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
}
.map-in-map-data .debug {
    stroke-width: 1;
}

.nocolor { color: rgba(0, 0, 0, 0); }
.red     { color: rgba(255, 0, 0, 0.75); }
.green   { color: rgba(0, 255, 0, 0.75); }
.blue    { color: rgba(176, 176, 255, 0.75); }
.yellow  { color: rgba(255, 255, 0, 0.75); }
.cyan    { color: rgba(0, 255, 255, 0.75); }
.magenta { color: rgba(255, 0, 255, 0.75); }
.orange  { color: rgba(255, 153, 0, 0.75); }
.pink    { color: rgba(255, 0, 153, 0.75); }
.purple  { color: rgba(153, 0, 255, 0.75); }

.debug-legend {
    position: absolute;
    top: 70px;
    right: 80px;
    padding: 5px;
    border-radius: 4px;
    pointer-events: none;
}

.debug-legend-item {
    padding-right: 5px;
}
.debug-legend-item:before {
    content: "\25A0";
    padding: 0 5px;
}


.over-map {
    position: absolute;
    left: 0;
    right: 0;
    top: 71px;
    bottom: 30px;
    pointer-events: none;
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-end;
}
.over-map > * {
    pointer-events: auto;
}

/* Information Panels
------------------------------------------------------- */
.info-panels {
    display: flex;
    flex-flow: row-reverse wrap-reverse;
    width: 100%;
    z-index: 1;
    -ms-user-select: element;
    pointer-events: none;
}

.panel-container h1,
.panel-container h2,
.panel-container h3,
.panel-container h4,
.panel-container h5 {
    display: inline-block;
    margin-bottom: 0;
}

.panel-container h1,
.panel-container h2,
.panel-container h3 {
    color: #ff8;
}

.panel-container {
    flex: 0 0 auto;
    margin: 0 2px 2px 0;
    border-radius: 4px;
    border: 1px solid rgba(0, 0, 0, 0.75);
    padding-bottom: 10px;
    width: 250px;
    pointer-events: auto;
}

.panel-container .panel-title {
    border-radius: 4px 4px 0 0;
}

.panel-title {
    padding: 5px 10px;
}

.panel-title button.close {
    float: right;
    height: 20px;
    background: none;
    color: #ddd;
}
[dir='rtl'] .panel-title button.close {
    float: left;
}

.panel-title button.close:hover {
    color: #fff;
}
.panel-title button.close .icon {
    height: 20px;
    width: 16px;
}

.panel-content {
    padding: 5px 10px;
    position: relative;
}

.panel-content li span {
    display: inline-block;
    white-space: nowrap;
    margin: 0 8px;
}

.panel-content .button {
    display: inline-block;
    background: #7092ff;
    border-radius: 2px;
    padding: 0 4px;
    margin-top: 10px;
    margin-right: 10px;
    color: #fff;
}
[dir='rtl'] .panel-content .button {
    margin-right: auto;
    margin-left: 10px;
}

.panel-content-history .links a {
    margin-left: 8px;
}
[dir='rtl'] .panel-content-history .links a {
    margin-left: auto;
    margin-right: 8px;
}
.panel-content-history h4 {
    padding-bottom: 0;
}
.panel-content-location .location-info {
    margin-top: 10px;
}


/* About Section, Attribution, Footer
------------------------------------------------------- */
#about {
    width: 100%;
    position: absolute;
    right: 0;
    bottom: 0;
    border-radius: 0;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    -ms-user-select: element;
}

#attrib {
    width: 100%;
    height: 20px;
    margin-bottom: 5px;
}

#attrib * { pointer-events: all; }

.base-layer-attribution,
.overlay-layer-attribution {
    position: absolute;
    color: #ccc;
    font-size: 10px;
}

.base-layer-attribution {
    left: 10px;
}

.overlay-layer-attribution {
    right: 10px;
}

.overlay-layer-attribution .attribution:not(:last-child):after {
    content: '; ';
}

.attribution a,
.attribution a:visited {
    color: #ccf;
}

.attribution a:hover {
    color: #aaf;
}

.attribution .source-image {
    height: 20px;
    vertical-align: middle;
    border-radius: 3px;
}

.attribution span {
    margin: 0 3px;
}

#footer {
    pointer-events: all;
    display: block;
    height: 30px;
}


/* Footer - Flash messages
------------------------------------------------------- */
#flash-wrap {
    display: flex;
    flex: 0 0 100%;
    flex-flow: row nowrap;
    justify-content: space-between;
    max-height: 30px;
    position: absolute;
    right: 0;
    left: 0;
}

.flash-content {
    display: flex;
    flex: 1 0 auto;
    flex-flow: row nowrap;
    align-items: center;
    padding: 2px;
    height: 30px;
}

.flash-icon {
    flex: 0 0 auto;
    width: 20px;
    height: 20px;
    margin: 0 8px;
}

.flash-icon circle {
    fill: #eee;
}
.flash-icon.disabled circle {
    cursor: auto;
    fill: rgba(255,255,255,0.7);
}

.flash-icon use {
    color: #222;
}
.flash-icon.disabled use {
    color: rgba(32,32,32,0.7);
}

.flash-icon.operation use {
    fill: #222;
    color: #79f;
}
.flash-icon.operation.disabled use {
    fill: rgba(32,32,32,0.7);
    color: rgba(40,40,40,0.7);
}

.flash-text {
    flex: 1 1 auto;
}

#footer-wrap {
    display: flex;
    flex: 0 0 100%;
    flex-flow: row nowrap;
    justify-content: space-between;
    max-height: 30px;
    position: absolute;
    right: 0;
    left: 0;
}

.footer-show {
    bottom: 0px;
    transition: bottom 75ms linear;
    -moz-transition: bottom 75ms linear;
    -webkit-transition: bottom 75ms linear;
}

.footer-hide {
    bottom: -35px;
    transition: bottom 75ms linear;
    -moz-transition: bottom 75ms linear;
    -webkit-transition: bottom 75ms linear;
}


/* Footer - Scale bar, About, Source Switcher
------------------------------------------------------- */
#scale-block {
    vertical-align: bottom;
    width: 250px;
    max-height: 30px;
    flex: 0 0 250px;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

#info-block {
    max-height: 30px;
    flex: 1 1 auto;
}

#scale {
    height: 30px;
    width: 100%;
}
[dir='rtl'] #scale {
    transform: scaleX(-1);
}

#scale:hover {
    cursor: pointer;
}

#scale text {
    font: 12px sans-serif;
    stroke: none;
    fill: #ccc;
    text-anchor: start;
}
[dir='rtl'] #scale text {
    transform: scaleX(-1);
}

#scale path {
    fill: none;
    stroke: #ccc;
    stroke-width: 1;
    shape-rendering: crispEdges;
}

#about-list {
    text-align: right;
    margin-right: 10px;
    clear: right;
    overflow: hidden;
}
[dir='rtl'] #about-list {
    text-align: left;
    clear: left;
    margin-left: 10px;
    margin-right: 0;
}

#about-list li {
    float: right;
    border-left: 1px solid rgba(255,255,255,.5);
    padding: 5px 0 5px 5px;
    margin-left: 5px;
}
[dir='rtl'] #about-list li {
    float: left;
    border-left: none;
    border-right: 1px solid rgba(255,255,255,.5);
    margin-left: 0;
    margin-right: 5px;
    padding: 5px 5px 5px 0;
}
#about-list li:empty {
    display: none;
}

#about-list li:last-child {
    border-left: 0;
    margin-left: 0;
    padding-left: 0;
}
[dir='rtl'] #about-list li:last-child {
    border-right: none;
}

#about-list a.chip {
    padding: 2px 4px 3px 4px;
    border-radius: 2px;
    color: #eee;
}
#about-list a.chip .icon {
    width: 14px;
    height: 14px;
    margin-top: 3px;
}
[dir='ltr'] #about-list a.chip .icon,
[dir='ltr'] #about-list a.chip span {
    margin-right: 3px;
}
[dir='rtl'] #about-list a.chip .icon,
[dir='rtl'] #about-list a.chip span {
    margin-left: 3px;
}

.source-switch a.chip.live {
    background: #d32232;
    color: #fff;
}

.feature-warning a.chip {
    background: #1e90ff;
}

.issues-info a.chip.resolved-count {
    background: #15911E;
}
.issues-info a.chip.warnings-count {
    background: #DF8500;
}
[dir='ltr'] .issues-info a.chip:not(:last-child) {
    margin-right: 5px;
}
[dir='rtl'] .issues-info a.chip:not(:last-child) {
    margin-left: 5px;
}

.user-list a:not(:last-child):after {
    content: ', ';
}

.api-status {
    text-align: right;
    padding: 1px 10px;
    color: #eee;
    flex: 1 1 auto;
}
[dir='rtl'] .api-status {
    text-align: left;
}

.api-status.offline,
.api-status.readonly,
.api-status.error {
    background: #a22;
}

.api-status a {
    text-decoration: underline;
    color: #ccc;
    pointer-events: all;
}
.api-status a:hover {
    color: inherit;
}

/* Notification Badges
------------------------------------------------------- */
/* For an icon (e.g. new version) */
.badge {
    display: inline-block;
    background: #d32232;
    width: 21px;
    height: 20px;
    border-radius: 11px;
    margin-left: 6px;
}
[dir='rtl'] .badge {
    margin-left: 0;
    margin-right: 6px;
}
.badge a {
    margin-right: 5px;
}
[dir='rtl'] .badge a {
    margin-right: 0;
    margin-left: 5px;
}
.badge .icon {
    vertical-align: baseline;
    width: 11px;
    height: 11px;
    color: #fff;
}

/* For text (e.g. upcoming events) */
.badge-text {
    display: inline-block;
    color: #fff;
    text-align: center;
    width: 16px;
    height: 16px;
    font-size: 10px;
    font-weight: bold;
    margin-left: 5px;
    background: #f00;
    border-radius: 9px;
}
[dir='rtl'] .badge-text {
    margin-left: 0;
    margin-right: 5px;
}


/* Modals / Prompts
------------------------------------------------------- */
.modal {
    top: 40px;
    display: inline-block;
    position: absolute;
    border-radius: 3px;
    overflow: hidden;
    left: 0;
    right: 0;
    margin: auto;
    z-index: 50;
    width: 50%;
    min-width: 200px;
    max-width: 600px;
}

.modal .loader {
    margin-bottom: 10px;
}
.modal .description {
    text-align: center;
}

.shaded {
    z-index: 5000;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: auto;
}
.shaded:before {
    content:'';
    background: rgba(0,0,0,0.5);
    position: absolute;
    left: 0px; right: 0px; top: 0px; bottom: 0px;
}

.modal-section {
    padding: 20px;
    border-bottom: 1px solid #ccc;
}
.modal-section p:not(:last-of-type) {
    padding-bottom: 20px;
}
.modal-section.header h3 {
    padding: 0;
}
.modal-section.buttons {
    text-align: center;
}

.modal-section.buttons button {
    min-width: 130px;
}

.modal-section.buttons .action {
    display: inline-block;
    margin: 0 10px;
    text-align: center;
    vertical-align: middle;
}

.save-section .buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    margin-bottom: 30px;
}

.save-section .buttons .action,
.save-section .buttons .secondary-action {
    width: 45%;
    margin: 10px auto;
    text-align: center;
    vertical-align: middle;
}

.loading-modal {
    text-align: center;
}
.modal-actions {
    display: flex;
}
.modal-actions button {
    font-weight: normal;
    color: #7092ff;
    border-bottom: 1px solid #ccc;
    border-radius: 0;
    height: 160px;
    text-align: center;
    width: 100%;
}
.modal-actions button:hover {
    background-color: #ececec;
}

.logo-small {
    height: 40px;
    width: 40px;
    margin: auto;
}

.logo {
    height: 100px;
    width: 100%;
    max-width: 100px;
    margin: auto;
}

.modal-actions > :first-child {
    border-right: 1px solid #ccc;
}

.modal-section:last-child {
    border-bottom: 0;
}

/* Restore Modal
------------------------------------------------------- */
.modal-actions .logo-restore {
    color: #7092ff;
}
.modal-actions .logo-reset {
    color: #e06c5e;
}

/* Success Screen / Community Index
------------------------------------------------------- */
.save-success.body {
    overflow-y: scroll;
    overflow-x: hidden;
}

.save-success .link-out {
    margin: 0px 5px;
    white-space: nowrap;
}

.save-summary,
.save-communityLinks {
    padding: 0px 20px 15px 20px;
}

.save-communityLinks {
    border-top: 1px solid #ccc;
}

.save-success table,
.save-success p {
    margin-top: 15px;
}
.save-success h3 {
    font-size: 14px;
    margin-top: 15px;
    line-height: 1.5;
    padding-bottom: 0;
}
.save-success td {
    vertical-align: top;
}
.save-success td.cell-icon {
    width: 40px;
}
.save-success td.cell-detail {
    padding: 0 10px;
}
.save-success td.community-detail {
    padding-bottom: 15px;
}

.summary-view-on-osm,
.community-name {
    font-size: 14px;
    font-weight: bold;
}
.community-languages {
    margin-top: 5px;
    font-style: italic;
}
.community-languages:only-child {
    margin-top: 0;
}

.community-detail a.hide-toggle,
.community-detail a:visited.hide-toggle {
    font-size: 12px;
    font-weight: normal;
    padding-bottom: 0;
}
.community-detail .hide-toggle svg.icon.pre-text {
    width: 12px;
    height: 15px;
}

.community-events {
    margin-top: 5px;
}

.community-event,
.community-more {
    background-color: #efefef;
    padding: 8px;
    border-radius: 4px;
    margin-bottom: 5px;
}

.community-event-name {
    font-size: 14px;
    font-weight: bold;
}
.community-event-when {
    font-weight: bold;
}

.community-missing {
    padding: 10px;
    text-align: center;
}


/* Splash Modal
------------------------------------------------------- */
.modal-actions .logo-walkthrough,
.modal-actions .logo-features {
    color: #7092ff;
}


/* Shortcuts Modal
------------------------------------------------------- */
.modal-shortcuts {
    width: 90%;
    max-width: 950px;
}

.modal-shortcuts .modal-section:last-child {
    padding-top: 10px;
    min-height: 275px;
}

.modal-shortcuts .tabs-bar {
    text-align: center;
    padding-bottom: 5px;
    font-size: 16px;
    font-weight: bold;
}

.modal-shortcuts .tab {
    display: inline-block;
    padding: 5px 10px;
    margin: 0 5px;
    cursor: pointer;
    color: #666;
}
.modal-shortcuts .tab.active {
    color: #7092ff;
    border-bottom: 2px solid;
}
.modal-shortcuts .tab:hover {
    color: #597be7;
    background-color: #efefef;
}

.modal-shortcuts .shortcut-tab {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
}

.modal-shortcuts .shortcut-column {
    width: auto;
}

.modal-shortcuts .shortcut-tab-tools .shortcut-column {
    flex: 1 1 100%;
    width: 100%;
}

.modal-shortcuts td {
    padding-bottom: 5px;
}

.modal-shortcuts .shortcut-section {
    padding: 20px 0 10px 0;
}

.modal-shortcuts .shortcut-keys {
    padding: 0 10px;
    color: #767676;
    text-align: right;
    white-space: nowrap;
}
[dir='rtl'] .modal-shortcuts .shortcut-keys {
    text-align: left;
}

.modal-shortcuts .shortcut-keys kbd {
    color: #555;
}

svg.mouseclick use.left {
    fill: rgba(112, 146, 255, 1);
    color: rgba(112, 146, 255, 0);
}
svg.mouseclick use.right {
    fill: rgba(112, 146, 255, 0);
    color: rgba(112, 146, 255, 1);
}

.modal-shortcuts .shortcut-keys .gesture {
    color: #333;
    padding: 3px;
}


/* Settings Modals
------------------------------------------------------- */
.settings-modal textarea {
    height: 70px;
    width: 100%;
}

.settings-custom-background .instructions-template {
    margin-bottom: 20px;
}

.settings-custom-data .instructions-url {
    margin-bottom: 10px;
}
.settings-custom-data .field-file,
.settings-custom-data .instructions-template {
    margin-bottom: 20px;
}


/* Save Mode
------------------------------------------------------- */
.mode-save a.user-info {
    display: inline-block;
}

.mode-save .commit-form {
    margin-bottom: 0;
}

.mode-save .user-info img {
    float: left;
}

.mode-save h3 small.count {
    margin-right: 10px;
    text-align: center;
    float: left;
    height: 12px;
    min-width: 12px;
    font-size: 12px;
    line-height: 12px;
    border-radius: 24px;
    padding: 5px;
    background: #7092ff;
    color: #fff;
}

.note-save .field-warning,
.mode-save .field-warning {
    background: #ffb;
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 10px;
}

.note-save .field-warning:empty,
.mode-save .field-warning:empty {
    display: none;
}

.mode-save .field-warning,
.mode-save .changeset-info,
.mode-save .request-review,
.mode-save .commit-info {
    margin-bottom: 10px;
}

.mode-save .request-review label {
    cursor: pointer;
}

.mode-save .changeset-list {
    border: 1px solid #ccc;
    border-radius: 4px;
    background: #fff;
    margin-bottom: 10px;
}

.mode-save .warning-section .changeset-list button {
    border-left: 1px solid #ccc;
}

.mode-save .changeset-list li {
    position: relative;
    border-top: 1px solid #ccc;
    padding: 5px 10px;
    cursor: pointer;
}

.mode-save .changeset-list li:hover {
    background-color: #ececec;
}

.mode-save .changeset-list .alert {
    opacity: 0.5;
}

.changeset-list li span.count {
    font-size: 10px;
    color: #555;
}

.mode-save .commit-section .changeset-list button {
    border-left: 1px solid #ccc;
}

.changeset-list li span.count:before { content: '('; }

.changeset-list li span.count:after { content: ')'; }

.changeset-list li:first-child { border-top: 0;}


/* Conflict resolution
------------------------------------------------------- */
.conflicts-help {
    padding: 20px;
    background-color: #ffffbb;
    border-bottom: 1px solid #ccc;
}

.conflicts-buttons {
    padding: 20px;
}

.mode-save button.conflicts-button {
    float: left;
}

.conflict-container {
    border-bottom: 1px solid #ccc;
}

.conflict-description {
    padding: 5px 20px;
    display: block;
}

.conflicts-done {
    padding: 20px 20px 0 20px;
}

.conflict-detail-container {
    padding: 10px 20px;
}

.conflict-count {
    padding: 10px 20px;
}

.conflict-choices {
    margin-top: 10px;
}

.conflict-nav-buttons {
    padding: 10px 0 20px 0;
}

.conflict-nav-button {
    height: 30px;
}


/* Notices (Zoom in to Edit)
------------------------------------------------------- */
.notice {
    position: absolute;
    top: 15px;
    left: 0;
    right: 0;
    text-align: center;
}

.notice .zoom-to {
    margin: auto;
    width: 300px;
    height: 70px;
    font-size: 150%;
    border-radius: 8px;
}

.notice .zoom-to:hover,
.notice .zoom-to:focus {
    background: rgba(0,0,0,0.6);
}

.notice .zoom-to .icon {
    width: 30px;
    height: 30px;
    vertical-align: middle;
    margin-right: 10px;
}
[dir='rtl'] .notice .zoom-to .icon {
    margin-left: 10px;
    margin-right: 0;
}


/* Tooltips
------------------------------------------------------- */
.popover {
    position: absolute;
    display: none;
}
.tooltip {
    color: #333;
    font-size: 12px;
    white-space: initial;
}
.tooltip:not(.curtain-tooltip) {
    pointer-events: none;
}
.popover.in {
    z-index: 5000;
    height: auto;
    display: block;
}
.tooltip.in {
    opacity: 0.95;
}
.popover.top {
    margin-top: -4px;
}
.popover.right {
    margin-left: 4px;
}
.popover.bottom {
    margin-top: 4px;
}
.popover.left {
    margin-left: -4px;
}
.popover.arrowed.top {
    margin-top: -10px;
}
.popover.arrowed.right {
    margin-left: 10px;
}
.popover.arrowed.bottom {
    margin-top: 10px;
}
.popover.arrowed.left {
    margin-left: -10px;
}
.bar-button .tooltip.arrowed.bottom {
    margin-top: 20px;
}
.tooltip.top {
    text-align: center;
}
.tooltip.right {
    text-align: left;
}
.tooltip.bottom {
    text-align: center;
}
.tooltip.left {
    text-align: right;
}

.popover-inner {
    border-radius: inherit;
}

.tooltip .popover-inner {
    border-radius: 4px;
    max-width: 200px;
    min-width: 80px;
    padding: 10px;
    font-weight: normal;
    background-color: #fff;
}

.tail {
    width: 200px;
    height: 400px;
    pointer-events: none;
    opacity: .8;
    margin-top: -200px;
    position: absolute;
    background: transparent;
}
.tail::after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
    top: 50%;
    right: -5px;
    margin-top: -5px;
    border-left-color: #fff;
    border-width: 5px 0 5px 5px;
}

.tail div {
    border-radius: 3px;
    padding: 10px;
    background: #fff;
    position: absolute;
    top: 180px;
    left: 0;
    right: 0;
    margin: auto;
}

.left.tail::after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
    top: 50%;
    left: -5px;
    margin-top: -5px;
    border-right-color: #fff;
    border-width: 5px 5px 5px 0;
}
.popover-arrow {
    position: absolute;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
}
.popover.top .popover-arrow {
    bottom: -5px;
    left: 50%;
    margin-left: -5px;
    border-top-color: #fff;
    border-width: 5px 5px 0;
}
.popover.right .popover-arrow {
    top: 50%;
    left: -5px;
    margin-top: -5px;
    border-right-color: #fff;
    border-width: 5px 5px 5px 0;
}
.popover.left .popover-arrow {
    top: 50%;
    right: -5px;
    margin-top: -5px;
    border-left-color: #fff;
    border-width: 5px 0 5px 5px;
}
.popover.bottom .popover-arrow {
    top: -5px;
    left: 50%;
    margin-left: -5px;
    border-bottom-color: #fff;
    border-width: 0 5px 5px;
}
.popover:not(.arrowed) .popover-arrow {
    display: none;
}

.tooltip-heading {
    font-weight: bold;
    background: #f6f6f6;
    padding: 10px;
    margin: -10px -10px 10px -10px;
    border-radius: 3px 3px 0 0;
    font-size: 14px;
}

.keyhint-wrap {
    background: #f6f6f6;
    padding: 10px;
    margin: 10px -10px -10px -10px;
    border-radius: 0 0 3px 3px;
}
.popover-inner .shortcut {
    font-weight: bold;
    margin-left: 5px;
}

[dir='rtl'] .popover-inner .shortcut {
    margin-left: 0;
    margin-right: 5px;
}

/* dark tooltips for sidebar / panels */
.tooltip.dark.top .popover-arrow,
.map-pane .tooltip.top .popover-arrow,
#sidebar .tooltip.top .popover-arrow {
    border-top-color: #000;
}
.tooltip.dark.bottom .popover-arrow,
.map-pane .tooltip.bottom .popover-arrow,
#sidebar .tooltip.bottom .popover-arrow {
    border-bottom-color: #000;
}
.tooltip.dark.left .popover-arrow,
.map-pane .tooltip.left .popover-arrow,
#sidebar .tooltip.left .popover-arrow {
    border-left-color: #000;
}
.tooltip.dark.right .popover-arrow,
.map-pane .tooltip.right .popover-arrow,
#sidebar .tooltip.right .popover-arrow {
    border-right-color: #000;
}
.tooltip.dark .popover-inner,
.tooltip.dark .tooltip-heading,
.tooltip.dark .keyhint-wrap,
.map-pane .popover-inner,
.map-pane .tooltip-heading,
.map-pane .keyhint-wrap,
#sidebar .popover-inner,
#sidebar .tooltip-heading,
#sidebar .keyhint-wrap {
    background: #000;
    color: #ccc;
}
.tooltip.dark kbd,
.map-pane .tooltip kbd,
#sidebar .tooltip kbd {
    background-color: #666;
    border: solid 1px #444;
    border-bottom-color: #333;
    box-shadow: inset 0 -1px 0 #333;
    color: #eee;
}

/* Exceptions for tooltip layouts */

/* commit warning tooltips need to be closer */
.warning-section .tooltip.top {
    margin-top: -5px;
}

li:first-of-type .badge .tooltip,
li.hide + li.version .badge .tooltip {
    left: auto !important;
    right: 5px !important;
}
[dir='rtl'] li:first-of-type .badge .tooltip,
[dir='rtl'] li.hide + li.version .badge .tooltip {
    left: 5px !important;
    right: auto !important;
}
li:first-of-type .badge .tooltip .popover-arrow,
li.hide + li.version .badge .tooltip .popover-arrow {
    right: 15px !important;
    left: auto !important;
}
[dir='rtl'] li:first-of-type .badge .tooltip .popover-arrow,
[dir='rtl'] li.hide + li.version .badge .tooltip .popover-arrow {
    left: 15px !important;
    right: auto !important;
}


/* Contextual Radial Menu (deprecated)
------------------------------------------------------- */
.radial-menu-tooltip {
    opacity: 0.8;
    display: none;
    position: absolute;
    width: 200px;
}

.radial-menu-background {
    fill: none;
    stroke: black;
    stroke-opacity: 0.5;
}

.radial-menu-item circle {
    fill: #eee;
}

.radial-menu-item circle:active,
.radial-menu-item circle:hover {
    fill: #fff;
}

.radial-menu-item.disabled circle {
    cursor: auto;
    fill: rgba(255,255,255,.5);
}

.radial-menu-item use {
    fill: #222;
    color: #79f;
}

.radial-menu-item.disabled use {
    fill: rgba(32,32,32,.5);
    color: rgba(40,40,40,.5);
}


/* Contextual Edit Menu
------------------------------------------------------- */
.edit-menu-tooltip {
    width: 200px;
}

.edit-menu-background {
    fill: #eee;
}

.edit-menu-item rect {
    fill: #eee;
    cursor: default;
}

.edit-menu-item rect:active,
.edit-menu-item rect:hover {
    fill: #ccc;
}

.edit-menu-item.disabled rect {
    cursor: not-allowed;
}
.edit-menu-item.disabled rect:hover {
    cursor: not-allowed;
    fill: #eee;
}

.edit-menu-item use {
    fill: #222;
    color: #79f;
    pointer-events: none;
}
.edit-menu-item.disabled use {
    fill: rgba(32,32,32,.2);
    color: rgba(40,40,40,.2);
}


/* Lasso
------------------------------------------------------- */
.lasso-path {
    fill-opacity: 0.3;
    stroke: #fff;
    stroke-width: 1;
    stroke-opacity: 1;
    stroke-dasharray: 5, 5;
}


/* Scrollbars
 ----------------------------------------------------- */
::-webkit-scrollbar {
    height: 20px;
    overflow: visible;
    width: 10px;
    background: #fff;
    border-left: 1px solid #DDD;
}

::-webkit-scrollbar-track {
    background-clip: padding-box;
    border: solid transparent;
    border-width: 0;
}

::-webkit-scrollbar-thumb {
    background-color: rgba(0,0,0,.2);
    background-clip: padding-box;
    border: solid transparent;
    border-width: 3px 3px 3px 4px;
    border-radius: 6px;
}
::-webkit-scrollbar-track:hover,
::-webkit-scrollbar-track:active {
    background-color: rgba(0,0,0,.05);
}


/* Intro walkthrough
 ----------------------------------------------------- */
.curtain-darkness {
    pointer-events: all;
    fill-opacity: 0.7;
    fill: #222;
    fill-rule: evenodd;
}

.intro-nav-wrap {
    display: flex;
    flex-direction: row;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 30px;
    padding: 10px;
    z-index: 1001;
}

.intro-nav-wrap .intro-nav-wrap-logo {
    flex: 0 0 auto;
    height: 40px;
    width: 40px;
    color: #fff;
    margin: 0px 20px;
    vertical-align: middle;
}

.intro-nav-wrap .joined {
    flex: 1 1 auto;
    display: flex;
    flex-direction: row;
}

.intro-nav-wrap button.chapter {
    flex: 1 1 100%;
    padding: 0px 20px;
}

.intro-nav-wrap button.chapter.next {
    animation-duration: 1s;
    animation-name: pulse;
    animation-iteration-count: infinite;
    animation-direction: alternate;
}
@keyframes pulse {
    from  { background: #7092ff; }
    to    { background: #c6d4ff; }
}

.intro-nav-wrap button.chapter.finished {
    background: #8cd05f;
}

.intro-nav-wrap button.chapter .status {
    display: none;
}

.intro-nav-wrap button.chapter.finished .status {
    display: inline-block;
}

.curtain-tooltip.tooltip.in {
    opacity: 1;
}
.curtain-tooltip.tooltip {
    text-align: left;
}
[dir='rtl'] .curtain-tooltip.tooltip {
    text-align: right;
}

.curtain-tooltip .popover-inner {
    font-size: 15px;
    position: relative;
    padding: 20px;
}

.curtain-tooltip .popover-inner .button-section,
.curtain-tooltip .popover-inner .instruction {
    font-weight: bold;
    display: block;
    border-top: 1px solid #ccc;
    margin-top: 10px;
    margin-left: -20px;
    margin-right: -20px;
    padding: 10px 20px 0 20px;
}

.curtain-tooltip .popover-inner .button-section button {
    width: 66.6666%;
}

.curtain-tooltip .popover-inner .instruction:only-child {
    border: 0;
    padding: 0;
    margin: 0;
}

.curtain-tooltip .popover-inner .icon.pre-text {
    vertical-align: text-top;
    margin-right: 0;
    margin-left: 0;
    display: inline-block;
}

.curtain-tooltip.intro-points-describe ,
.curtain-tooltip.intro-lines-name_road {
    top: 133px !important;
}

.tooltip-illustration {
    height: 80px;
    width: 200px;
    margin-left: -20px;
    margin-top: -10px;
}
[dir='rtl'] .tooltip-illustration {
    margin-left: auto;
    margin-right: -20px;
}

.curtain-tooltip.intro-mouse {
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.curtain-tooltip.intro-mouse .counter {
    position: absolute;
    display: block;
    top: 50px;
    width: 100%;
    text-align: center;
    font-weight: bold;
    font-size: 14px;
    z-index: 1003;
}

.curtain-tooltip.intro-mouse .tooltip-illustration use {
    fill: rgba(112, 146, 255, 0);
    color: rgba(112, 146, 255, 0);
}
.curtain-tooltip.intro-mouse.leftclick .tooltip-illustration use {
    fill: rgba(112, 146, 255, 1);
}
.curtain-tooltip.intro-mouse.rightclick .tooltip-illustration use {
    color: rgba(112, 146, 255, 1);
}

.huge-modal-button {
    width: 100%;
    height: auto;
    padding: 20px;
}

.huge-modal-button .illustration {
    height: 100px;
    width: 100px;
    color: #7092ff;
}


.list-item-photos.list-item-mapillary-map-features .request-data-link {
    float: right;
    margin-top: -20px;
}
[dir='rtl'] .list-item-photos.list-item-mapillary-map-features .request-data-link {
    float: left;
}
