X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/2ef2d7c876168d6beb606b655470f48ffabc8841..726db77827fa71133cc9762c3bf295189269ebb5:/app/assets/stylesheets/common.css.scss diff --git a/app/assets/stylesheets/common.css.scss b/app/assets/stylesheets/common.css.scss index 8f500acea..d8b843000 100644 --- a/app/assets/stylesheets/common.css.scss +++ b/app/assets/stylesheets/common.css.scss @@ -1,11 +1,115 @@ +/* Parameters */ +$lineheight: 20px; +$typeheight: 14px; + +$offwhite: #f4f4ff; +$blue: #7092FF; +$lightblue: #B8C5F0; +$green: #7ebc6f; +$grey: #CCC; +$red: red; +$lightgrey: #EEE; +$darkgrey: #AAA; +$hovercolor: 20%; +$headerHeight: 54px; +$sidebarWidth: 300px; +$keyline: 1px solid $lightgrey; +$border-radius: 3px; + /* Styles common to large and small screens */ +/* Minimal CSS reset */ + +html, body, ul, ol, li, form, fieldset, legend, h1, h2, h3, h4, h5, h6, p, input { + margin: 0; + padding: 0; + border: 0; + font-size:100%; +} + +fieldset,img { border: 0; } + +legend { color: #000; } + +sup { vertical-align: text-top; } + +sub { vertical-align: text-bottom; } + +table { + border-collapse: collapse; + border-spacing: 0; +} + +li { list-style: none; } + +input, +select, +textarea, +body { font: #{$typeheight}/#{$lineheight} "Helvetica Neue",Arial,sans-serif; } + +abbr, acronym { + border-bottom: .1em dotted; + cursor: help; +} + +strong { font-weight: 500; } + +/* Micro Clearfix | Details: http://nicolasgallagher.com/micro-clearfix-hack/ */ + +.clearfix:before, +.clearfix:after { + content: " "; + display: table; +} + +.clearfix:after { + clear: both; +} + +/* Basic grid */ + +.col0 { float:left; width:04.1666%; } +.col1 { float:left; width:08.3333%; } +.col2 { float:left; width:16.6666%; } +.col3 { float:left; width:25.0000%; } +.col4 { float:left; width:33.3333%; } +.col5 { float:left; width:41.6666%; } +.col6 { float:left; width:50.0000%; } +.col7 { float:left; width:58.3333%; } +.col8 { float:left; width:66.6666%; } +.col9 { float:left; width:75.0000%; } +.col10 { float:left; width:83.3333%; } +.col11 { float:left; width:91.6666%; } +.col12 { width:100%; } + +.margin0 { margin-left:04.1666%; } +.margin1 { margin-left:08.3333%; } +.margin2 { margin-left:16.6666%; } +.margin3 { margin-left:25.0000%; } +.margin4 { margin-left:33.3333%; } +.margin5 { margin-left:41.6666%; } +.margin6 { margin-left:50.0000%; } +.margin7 { margin-left:58.3333%; } +.margin8 { margin-left:66.6666%; } +.margin9 { margin-left:75.0000%; } +.margin10 { margin-left:83.3333%; } +.margin11 { margin-left:91.6666%; } +.margin12 { margin-left:100.0000%; } + +.fillL { background-color: white; } + /* Default rules for the body of every page */ +* { + -webkit-box-sizing: border-box; + -moz-box-sizing: border-box; + box-sizing: border-box; +} + body { font-family: 'Helvetica Neue',Arial,sans-serif; - font-size: 14px; - line-height: 20px; + font-size: $typeheight; + line-height: 1.6666; color: #222; background-color: #fff; margin: 0px; @@ -17,15 +121,81 @@ body.slim { background-color: #f0f0f0; } +h1, h2, h3 { + font-weight: 500; + line-height: 1.2; +} + +h4, h5 { font-weight: 500; } + +h1 { + font-size: 18px; +} + +h2, h3 { + font-size: 16px; +} + +p > img { + width: auto; + max-width: 100%; +} + +small, aside { + font-size: 12px; +} + +.column-1 { + width: 50%; + margin: 0 0 $lineheight/2 0; +} + +.small_icon { + vertical-align: middle; + margin-right: $lineheight/4; +} + +.red { color: $red; } + +/* Rules for icons */ + +.icon { + display:inline-block; + vertical-align:top; + width:20px; + height:20px; + background:transparent image-url("sprite.png") no-repeat 0 0; + text-indent:-9999px; + overflow:hidden; +} + +.icon.search { background-position: 0 0; } +.icon.donate { background-position: -20px 0; } +.icon.zoomin { background-position: -40px 0; } +.icon.zoomout { background-position: -60px 0; } +.icon.geolocate { background-position: -80px 0; } +.active .icon.geolocate { background-position: -80px -20px; } +.icon.layers { background-position: -100px 0; } +.icon.key { background-position: -120px 0; } +.icon.share { background-position: -140px 0; } +.icon.clipboard { background-position: -160px 0; } +.icon.link { background-position: -180px 0; } +.icon.close { background-position: -200px 0; } +.icon.close:hover { background-position: -200px -20px; } +.icon.check { background-position: -220px 0; } +.icon.note { background-position: -240px 0; } +.icon.gear { background-position: -260px 0; } + /* Rules for links */ a { color: #00f; text-decoration: none; -} - -a:hover { - text-decoration: underline; + -webkit-appearance: none; + outline: 0; + &:hover { + text-decoration: underline; + } } /* Rules for horizontal lines */ @@ -37,467 +207,653 @@ hr { height: 1px; } -/* Default rules for headings */ +/* General styles for tables */ -h2 { - margin: 5px 0; - font-size: 25px; - line-height: 30px; +table { + width: 100%; + margin-bottom: $lineheight; + th, td { + text-align: left; + padding: $lineheight/4; + line-height: $lineheight; + } + th { + font-weight: 500; + vertical-align: top; + } + td { + vertical-align: middle; + } } -/* Rules for the whole left sidebar, including the logo */ +/* Utility for de-emphasizing content */ -#left { - position: absolute; - top: 30px; - bottom: 0; - width: 185px; - font-size: 11px; - line-height: 12px; - border-right: 1px solid #ccc; +.deemphasize { + color: #999; + a { + color: $blue; + } } -/* Rules for the OpenStreetMap logo in the top left corner */ +/* Rules for the header */ -#logo { +#menu-icon { + display: none !important; + float: right; + background: url("/assets/menu-icon.png") no-repeat; + background-size: 30px 30px; display: block; - width: 170px; - min-width: 170px; - padding: 5px; - text-align: center; - margin: auto; + width: 30px; + height: 30px; + margin: 14px 10px 0 0; + opacity: 0.6; } -#logo img { - border: 0px; -} +header { + height: $headerHeight; + position: relative; + z-index: 1001; + font-size: 13px; -#logo h1 { - font-size: 18px; - line-height: 20px; - text-align: center; - margin: 0px; -} + h1, nav, nav > ul, nav > ul > li, .dropdown { + display: inline-block; + } -#logo h2 { - font-size: 10px; - line-height: 15px; - margin: 0px; -} + > * { + height: 100%; + padding: $lineheight/2 $lineheight; + } -/* Rules for the site name */ + h1, nav.primary { + float: left; + } -#small-title { - display: none; -} + a, a:hover { + text-decoration: none; + } -#small-title img { - border: 0px; -} + img.logo { + width: 30px; + height: 30px; + margin-top: -4px; + vertical-align: middle; + } -/* Rules for the introductory text displayed in the left sidebar to new users */ + h1 { + margin: 0; + padding: ($lineheight - 3) $lineheight ($lineheight + 3); -.sidebar-copy { - padding: 5px 10px; + a { + color: #000; + } + } } -.sidebar-copy p { - margin: 5px 0; -} +nav.primary { + > ul { + $border: 1px solid $green; -.sidebar-copy.intro { - margin-top: -1px; - border-top: 1px solid #ccc; -} + border: $border; + border-radius: $border-radius; -/* - * Rules for alert boxes shown in the left sidebar when important - * information needs to be conveyed such as when the site is - * undergoing maintenance. - */ + > li { + border-right: $border; + float: left; + &:last-child { + border-right: 0; + > a { border-radius: 0 $border-radius $border-radius 0; } + } + &:first-child > a { border-radius: $border-radius 0 0 $border-radius; } + > a:hover { background: lighten($green, 30%); } + &.current > a:hover { background: $green; } + &.disabled > a:hover { background: lighten($green, 38%); } + &.dropdown { + > a.tab { border-right: 1px solid lighten($green, 30%); } + &.current > a.tab { border-right: 1px solid lighten($green, 10%); } + } + } + } -.sidebar-alert { - padding: 4px 5px 4px 5px; - border-top: 1px solid #ccc; - margin-top: 4px; - margin-bottom: -4px; - background: #e00; - font-size: 13px; - font-weight: bold; - line-height: 17px; + a.tab, + .dropdown-toggle { + display: inline-block; + font-weight: 500; + color: $green; + padding: 5px 15px; + } - p { - margin: 5px; + .dropdown-toggle { + padding: 5px 6px; } -} -/* - * Rules for notice boxes shown in the left sidebar when important, but - * non-critical information needs to be conveyed such as notices about - * donation drives. - */ + .caret { + border-top-color: $green; + margin-top: 10px; + } -.sidebar-notice { - padding: 4px 5px 4px 5px; - border-top: 1px solid #ccc; - margin-top: 4px; - margin-bottom: -4px; - background: #ea0; - font-size: 13px; - line-height: 17px; + .disabled a { + color: #ccc; + cursor: default; - p { - margin: 5px; + .caret { + border-top-color: #ccc; + } } -} -/* Rules for the menu displayed in the left sidebar */ + > ul li.current { + background-color: $green; -.left_menu { - left: 0px; - margin: 0; - padding: 5px 10px; - line-height: 15px; - font-size: 12px; - list-style-type: none; - border-bottom: 1px solid #ccc; - border-top: 1px solid #ccc; -} + .tab { + color: #fff; + } -.left_menu ul { - padding: 0; - margin: 0; + .caret { + border-top-color: #fff; + } + } } -.left_menu li { - list-style-type: none; - padding: 0; - margin: 0; -} +nav.secondary { + position: absolute; + right: 0; -.left_menu h4 { - padding: 5px 0 5px 0; - font-size: 12px; - margin: 0; -} + > ul { + vertical-align: middle; + a, .dropdown-toggle { + display: inline-block; + text-decoration: none; + color: $darkgrey; + padding: 5px; -.left_menu li:last-child h4 { - padding-top: 0; -} + &:hover { color: darken($darkgrey, 10%); } + } + } -/* Rules for SOTM advert */ + > ul li.current a { + color: darken($darkgrey, 25%); + } -#sotm { - width: 165px; - margin: 10px; - padding: 0px; - border: 0px; - background: #fff; -} + .user-menu { + $border: 1px solid $grey; -#sotm img { - width: 165px; -} + font-weight: 500; + border: $border; + border-radius: $border-radius; + margin-left: 10px; -/* - * Rules for "optional boxes" which appear in the left sidebar on - * certain pages. Current users are the seach box on the main page - * and the tag cloud on the traces pages. - */ + > li { + border-right: $border; + float: left; + &:last-child { + border-right: 0; -.optionalbox { - left: 0px; - padding: 5px 10px; - margin: 5px 0; - text-align: left; -} + > a { + border-radius: 0 $border-radius $border-radius 0; + } + } + &:first-child > a { border-radius: $border-radius 0 0 $border-radius; } + &:hover a { background: lighten($darkgrey, 30%); } + } -.optionalbox h1 { - font-size: 14px; - font-weight: bold; - line-height: 20px; - margin: 0px; - vertical-align: bottom; -} + a { + padding: 5px 15px; -/* Rules for the search box */ + } -.whereami { -} + &.logged-in > a { + padding: 0; + > .user-button { + padding: 5px 10px 5px 6px; + display: inline-block; + color: $darkgrey; + } + &:hover > .user-button { color: darken($darkgrey, 5%); } + } + } -#search_field form { - width: 165px; - margin: 0px; - padding: 0px; -} + .caret { + border-top-color: $grey; + margin-top: 9px; + } -#search_field { - position: relative; -} + img.user_thumbnail_tiny { + border: 0; + vertical-align: top; + margin-top: 0px; + margin: 3px 0 0 3px; + border-radius: 2px; + } -#search_field input[type="text"] { - width: 165px; - font-size: 14px; - line-height: 15px; - height: 25px; - padding: 2px 0px 2px 5px; - box-shadow: inset #DDD 0px 1px 3px; - box-sizing: border-box; - -webkit-box-sizing: border-box; - -moz-box-sizing: border-box; - -ms-box-sizing: border-box; -} + #inboxanchor { + display: inline-block; + vertical-align: top; + height: 25px; + margin: 3px 0 3px 3px; + background-color: lighten($grey, 10%); + line-height: 20px; + border-radius: 2; + } -#search_field input[type="text"]:focus { - outline: none; - border: 1px solid #000; -} + .dropdown-menu { + left: auto; + right: -1px; + border-radius: 3px 0 3px 3px; -#search_field input[type="submit"] { - width: 15px; - height: 15px; - border: 0px; - text-indent: -1000px; - overflow: hidden; - text-transform: capitalize; - padding-left: 0px; - padding-right: 0px; - background: image-url("sprite.png"); - position: absolute; - top: 5px; - right: 4px; - cursor: pointer; + .count-number { + float: right; + padding: 0 5px; + margin: 0; + } + } } -.search_help { - margin: 5px 0 0 0; +#compact-secondary-nav { + display: none; + ul li a { + width: 100%; + color: #333; + &:hover { color: #fff; } + } } -.deemphasize { - color: #999; +@media only screen and (max-width:960px) { + #compact-secondary-nav { + display: inline-block; + } + .compact-hide { + display: none; + } } -.deemphasize a { - color: #7092FF; -} -/* Rules for donation request box */ +/* Utility for styling notification numbers */ -.donate { - display: block; - position: relative; - width: 153px; - margin: 10px 10px 0px 10px; - padding: 5px; - border: 1px solid #AED1A0; - background: #cbeea7; - line-height: 20px; - text-align: center; - font-size: 14px; +.count-number { + padding: 2px $lineheight/4; border-radius: 2px; - -moz-border-radius: 2px; - color: #222; -} - -.donate:hover { - background: #9ed485; - text-decoration: none; + background: lighten($green, 30%); + margin: 0 2px; + font-size: 11px; + color: #333; } -.donate p { - text-indent: 20px; - margin: 0; -} +/* Rules for the message shown in place of the map when javascript is disabled */ -.donate .donate-icon { - width: 15px; - height: 15px; - border: 0px; - padding-left: 0px; - padding-right: 0px; - background: image-url("sprite.png") 0 -30px no-repeat; +#noscript { + z-index: 20000000; position: absolute; - top: 8px; - left: 17px; -} - -/* Rules for Creative Commons logo button */ - -#cclogo { - margin-top: 10px; - margin-bottom: 10px; + top: 15px; + left: 15px; } -/* Rules for tabbed navigation bar */ +/* Rules for bootstrap tooltips */ -#top-bar { +.tooltip { position: absolute; - top: 0; - left: 185px; - right: 0; - height: 29px; - border-bottom: 1px solid #ccc; - background: white; + display: none; + color: #333; + text-align: left; + font-size: 12px; + max-width: 250px; } -#tabnav { - padding: 0; - margin: 0; - overflow:hidden; +.tooltip.in { + opacity: 0.8; + z-index: 1030; + height: auto; + display: block; } -#tabnav li { - margin: 0px; - padding: 0px; - display: inline; - list-style-type: none; +.tooltip.top { + margin-top: -10px; + text-align: center; } -#tabnav a, #tabnav a:link, #tabnav a:visited { - float: left; - background: #fff; - font-size: 14px; - line-height: 19px; - font-weight: bold; - padding: 5px 10px; - margin-right: 1px; - text-decoration: none; - color: #333; - -webkit-transition: color 200ms ease-in; - -moz-transition: color 200ms ease-in; - -o-transition: color 200ms ease-in; - transition: color 200ms ease-in; +.tooltip.right { + margin-left: 10px; } -body.site-index #tabnav a#viewanchor, -body.site-edit #tabnav a#editanchor, -body.changeset-list #tabnav a#historyanchor, -body.site-export #tabnav a#exportanchor { - border-bottom: 1px solid #aaa; - background: #9ed485; - color: #000; +.tooltip.bottom { + margin-top: 10px; + text-align: center; } -#tabnav a:link:hover, #tabnav a:visited:hover { - text-decoration:underline; +.tooltip.left { + margin-left: -10px; + text-align: right; } -#tabnav a:link.disabled, -#tabnav a:visited.disabled, -#tabnav a:link:hover.disabled, -#tabnav a:visited:hover.disabled { - color: #ccc; - cursor: default; +.tooltip-inner { + display: inline-block; + padding: 10px; + font-weight: normal; + background-color: white; } -#tabnav a:link.disabled:hover, -#tabnav a:visited.disabled:hover, -#tabnav a:link:hover.disabled:hover, -#tabnav a:visited:hover.disabled:hover { - text-decoration: none; +.tooltip-arrow { + position: absolute; + width: 0; + height: 0; + border-color: transparent; + border-style: solid; } -.count-number { - padding: 2px 5px; - border-radius: 3px; - background: #eee; - margin: 0 2px; - font-size: 11px; - color: #333; +.tooltip.top .tooltip-arrow { + bottom: -5px; + left: 50%; + margin-left: -5px; + border-top-color: white; + border-width: 5px 5px 0; } -/* Rules for greeting bar in the top right corner */ +.tooltip.right .tooltip-arrow { + top: 50%; + left: -5px; + margin-top: -5px; + border-right-color: white; + border-width: 5px 5px 5px 0; +} -#greeting { - float: right; - height: 28px; - margin: 0px; - padding-right: 10px; - font-size: 13px; - line-height: 28px; +.tooltip.left .tooltip-arrow { + top: 50%; + right: -5px; + margin-top: -5px; + border-left-color: white; + border-width: 5px 0 5px 5px; } -.greeting-bar-unread { - font-weight: bold; +.tooltip.bottom .tooltip-arrow { + top: -5px; + left: 50%; + margin-left: -5px; + border-bottom-color: white; + border-width: 0 5px 5px; } -/* Rules for the message shown in place of the map when javascript is disabled */ +/* Rules for Leaflet maps */ -#noscript { - z-index: 20000000; - position: absolute; - top: 15px; - left: 15px; -} +.leaflet-control .control-button { + display: block; + height: 40px; + width: 40px; + background-color: #333; + background-color: rgba(0,0,0,.6); + border-radius: 4px 0 0 4px; + margin-bottom: 10px; + outline: none; -/* Rules for Leaflet maps */ + &:hover { + background-color: black; + } -#map { - margin: 0px; - border: 0px; - padding: 0px; + &.active { + background-color: #9ed485; + } + + &.disabled { + background-color: #333; + background-color: rgba(0,0,0,.5); + cursor: default; + } + + .icon { + margin: 10px; + } } -#permalink { - z-index: 10000; - position: absolute; - bottom: 0px; - right: 0px; - padding: 5px; - background:#fff; - text-align: right; - font-size: 12px; +.leaflet-control .zoomin, +.control-layers .control-button { + margin-bottom: 0px; + border-radius: 4px 0 0 0; } -#permalink a { - padding: 5px; +.leaflet-control .zoomout, +.control-key .control-button { + margin-bottom: 0; + border-radius: 0; } -.site-index .leaflet-top, -.site-export .leaflet-top { - top: 10px !important; +.control-locate .control-button, +.control-share .control-button { + border-radius: 0 0 0 4px; +} - .leaflet-control { - margin-top: 0px !important; +/* Rules for the sidebar and main map area */ + +.map-layout { + #content { + position: absolute; + top: $headerHeight; + bottom: 0; + width: 100%; + } + + #sidebar, #map { + position: relative; + height: 100%; + overflow-x: hidden; + overflow-y: auto; + } + + #sidebar { + float: left; + width: $sidebarWidth; + + h2, h3, h4 { + padding: $lineheight $lineheight $lineheight/2; + } + + h4, span.user, span.date { + font-weight: normal; + color: #666; + font-size: 12px; + } + + .icon.close { + position: absolute; + right: $lineheight; + cursor: pointer; + } + + .footer { + position: absolute; + bottom: 0; + } + + p.credits { + font-size: 11px; + color: #999; + + a { + color: #666; + } + } + + p.large-text { + font-size: 1.7em; + line-height: 1.4em; + font-weight: 300; + } + } + + #sidebar.minimized { + position: absolute; + z-index: 1000; + height: auto; + border-right: none; + + #sidebar_content { + display: none; + } + + #search_form { + background: none; + width: 78%; + } + } + + #map { + height: 100%; + overflow: hidden; + } + + #map-ui { + display: none; + position: relative; + float: right; + width: 250px; + height: 100%; + background: white; + overflow: auto; + + .section { + border-bottom: 1px solid #DDD; + padding: 10px 20px; + } + + a.close-button { + float: right; + padding:5px; + font-size:20px; + line-height:10px; + color:#222; + border:1px solid #ddd; + } } } -.site-index #map .olControlScaleLine, -.site-export #map .olControlScaleLine { - left: 10px !important; +.layers-ui, +.share-ui { + li:last-child { + margin-bottom: 0; + } } -/* Rules for edit menu */ +.layers-ui { + .base-layers { + .leaflet-container { + width: 100%; + height: 50px; + cursor: pointer; + } -.menuicon { - padding: 5px; + li { + overflow: hidden; + border-radius: 3px; + border: 2px solid #fff; + margin-bottom: 8px; + position: relative; + transition: border-color 0.08s ease-in; + + label { + position: absolute; + top: 0; + left: 0; + padding: 2px 6px; + border-bottom-right-radius: 3px; + cursor: pointer; + font-weight: 500; + font-size: 16px; + text-stroke: 2px #fff; + background: rgba(255,255,255,.9); + text-shadow: + -2px -2px 1px #fff, + 2px -2px 1px #fff, + -2px 2px 1px #fff, + 2px 2px 1px #fff; + input[type="radio"] { + display: none; + } + } - &:hover { - background: #eee; - text-decoration: none !important; + &.active { border-color: darken($green, 10%); } + &:hover { + border-color: $grey; + &.active { border-color: darken($green, 20%); } + } + } + } + + .overlay-layers { + p { + font-size: 13px; + margin-bottom: 8px; + } } } -.menu { - display: none; - z-index: 10000; - position: absolute; - background-color: #ffffff; - border: 1px solid #cccccc; - border-top: 0px; +.share-ui { + .share-tabs { + margin-bottom: 10px; + + a { + color: #fff; + text-decoration: none; + background-color: $lightblue; + padding: 5px 10px; + } + + a:first-child { + border-right: 1px solid #fff; + border-radius: 4px 0 0 4px; + } + + a:last-child { + border-left: 1px solid #fff; + border-radius: 0 4px 4px 0; + } + + a.active { + background-color: $blue; + } + } + + .share-tab { + display: none; + } + + .share-link { + input[type=text], + textarea { + width: 100%; + font-family: monospace; + font-size: small; + line-height: 1.3; + } + } + + .share-image { + label { + margin-right: 10px; + } + } + + #embed_html { + resize: vertical; + } + + #mapnik_scale { + width: 100px; + } } -.menu ul { - margin: 0px; - padding: 0px; +.leaflet-top.leaflet-right { + top: $lineheight !important; + .leaflet-control { + margin-right: 0px !important; + margin-top: 0px !important; + } } -.menu li { - padding: 2px 5px; - margin: 0px; - list-style-type: none; - border-top: 1px solid #eee; - white-space: nowrap; +.leaflet-popup-scrolled { + padding-right: $lineheight; + border-bottom: 0px !important; + border-top: 0px !important; +} + +.leaflet-popup-content-wrapper { + border-radius: 4px !important; + -webkit-border-radius: 4px !important; } /* Rules for attribution text under the main map shown on printouts */ @@ -506,7 +862,8 @@ body.site-export #tabnav a#exportanchor { display: none; } -.attribution_license { +.attribution_license, +.attribution_project { text-align: left; } @@ -514,874 +871,1752 @@ body.site-export #tabnav a#exportanchor { text-align: center; } -.attribution_project { - text-align: right; -} +.donate-attr { color: darken($green, 10%) !important; } -/* Rules for the popout map sidebar */ +/* Rules for the sidebar */ -#sidebar { - display: none; - position: absolute; - margin: 30px 0px 0px 0px; - padding: 0px; - border-right: 1px solid #ccc; - width: 30%; - top: 0px; - bottom: 0px; - left: 0px; +.sidebar_heading { + position: relative; + padding: $lineheight/2 $lineheight; + // background: $offwhite; + // border-bottom: 1px solid #ccc; + > .close { + float: right; + margin-top: 2px; + cursor: pointer; + } } -#sidebar #sidebar_content { - overflow: auto; +#sidebar_content { position: absolute; - font-size: 13px; - line-height: 15px; - top: 29px; - bottom: 0px; - left: 0px; - right: 0px; + top: 50px; + bottom: 0; + width: 100%; + overflow-y: auto; + + .loader, + .load_more { + text-align: center; + margin: $lineheight auto; + width: $lineheight; + display: block; + } } -#sidebar .sidebar_title { - margin: 0px; - padding: 3px 6px 4px 6px; - height: 29px; - font-size: 14px; - line-height: 15px; - background: #ccc; +/* Rules for the search box */ + +#search_form { + position: relative; + padding: $lineheight/2 $lineheight; + background-color: $lightgrey; + + #query_wrapper { + position: relative; + overflow: hidden; + } + + input { + width: 100%; + height: 30px; + border-right: none; + border-radius: 2px 0 0 2px; + + transition: 300ms linear; + -webkit-transition: 300ms linear; + -moz-transition: 300ms linear; + } + + input:focus { + outline: none; + box-shadow: 0px 0px 7px #9ED485; + } + + input[type=submit] { + float: right; + width: auto; + min-width: 0; + border-radius: 0 2px 2px 0; + } + + #describe_location { + position: absolute; + top: 6px; + right: 6px; + font-size: 10px; + color: $blue; + } } -#sidebar #sidebar_title { - text-align: left; +/* Rules for donation request box */ + +a.donate { + display: block; + padding: $lineheight/4 $lineheight; + border: 1px solid $green; + font-size: $typeheight; + line-height: 1.4; + text-align: center; + border-radius: 2px; + color: #222; + margin: $lineheight/2 $lineheight; + + &:hover { + background: $green; + text-decoration: none; + } } -#sidebar #sidebar_close { - text-align: right; +/* Rules for rotating sidebar ads */ + +.ad-container { + display: block; + height: 120px; + margin: auto; + overflow: hidden; + position: relative; + border-bottom: 1px solid #ccc; + + a { + display: block; + width: 165px; + margin: auto; + } + + .ad { + height: 100px; + border: 0; + background: #fff; + } } /* Rules for the map key which appears in the popout sidebar */ -#mapkey h3 { - font-size: 110%; - font-weight: normal; +#mapkey { + .mapkey-table-key img { + display: block; + margin-left: auto; + margin-right: auto; + } + td { + padding: 0 $lineheight/4 $lineheight/4 $lineheight/4; + } +} + +/* Rules for search results which appear in the popout sidebar */ + +.search_results_entry { + ul li { + border-bottom: $keyline; + &:first-child { border-top: $keyline; } + } + + .search_details { + display: block; + float: right; + text-align: right; + margin-top: 0.2em; + margin-left: 0.5em; + } +} + +.search_results_error { + color: #f00; +} + +/* Rules for data browser information which appears in the popout sidebar */ + +#browse_content { + position: relative; + .browse_show_list.button { + position: absolute; + left: $lineheight; + right: $lineheight; + bottom: -40px; + margin-bottom: 0; + } + a.more-details { + position: absolute; + top: 0; + right: $lineheight; + } + ul li { + margin-bottom: 0; + } +} + +/* Rules for entity history */ +#sidebar_content { + .browse_details { + position: relative; + border-bottom: $keyline; + } +} + +.browse_status { + display: none; +} + +/* Rules for the changeset list shown by the history tab */ + +#sidebar .changesets { + li { + padding: $lineheight; + border-bottom: $keyline; + cursor: pointer; + + &.selected { background: #FFFFE6; } + /* color is derived from changeset bbox fillColor in history.js */ + } + + .comment a { + font-weight: 500; + color: #000; + } +} + +/* Rules for the data browser */ + +#sidebar_content { + .browse-section { + padding: 10px 20px; + + h4 { + padding: 0; + } + } + + .paginate ul, .note-comments ul { + padding-left: 20px; + } + + .browse-field { + margin-bottom: 10px; + + h4 { + padding: 5px 0 5px 10px; + font-size: 12px; + border: 1px solid #CCC; + border-radius: 4px 4px 0 0; + background-color: #F6F6F6; + } + + p { + padding: 7px 10px; + font-size: 12px; + background-color: #FFF; + border: 1px solid #CCC; + border-top: 0; + border-radius: 0 0 4px 4px; + } + } + + .browse-tag-list { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + font-size: 12px; + margin-left: -$lineheight; + margin-right: -$lineheight; + + li { + border-bottom: 1px solid #ddd; + } + + li:last-child { + border-bottom: 0; + } + + .browse-tag-k, + .browse-tag-v { + display: inline-block; + width: 50%; + height: 30px; + float: left; + padding: 6px 10px 6px $lineheight; + } + + .browse-tag-k { + font-weight: 500; + background-color: #F6F6F6; + } + + .browse-tag-v { + border-left: 1px solid #ddd; + } + } +} + +/* Rules for export information which appears in the popout sidebar */ + +.export_bounds { text-align: center; } -#mapkey .mapkey-table { - padding-left: 5px; - padding-right: 5px; +.export_area_inputs { + margin-bottom: $lineheight/2; + input[type="text"] { + width: 80px; + margin-bottom: 5px; + } } -#mapkey .mapkey-table-key img { - display: block; - margin-left: auto; - margin-right: auto; +.export_bound { + margin: $lineheight/4; } -#mapkey .mapkey-table-value { - font-size: 90%; +#export_osm { + span.small-title { + font-weight: 500; + display: block; + font-size: 14px; + padding-bottom: 5px; + } + + dl { + padding-left: 30px; + font-size: 13px; + color: #666; + dd { + margin-left: 0; + margin-bottom: 10px; + } + } } -/* Rules for search results which appear in the popout sidebar */ +/* Rules for edit pages */ -.search_searching { - margin-top: 5px; - margin-bottom: 5px; +.site-edit { + #content { + position: absolute; + top: $headerHeight; + bottom: 0; + width: 100%; + } + + #map { + height: 100%; + } } -.search_results_heading { - margin: 0px; - padding: 2px 5px; - border-bottom: 1px solid #ccc; - font-weight: bold; +/* Rules for non-map content pages */ + +.content-heading { + background: $lightgrey; + + h1 { font-size: 22px; } } -.search_results_entry { - margin: 0px; - padding: 2px 5px; +.content-body { + h1, h2, h3, p { + margin-bottom: $lineheight; + } + + h1, h2, h3 { + margin-top: $lineheight/2; + } } -.search_results_error { - margin: 0px; - padding: 2px 6px 0px; - color: #f00; +.content-inner { + position: relative; + max-width: 900px; + margin: auto; + padding: $lineheight; } -/* Rules for data browser information which appears in the popout sidebar */ +/* Overrides for pages that use new layout conventions */ -.browse_heading { - margin: 0px; - padding: 3px 6px; +.user-new, +.user-create, +.user-terms { + .content-body .content-inner { + padding: 0; + } +} + +.user-new, +.user-create, +.user-terms, +.user-confirm { + .content-heading .content-inner { + height: 200px; + } +} + +.header-illustration { + background-position: 0 0; + background-repeat: no-repeat; + position: absolute; + height: 200px; + width: 100%; + left: 0; + bottom: 0; + + &.new-user-main { + background-image: image-url("sign-up-illustration.png"); + } + + &.confirm-main { + background-image: image-url("confirm-illustration.png"); + } + + &.new-user-terms { + background-image: image-url("terms-illustration.png"); + } + + &.new-user-arm { + height: 110px; + width: 130px; + left: 260px; + top: 160px; + background-image: image-url("sign-up-illustration-arm.png"); + z-index: 100; + } +} + +#content.maximised { + top: 0; + left: 0; + right: 0; + bottom: 0; + border: 0; + z-index: 1000; +} + +#slim_container { + width: 100%; +} + +#slim_container_content { + max-width: 50em; + background-color: #FFFFFF; + margin: $lineheight/2 auto; + padding: 3px; + border-radius: 25px; + -moz-border-radius: 25px; + border: 1px solid #e6e6e6; +} + +#slim_content { + margin: $lineheight/2; + margin-top: 95px; + max-width: 50em; + + .content-heading { + margin-bottom: 15px; + } +} + +#slim_header { + margin: 30px $lineheight/2; + position: absolute; + top: 0px; + margin-right: $lineheight/4; + img { + vertical-align: middle; + margin-bottom: $lineheight/4; + margin-right: $lineheight/4; + } +} + +/* Rules for small maps in content areas */ + +.content_map { + position: relative; + width: 45%; + height: 400px; border: 1px solid #ccc; - background: #ddd; + margin-bottom: $lineheight; + float: right; } -.browse_details { - margin: 0px; - padding: 0px 6px; +/* Rules for the trace list shown by the traces tab etc */ + +#trace_list { + font-size: $lineheight/2; + border-width: 0px; + text-align: right; + + .trace_summary { + font-size: 12px; + color: gray; + } + + .trace_pending { + color: red; + } + + .trace_public { + color: green; + } + + .trace_identifiable { + color: green; + } + + .trace_trackable { + color: red; + } + + .trace_private { + color: red; + } } -/* Rules for export information which appears in the popout sidebar */ +/* Rules for the user profile page */ -.export_heading { - margin: 0px; - padding: 2px 5px; +#userinformation { + + min-height: 100px; + .userinformation-inner { + float: left; + } + h2 { + margin-top: 0; + } + .user-description { + width: 100%; + clear: both; + } + .deemphasize { + margin: 0; + } +} + +.admin-user-info small { + margin-bottom: $lineheight/2; + display: inline; + margin-right: $lineheight; +} + +.activity-block { + clear: left; border-bottom: 1px solid #ccc; - font-weight: bold; + padding-bottom: $lineheight; + float: left; + h3 { + margin-bottom: $lineheight/2; + } } -.export_bounds { +.contact-activity { + margin-top: $lineheight; width: 100%; - text-align: center; } -.export_bound { - margin: 5px; +.activity-details p { + margin-left: 70px; + margin-bottom: 0; +} + +#friends-container .contact-activity ul { + margin-left: 70px; +} + +.user-view { + p#no_home_location { + margin: $lineheight; + } + .user_thumbnail { + margin-top: $lineheight/4; + float: left; + } +} + +/* Rules for the user map */ + +.content_map .leaflet-popup-content { + margin: $lineheight/2; + min-height: 50px; } -.export_details { - padding: 2px 6px; +/* Rules for user popups on maps */ + +.user_popup { + min-width: 200px; + p { + padding: 0 0 5px 0; + margin-top: 0 0 0 60px; + font-size: 12px; + } + img.user_thumbnail { + float: left; + margin: 0 $lineheight/2 0 0; + } +} + +/* Rules for the user list */ + +#user_list { + font-size: $lineheight/2; + width: 100%; + + tr { + vertical-align: middle; + } + + p { + margin-top: 0px; + margin-bottom: 0px; + } +} + +#user_list_actions { + float: right; + margin-top: $lineheight/2; +} + +/* Rules for the diary list page */ + +.diary_post { + position: relative; + margin-top: $lineheight/2; + padding-top: $lineheight; + border-top: 1px solid #ccc; + + .post_heading { + margin-bottom: $lineheight; + + h2 { + margin-top: 0; + margin-bottom: $lineheight/2; + font-size: 24px; + } + } + + img.user_thumbnail { + float: left; + } + + small.deemphasize { + float: left; + display: block; + } + + ul.secondary-actions { + display: inline-block; + } +} + +.content-heading .hide_unless_logged_in { // hacky selector, better to just add a new class to this div + display: inline; +} + +/* Rules for the diary entry page */ + +.diary_entry { + #map { + position: relative; + width: 90%; + height: 400px; + border: 1px solid #ccc; + display: none; + margin-bottom: $lineheight; + } + #newcomment { + border-top: 1px solid #ccc; + padding-top: $lineheight; + margin-top: $lineheight/2; + } + .comments { + max-width: 740px; + } + .diary-comment { + margin-top: $lineheight/2; + border-top: 1px dashed #ccc; + padding-top: $lineheight/2; + &:first-child { + margin-top: $lineheight; + padding-top: $lineheight; + border-top: 1px solid #ccc; + } + p { + margin-bottom: $lineheight/2; + } + .comment-heading { + margin-bottom: 0; + margin-top: 0; + } + } +} + +.diary_entry-view img.user_thumbnail { + float: left; +} + +/* Rules for the log in page */ + +#login_openid_buttons { + margin-bottom: 0; +} + +#login_openid_buttons li { + float: left; + padding: $lineheight/4 $lineheight/2; +} + +/* Rules for the account confirmation page */ + +.user-terms { + .legale { + border: 1px solid #ccc; + padding: $lineheight; + margin-bottom: $lineheight; + overflow: auto; + height: 10em; + } + + #decline { + background: $lightblue; + &:hover { + background: darken($lightblue, $hovercolor); + } + } + + .form-row { + margin: auto; + max-width: 370px; + } } -#export_osm { - display: none; -} +/* Rules for the account settings page */ -#export_mapnik { - display: none; +#accountForm .user_map { + position: relative; + width: 500px; + height: 400px; + border: 1px solid #ccc; } -#export_osmarender { - display: none; +#accountForm .user_image { + margin-bottom: 0; } -.export_hint { - padding: 0px 12px; - font-style: italic; +#accountForm #user_image { + margin-left: 20px; } -.export_buttons { - width: 100%; - text-align: center; +#accountForm ul.accountImage-options { + margin-left: 120px; } -/* Rules for the main content area */ - -#content { - padding: 20px; - margin: 30px 0px 0px 185px; - border-left: 1px solid #ccc; - text-align: left; +.nohome .location { + display: none; } -.site-edit #content, -.site-index #content, -.site-export #content { - position: fixed; - left: 0px; - right: 0px; - top: 0px; - bottom: 0px; - padding: 0px; +#homerow .message { + display: none; } -#slim_container { - width: 100%; +.nohome .message { + display: inline !important; } -#slim_container_content { - max-width: 50em; - background-color: #FFFFFF; - margin: 10px auto; - padding: 3px; - border-radius: 25px; - -moz-border-radius: 25px; - border: 1px solid #e6e6e6; +.content_map.settings_map { + width: 50%; + float: none; } -#slim_content { - margin: 10px; - margin-top: 90px; - max-width: 50em; -} +/* Rules for the oauth settings page */ -#slim_header { - margin: 10px; - position: absolute; - top: 0px; +.oauth_clients .buttons .oauth-edit { + border-radius: 2px 0 0 2px; } -#slim_header img { - vertical-align: middle; - margin-bottom: 5px; - margin-right: 5px; +.oauth_clients .buttons .oauth-delete { + border-radius: 0 2px 2px 0; } -/* Rules for text content pages */ +/* Rules for messages pages */ -.wide-table { +.messages { width: 100%; -} + border: 1px solid #ddd; -/* Rules for the home page */ + input[type="submit"] { + margin: auto; + } + tbody tr { + border-top: 1px solid #ccc; + } -.site-index #map { - position: absolute; - top: 0px; - bottom: 0px; - left: 0px; - right: 0px; -} + .inbox-row { + background: #f8f8ff; + } -.site-export #map { - position: absolute; - top: 0px; - bottom: 0px; - left: 0px; - right: 0px; -} + .inbox-row-unread { + background:#CBEEA7; + } -/* Rules for the edit page */ + .right { + float: right; + } -.site-edit #map { - position: absolute; - top: 0px; - bottom: 0px; - left: 0px; - right: 0px; - overflow: hidden; + tr td, + tr th { + padding: $lineheight/4; + } + p:last-child, + h2:last-child, + h3:last-child, + ol:last-child, + ul:last-child { + margin-bottom:0; + } + tr td { + height: 30px; + border-right: 1px solid $lightgrey; + } } -/* Rules for the changeset list shown by the history tab etc */ - -#changeset_list_container { - position: relative; +.inbox-row .inbox-mark-read { + display: none; } -#changeset_list { - width: 50%; - font-size: small; - border-collapse: collapse; - border-width: 0px; - margin-top: 1px; - margin-bottom: 1px; - text-align: left; -} +.info-line { + margin-bottom: $lineheight; + padding: $lineheight/4 0px 4px 0px; + border-bottom: 1px solid #ccc; -#changeset_list td { - vertical-align: top; - padding: 3px; + form, form div { + display: inline; + } } -#changeset_list .date { - white-space: nowrap; +.info-line .user_thumbnail_tiny { + vertical-align: middle; } -#changeset_list .user { - white-space: nowrap; +.inbox-mark-unread, +.inbox-mark-read, +.inbox-delete { + width: 1%; } -#changeset_list .area { - white-space: nowrap; +.inbox-row-unread .inbox-mark-unread { + display: none; } -#changeset_list .selected { - background-color: rgb(255, 255, 160); - background-color: rgba(255, 255, 85, 0.5); +.message-read .message-buttons { + margin-top: $lineheight; + padding-top: $lineheight; + border-top: 1px solid $lightgrey; } -#changeset_list_map { - position: absolute; - float: right; - top: 0px; - bottom: 0px; - right: 0px; - width: 49%; - min-height: 400px; - border: solid 1px black; +.message-read .buttons .mark-unread-button { + border-radius: 0; } -/* Rules for the data browser */ +/* Rules for "flash" notice boxes shown at the top of the content area */ -#browse_navigation { - float: right; - width: 250px; - margin-left: 10px; - text-align: center; +.error { + padding: $lineheight; + background-color: #ff7070; } -table.browse_details th { - white-space: nowrap; +.warning { + padding: $lineheight; + background-color: #ffe0cc; } -#browse_map { - float: right; - width: 250px; - text-align: right; - margin-left: 10px; +.notice { + padding: $lineheight; + background-color: #CBEEA7; } -#browse_map #small_map { - width: 250px; - height: 300px; - border: solid 1px black; +/* Rules for highlighting fields with rails validation errors */ + +.field_with_errors { + padding: 2px; + background-color: #ff7070; + display: inline-block; } -#browse_map .geolink { - display: none; +.formError { + display: inline-block; + padding: 5px 10px; + margin-top: 5px; + border-radius: 4px; + font-size: 12px; + color: #fff; + background-color: #ff7070; } -/* Rules for the trace list shown by the traces tab etc */ +/* Rules for rails validation error boxes */ -#trace_list { - font-size: small; - border-collapse: collapse; - border-width: 0px; - text-align: right; -} +#errorExplanation { + width: 400px; + border: 2px solid #ff7070; + padding: 0 $lineheight/2; + margin-bottom: $lineheight; + background-color: #f0f0f0; -#trace_list .trace_summary { - font-size: 12px; - color: gray; -} + h2 { + margin: 0 -10px 10px -10px; + padding: $lineheight/4 $lineheight/4 $lineheight/4 15px; + font-weight: 500; + font-size: 12px; + background-color: #c00; + color: #fff; + text-align: left; + } -#trace_list .trace_pending { - color: red; -} + p { + color: #333; + margin-bottom: 0px; + padding: $lineheight/4; + } -#trace_list .trace_public { - color: green; -} + ul { + padding-left: $lineheight; -#trace_list .trace_identifiable { - color: green; + li { + font-size: 12px; + list-style: disc; + } + } } -#trace_list .trace_trackable { - color: red; -} +/* Rules for forms */ -#trace_list .trace_private { - color: red; +.standard-form { + fieldset { + margin-bottom: $lineheight; + } + label.standard-label { + display: block; + margin-bottom: $lineheight/4; + font-size: $typeheight; + font-weight: 500; + line-height: 1.5; + } + label.standard-label.secondary { + display: inline-block; + font-weight: normal; + } + .form-help { + font-weight: normal; + } + .form-column { + float: left; + margin-right: 20px; + } + .form-divider { + margin-top: $lineheight; + padding-top: $lineheight; + border-top: 1px solid $lightgrey; + } + .horizontal-list .form-row { + float: left; + padding-right: 10px; + } + .form-row { + margin-bottom: $lineheight/2; + } + .form-list { + margin-bottom: 0; + } + .form-list li { + margin-bottom: 5px; + } + input[type="checkbox"], + input[type="radio"] { + float: left; + margin-top: 5px; + } } -/* Rules for the user list */ - -#user_list { - width: 100%; - font-size: small; +#remember_me_openid { + display: block; } -#user_list tr { - vertical-align: middle; +input[type="checkbox"], +input[type="radio"] { + margin-right: 5px; } -#user_list p { - margin-top: 0px; - margin-bottom: 0px; +input[type="text"], +input[type="email"], +input[type="url"], +input[type="password"], +textarea { + border: 1px solid #ccc; + padding: 2px 5px; + margin: 0; + width: 200px; } -#user_list_actions { - float: right; - margin-top: 10px; +textarea { + padding: 5px; + width: 100%; } -/* Rules for the diary list */ +/* Rules for user images */ -.diary_entry-list img.user_image { - float: right; +img.user_image { + max-width: 100px; + max-height: 100px; + border: 1px solid #ccc; + margin-bottom: $lineheight; + float: left; + margin-right: $lineheight; } -.diary_entry-list img.user_thumbnail { - float: right; +img.user_thumbnail { + max-width: 50px; + max-height: 50px; + border: 1px solid #ccc; + margin-right: $lineheight; } -/* Rules for the diary entry view */ - -.diary_entry-view img.user_image { - float: right; +img.user_thumbnail_tiny { + max-width: 25px; + max-height: 25px; + border: 1px solid #ccc; } -.diary_entry-view img.user_thumbnail { - float: right; +/* Rules for geo microformats */ + +abbr.geo { + border-bottom: none; } -/* Rules for the new diary entry page */ +/* Rules for RSS buttons */ -.diary_entry div#map { +.rsssmall { position: relative; - width: 90%; - height: 400px; - border: 1px solid #ccc; - display: none; + top: 3px; } -/* Rules for the login page */ +/* General styles for action lists / subnavs / pager navs */ -#login_wrapper div { - margin: 5px; - padding: 15px; - border-radius: 15px; - -moz-border-radius: 15px; +ul.secondary-actions { + font-style: normal; + margin-bottom: 0; + margin-left: 0; + &.pager { + display: inline-block; + margin-right: 60px; + } + > li { + display: block; + float: left; + list-style: none; + border-left: 1px solid #ccc; + padding-left: $lineheight/2; + margin-right: $lineheight/2; + &:first-child { + border-left: 0; + padding-left: 0; + } + &:last-child { + margin-right: 0px; + } + } } -#login_login { - background-color: #f5f5ff; - border: 1px solid #f3f3ff; - border-radius: 15px; - -moz-border-radius: 15px; +div.secondary-actions { + padding: 10px; + border-top: 1px solid #ccc; + text-align: center; } -#login_login h1 { - margin-top: 5px; -} +/* Utility for managing inner content areas */ -table#login_openid_buttons { - padding-bottom: 10px; -} +.inner22 { padding: $lineheight;} -#login_openid_buttons td { - padding-left: 10px; - padding-right: 10px; - padding-top: 5px; - padding-bottom: 5px; -} +.inner12 { padding: $lineheight/2 $lineheight;} -#login_openid_buttons img { - border: 0; -} +.inner11 { padding: $lineheight/2;} -#login_signup form.button-to div { - margin: 0px; - padding: 0px; -} +.inner20 { padding: $lineheight 0;} -/* Rules for the account confirmation page */ +.inner02 { padding: 0 $lineheight;} -div#contributorTerms { - border: 1px solid black; - padding: 4px; - overflow: auto; - width: 95%; - height: 400px; -} +/* Utility for general button styles */ -div#slim_content div#contributorTerms { - width: auto; +input[type="button"], +input[type="submit"], +input[type="reset"], +a.button { + cursor: pointer; + border: 0; + display: inline-block; + line-height: 20px; + padding: $lineheight/4 $lineheight/2; + min-height: 20px + $lineheight/2; + min-width: 120px; + margin: 0 0 $lineheight/2 0; + color: white; + background: $blue; + text-align: center; + border-radius: 2px; + -moz-border-radius: 2px; + &:hover { + background: darken($blue, $hovercolor); + text-decoration: none; + } + &.deemphasize { + background: $lightblue; + &:hover { + background: darken($lightblue, $hovercolor); + } + } + &:disabled { + background: $lightgrey; + &:hover { + background: $lightgrey; + } + } + &:last-child { + margin-bottom: 0; + } } -div#contributorTerms p#first { - margin-top: 0px; +.buttons { + min-width: 200px; + input[type="submit"], + input[type="button"], + input[type="reset"], + .button { + box-sizing: border-box; + float: left; + border-radius: 0; + margin:0; + min-width: 100px; + max-width: 180px; + border-right:1px solid white; + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + } + input:first-child, + .button:first-child { + border-radius:2px 0 0 2px; + } + input:last-child, + .button:last-child { + border-radius:0 2px 2px 0; + border-right-width: 0; + } + input:only-child, + .button:only-child, + *[value="Hide"] + input:last-child, + *[value="Hide"] + .button:last-child { + border-radius:2px; + border-right-width: 0; + } + /* if a 3-button set has a hidden middle button */ + *[value="Hide"] + input:nth-child(3), + *[value="Hide"] + .button:nth-child(3) { + border-radius:0 2px 2px 0; + border-right-width: 0; + } + /* if a 3-button set starts with a hidden button */ + *[value="Hide"] + input:nth-child(2):not(:last-child), + *[value="Hide"] + .button:nth-child(2):not(:last-child) { + border-radius:2px 0 0 2px; + border-right-width: 1px; + } } -div#contributorTerms p#last { - margin-bottom: 0px; -} +/* Rules for doing distinct colour of alternate table rows */ -div#contributorTerms ol { - margin-bottom: 0px; +.table0, +.item0 { + background: $offwhite; } -div#contributorTerms img { - display: block; - margin-left: auto; - margin-right: auto; - margin-top: 10%; +.table1, +.item1 { + background: #fff; } -form#termsForm { - width: 95%; - margin-bottom: 3em; -} +/* Rules for OpenID logo */ -form#termsForm div#buttons { - float: right; +.openid_logo { + vertical-align: text-bottom; + border: 0; } -form#termsForm input#agree { - margin-left: 50px; -} +/* Rules for rich text */ -div#slim_content form#termsForm { - width: auto; -} +.richtext, +.prose { + h1, h2 { + padding-bottom: $lineheight/2; + border-bottom: 1px dashed #cccccc; + margin-bottom: $lineheight/2; + } -p#contributorGuidance { - background-color: #f5f5ff; - border: 1px solid #f3f3ff; - border-radius: 15px; - -moz-border-radius: 15px; - padding: 10px; -} + h1 { + font-size: 24px; + } -/* Rules for the account settings page */ + h2 { + font-size: 18px; + } -#accountForm { - margin-top: 20px; -} + h3 { + font-size: $typeheight; + } -#accountForm td { - padding-bottom: 10px; -} + code { + font-size: 13px; + background: #e8e8e8; + padding: 2px 3px; + } -#accountForm .user_map { - position: relative; - width: 500px; - height: 400px; - border: 1px solid #ccc; -} + pre { + font-size: 13px; + background: #e8e8e8; + padding: 2px 3px; + + code { + padding: 0; + } + } -#accountForm td.accountImage { img { - vertical-align: top; - margin-top: 3px; + padding: $lineheight; + background-color: $offwhite; + display: block; + max-width: 100%; + margin: auto; } - table { - display: inline-block; + blockquote { + border-left: $lineheight solid $offwhite; + padding-left: $lineheight; + margin: 0; + color: #7E7E7E; + } - td { - padding-bottom: 0px; - } + ul, ol { + padding-left: $lineheight; + margin-bottom: $lineheight; + margin-left: $lineheight; } -} -.nohome .location { - display: none; -} + ul li { + list-style: disc; + } -#homerow .message { - display: none; + ol li { + list-style: decimal; + } } -.nohome .message { - display: inline !important; -} +.diary_post .richtext { + margin-top: $lineheight; + } -#accountForm input[type=submit] { - margin-top: 15px; +.comments .richtext { + margin-left: 70px; + margin-top: 0; } -/* Rules for the user view */ +/* Rules for rich text editors */ -.user-view img.user_image { - float: right; -} +.richtext_container { + margin-bottom: $lineheight; -.user-view .user_map { - float: right; - position: relative; - width: 400px; - height: 400px; - border: 1px solid #ccc; -} + .richtext_content { + width: 50%; + display: inline-block; + vertical-align: top; -.user-view .user_map p#no_home_location { - position: absolute; - top: 0px; - bottom: 0px; - width: 90%; - height: 30%; - margin: auto 5% -} + .richtext_preview { + display: inline-block; + padding: $lineheight; + background-color: $offwhite; + overflow-x: auto; -/* Rules for the user map */ + &.loading { + background-image: image-url("loading.gif"); + background-repeat: no-repeat; + background-position: center; + } -.user_map .leaflet-control-pan, -.user_map .leaflet-control-zoomslider { - display: none; -} + > :first-child { + margin-top: 0px; + } + } + } -.user_map .leaflet-control-zoom { - display: block; -} + .richtext_help { + display: inline-block; + vertical-align: top; + margin-left: 15px; + background-color: #f8f8ff; + padding: $lineheight/2; + width: 220px; -/* Rules for user popups on maps */ + ul { + margin-bottom: 0; + } -.user_popup { - min-width: 200px; -} + h4.heading, li { + border-bottom: 1px solid #ccc; + margin-bottom: $lineheight/4; + padding-bottom: $lineheight/4; + } -.user_popup p { - padding-top: 3px; - padding-bottom: 3px; - margin-top: 0px; - margin-bottom: 0px; - margin-left: 55px; - margin-right: 2px; -} + li h4, li span, li p { + display: inline-block; + vertical-align: top; + font-size: 11px; + } -.user_popup img.user_thumbnail { - float: left; + li h4 { + width: 40%; + margin: 0; + } + + li span, li p { + width: 50%; + margin-left: $lineheight/2; + margin-bottom: $lineheight/4; + white-space: nowrap; + } + } } -/* Rules for message in/out box page */ +/* Rules for the user notes list */ -.messages { - width: 100%; - border-collapse: collapse; - border-spacing: 0px; - border-width: 0px; -} +.note_list { + tr.creator { + background-color: #eeeeee; + } -.messages tbody tr { - border-top: 1px solid #ccc; -} + td { + padding: 3px; + } -.messages .inbox-row { - background: #eee; + p { + margin-bottom: 0px; + } } -.messages tr td, -.messages tr th { - padding: 0px 5px; -} +/* Rules for the notes interface */ -.inbox-row .inbox-mark-read { - display: none; +.leaflet-popup-content .note { + padding-top: $lineheight/2; } -.info-line { - border-bottom: 1px solid #ccc; - padding: 5px 0px 4px 0px; -} +.leaflet-popup-content .note { + h2 { + margin-bottom: $lineheight/2; + } -.info-line form, -.info-line form div { - display: inline; -} + div { + margin-top: $lineheight/2; + } -.info-line .user_thumbnail_tiny { - vertical-align: middle; -} + .permalink { + position: absolute; + top: $lineheight/4; + left: $lineheight/4; + min-width: 15px; + min-height: 15px; + } -.right { - float: right; -} + .permalink span { + display: none; + padding-left: $lineheight; + } -.inbox-row-unread .inbox-mark-unread { - display: none; -} + .permalink:hover span { + display: block; + } -/* Rules for "flash" notice boxes shown at the top of the content area */ + .warning { + display: block; + background-color: #ffe0cc; + padding: 4px 6px; + margin-bottom: $lineheight/2; + } -#error { - border: 1px solid red; - padding: 7px; - background-color: #fff0f0; - margin-bottom: 20px; - border-radius: 5px; - -moz-border-radius: 5px; -} + .comment_body { + margin-top: 2px; + margin-bottom: 2px; + + p { + margin-top: 0px; + margin-bottom: 0px; + } + } + + .comment { + width: 100%; + height: 100px; + } -#warning { - border: 1px solid orange; - padding: 7px; - background-color: #fff6f0; - margin-bottom: 20px; - border-radius: 5px; - -moz-border-radius: 5px; + .buttons { + margin-top: $lineheight/4; + text-align: right; + } } -#notice { - border: 1px solid green; - padding: 7px; - background-color: #f0fff0; - margin-bottom: 20px; - border-radius: 5px; - -moz-border-radius: 5px; +/* Rules for the iD editor */ + +.id-embed { + width: 100%; + height: 100%; } -/* Rules for highlighting fields with rails validation errors */ +/* Rules for dropdown menus */ -.field_with_errors { - padding: 2px; - background-color: red; - display: table; +.dropdown { + position: relative; } -/* Rules for rails validation error boxes */ +.dropdown-toggle { + *margin-bottom: -3px; +} -#errorExplanation { - width: 400px; - border: 2px solid red; - padding: 7px; - padding-bottom: 12px; - margin-bottom: 20px; - background-color: #f0f0f0; +.dropdown-toggle:active, +.open .dropdown-toggle { + outline: 0; } -#errorExplanation h2 { - font-weight: bold; - font-size: 12px; - padding: 5px 5px 5px 15px; - margin: -7px; - background-color: #c00; - color: #fff; - text-align: left; +.caret { + display: inline-block; + width: 0; + height: 0; + vertical-align: top; + border-top: 4px solid #000000; + border-right: 4px solid transparent; + border-left: 4px solid transparent; + content: ""; } -#errorExplanation p { - color: #333; - margin-bottom: 0px; - padding: 5px; +.dropdown .caret { + margin-top: 8px; + margin-left: 2px; } -#errorExplanation ul li { - font-size: 12px; - list-style: square; +.dropdown-menu { + position: absolute; + top: 100%; + left: -1px; + z-index: 1000; + display: none; + float: left; + min-width: 160px; + padding: 5px 0; + margin: 0; + list-style: none; + background-color: #ffffff; + border: 1px solid #ccc; + border-radius: 0 3px 3px; + *border-right-width: 2px; + *border-bottom-width: 2px; + -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); + -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); + box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); + -webkit-background-clip: padding-box; + -moz-background-clip: padding; + background-clip: padding-box; +} + +.dropdown-menu.pull-right { + right: 0; + left: auto; } -/* Rules for forms */ +.dropdown-menu .divider { + *width: 100%; + height: 1px; + margin: 9px 1px; + *margin: -5px 0 5px; + overflow: hidden; + background-color: #e5e5e5; + border-bottom: 1px solid #ffffff; +} -.fieldName { - vertical-align: top; - font-weight: bold; - font-size: 12px; +.dropdown-menu > li > a { + display: block; + padding: 3px 10px; + clear: both; + font-weight: normal; line-height: 20px; - text-align: right; + color: #333333; + white-space: nowrap; } -.submitButton { - text-align: right; +.dropdown-menu > li > a:hover, +.dropdown-menu > li > a:focus, +.dropdown-submenu:hover > a, +.dropdown-submenu:focus > a { + color: #ffffff; + text-decoration: none; + background-color: $green; } -.minorNote { - font-size: 0.8em; +.dropdown-menu > .active > a, +.dropdown-menu > .active > a:hover, +.dropdown-menu > .active > a:focus { + color: #ffffff; + text-decoration: none; + background-color: $green; + outline: 0; } -input[type="text"], -input[type="email"], -input[type="url"], -input[type="password"], -textarea { - border: 1px solid #ccc; +.dropdown-menu > .disabled > a, +.dropdown-menu > .disabled > a:hover, +.dropdown-menu > .disabled > a:focus { + color: #999999; } -input.openid_url { - background: image-url('openid_input.png') repeat-y left white; - padding-left: 16px; +.dropdown-menu > .disabled > a:hover, +.dropdown-menu > .disabled > a:focus { + text-decoration: none; + cursor: default; + background-color: transparent; + background-image: none; } -/* Rules for user images */ - -img.user_image { - max-width: 100px; - max-height: 100px; - border: 1px solid #ccc; +.open { + *z-index: 1000; } -img.user_thumbnail { - max-width: 50px; - max-height: 100px; - border: 1px solid #ccc; +.open > .dropdown-menu { + display: block; } -img.user_thumbnail_tiny { - max-width: 25px; - max-height: 25px; - border: 1px solid #ccc; +.dropdown-backdrop { + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 990; } -/* Rule for "nowrap" class that can be applied to anything to stop wrapping */ +/* Rules for the "Welcome" page */ +.site-welcome { + .center { + text-align: center; + .sprite { + float: none; + margin: auto; + } + } -.nowrap { - white-space: nowrap; -} + .sprite { + background-image: image-url("welcome-sprite.png"); + background-size: 500px 250px; + display: block; + float: left; + } -/* Rules for geo microformats */ + .icon-list { + padding-bottom: 20px; + div { + margin-bottom: 10px; + p { + padding-top: 10px; + } + } + } + .sprite.small { + width: 50px; + height: 50px; + } -abbr.geo { - border-bottom: none; -} + .sprite.x { + background-position: -50px 0; + } -/* Rules for RSS buttons */ + .sprite.term { + margin-right: 10px; + vertical-align: middle; + } -.rsssmall { - position: relative; - top: 4px; -} + .sprite.node { + background-position: -100px 0; + } -/* Rules for doing distinct colour of alternate table rows */ + .sprite.way { + background-position: -150px 0; + } -.table0 { - background: #f6f6f6; -} + .sprite.tag { + background-position: -200px 0; + } -.table1 { - background: #fff; -} + .sprite.editor { + background-position: -250px 0; + } -/* Rules for OpenID logo */ + .sprite.question { + background-position: -300px 0; + } -.openid_logo { - vertical-align: text-bottom; - border: 0; + .start-mapping { + margin: auto; + cursor: pointer; + border: none; + padding: 20px 40px; + font-size: 30px; + text-decoration: none; + } + + .note-box { + margin-top: 20px; + background-color: $offwhite; + } + + .icon.note { + background-color: #333; + border-radius: 4px; + } } -/* Rules for rich text editors */ +.site-about #content { + //background-color: #000; + background-color: #eee; + background-position: 50% 50%; + background-repeat: no-repeat; + background-size: cover; + background-attachment: fixed; + + &.photo-0 { background-image: image-url('about/0.jpg'); .photo-0 { display: block; } } + &.photo-1 { background-image: image-url('about/1.jpg'); .photo-1 { display: block; } } + &.photo-2 { background-image: image-url('about/2.jpg'); .photo-2 { display: block; } } + &.photo-3 { background-image: image-url('about/4.jpg'); .photo-3 { display: block; } } + &.photo-4 { background-image: image-url('about/4.jpg'); .photo-4 { display: block; } } + &.photo-5 { background-image: image-url('about/5.jpg'); .photo-5 { display: block; } } + + .caption { + max-width: 200px; + font: 13px/20px Helvetica, Arial, sans-serif; + position: fixed; + text-align: right; + right: 20px; + bottom: 60px; + text-shadow: #000 0px 1px 5px; + color: #eee; + opacity: 0.8; + display: none; + } -.richtext_container { - white-space: nowrap; + .caption a { + color: white; + white-space: nowrap; + text-decoration: none; + } - .richtext_content { - display: inline-block; - vertical-align: top; + a.next { + display: block; + position: fixed; + right: 10px; + bottom: 10px; + width: 40px; + height: 40px; + border-radius: 5px; + text-indent: -9999px; + overflow: hidden; + background: image-url('about/sprite.png') -120px 0px no-repeat; + background-color: #000; + background-color: rgba(0, 0, 0, 0.5); + } - .richtext_preview { - display: inline-block; - margin-top: 1px; - margin-bottom: 1px; - border: 4px solid #eee; - background-color: #eee; - white-space: normal; + .content-inner { + position: relative; + color: #333; + min-width: 320px; + max-width: 640px; - &.loading { - background-image: image-url("loading.gif"); - background-repeat: no-repeat; - background-position: center; - } + .section { + margin-bottom: 30px; + } - > :first-child { - margin-top: 0px; - } + .section:last-child { + margin-bottom: 0; } } - .richtext_help { - display: inline-block; - vertical-align: top; - background-color: #ddd; - margin-left: 15px; - padding: 5px 10px 10px 10px; - font-size: 12px; + .text { + background: white; + padding: 40px; + } - p { - margin: 0px; + .attr { + position: relative; + padding: 170px 40px 20px; + background: #333; + background: rgba(0, 0, 0, .8); + margin-bottom: 0; + margin-top: -20px; + + h1 { + display: block; + color: white; + font-weight: 300; + font-size: 34px; + span { + color: #76c551; + } } - th { - vertical-align: top; - text-align: left; - padding: 0px 15px 0px 0px !important; + .user-image { + position: absolute; + top: 0px; + right: 240px; + left: 0px; + height: 150px; + background-position: 0 50%; + background-repeat: no-repeat; + background-image: image-url('about/osm.png'); + background-size: cover; + background-color: #76c551; } - td { - text-align: left; - font-family: fixed; - line-height: 16px; - padding: 0px !important; + .byosm { + position: absolute; + top: 0px; + right: 0px; + z-index: 1; + width: 240px; + height: 150px; + padding: 20px 20px 20px 40px; + font: 500 20px/24px Helvetica, Arial, sans-serif; + white-space: nowrap; + color: #fff; + background: #76c551; } - input.richtext_doedit { - margin-top: 5px !important; - margin-right: 10px !important; + .byosm span { + display: inline-block; + width: 20px; + margin-left: -20px; } + } - input.richtext_dopreview { - margin-top: 5px !important; - margin-left: 10px !important; - } + h2 { + margin-bottom: 10px; + } + + .icon { + width: 30px; + height: 30px; + margin-right: 10px; + vertical-align: middle; + background: 40px 40px image-url('about/sprite.png') no-repeat; + + &.local { background-position: 0px 0px; } + &.community { background-position: 0px -40px; } + &.open { background-position: 0px -80px; } + &.contributors { background-position: 0px -120px; } + &.infringement { background-position: 0px -160px; } + } +} + +@import 'browse'; + +@media only screen and (max-width:960px) { + .header-illustration.new-user-arm { + display: none; } } +