Changes for page Public Web Site
Last modified by Agnease on 2026/05/30 16:24
Summary
-
Objects (1 modified, 0 added, 0 removed)
Details
- XWiki.StyleSheetExtension[1]
-
- code
-
... ... @@ -1,6 +1,16 @@ 1 1 /* ========== Agnease Public Top Menu ========== */ 2 2 3 -.agnease-menu-item { 3 +@brand: #00937D; 4 +@brand-strong: #007B6A; 5 +@text: #2D3A34; 6 +@muted: #5B6B64; 7 +@line: #E4ECE9; 8 +@brand-bg: #F4FCFA; 9 + 10 +/* Top-level menu items */ 11 + 12 +.agnease-services-menu, 13 +.agnease-products-menu { 4 4 .dropdown-toggle { 5 5 font-weight: inherit; 6 6 font-size: inherit; ... ... @@ -8,8 +8,6 @@ 8 8 9 9 .caret { 10 10 margin-left: 4px; 11 - border-top-color: @brand; 12 - border-bottom-color: @brand; 13 13 } 14 14 15 15 &.open > .dropdown-toggle, ... ... @@ -20,18 +20,10 @@ 20 20 background-color: transparent; 21 21 box-shadow: none; 22 22 } 23 - 24 - &.open > .dropdown-toggle .caret, 25 - .dropdown-toggle:hover .caret, 26 - .dropdown-toggle:focus .caret { 27 - border-top-color: @brand-strong; 28 - border-bottom-color: @brand-strong; 29 - } 30 30 } 31 31 32 32 /* Keep Agnease public top-level menu visually clean when hovered/open/focused */ 33 -.navbar-nav > li.agnease-menu-item.open > a, 34 -.navbar-nav > li.agnease-menu-item.open > a:hover, 34 + 35 35 .navbar-nav > li.agnease-services-menu > a, 36 36 .navbar-nav > li.agnease-products-menu > a, 37 37 .navbar-nav > li.agnease-services-menu > a:hover, ... ... @@ -45,7 +45,7 @@ 45 45 .navbar-nav > li.agnease-services-menu.open > a:focus, 46 46 .navbar-nav > li.agnease-products-menu.open > a:focus { 47 47 background: transparent; 48 - background-color: #fff;48 + background-color: transparent; 49 49 color: @brand-strong; 50 50 box-shadow: none; 51 51 } ... ... @@ -52,119 +52,232 @@ 52 52 53 53 /* Dropdown panels */ 54 54 55 -.agnease-dropdown { 56 - min-width: 270px; 57 - padding: 8px; 58 - border: 1px solid fade(@brand, 18%); 55 +.agnease-services-dropdown, 56 +.agnease-resources-dropdown, 57 +.agnease-products-dropdown { 58 + min-width: 360px; 59 + padding: 10px; 60 + border: 1px solid @line; 59 59 border-radius: 12px; 60 - background: #fff; 61 - box-shadow: 0 12px 32px fade(@brand-strong, 12%); 62 + box-shadow: 0 12px 36px rgba(0, 0, 0, .10); 62 62 63 63 > li > a { 64 64 display: flex; 65 - align-items: center; 66 - gap: 10px; 67 - padding: 9px 11px; 68 - border-radius: 9px; 69 - color: @brand; 70 - background: transparent; 71 - white-space: nowrap; 72 - font-size: 14px; 73 - font-weight: 700; 74 - line-height: 1.25; 66 + align-items: flex-start; 67 + gap: 12px; 68 + padding: 10px 12px; 69 + border-radius: 10px; 70 + color: @text; 71 + white-space: normal; 75 75 76 - i { 77 - width: 18px; 78 - flex: 0 0 18px; 79 - color: @brand; 80 - text-align: center; 81 - font-size: 14px; 82 - } 83 - 84 84 &:hover, 85 - &:focus, 86 - &:active { 74 + &:focus { 87 87 color: @brand-strong; 88 - background: fade(@brand, 8%);76 + background: @brand-bg; 89 89 text-decoration: none; 90 - outline: none; 91 91 92 - i { 79 + .menu-icon { 93 93 color: @brand-strong; 81 + background: fade(@brand, 14%); 82 + border-color: fade(@brand, 28%); 94 94 } 95 - } 96 - } 97 97 98 - > .active > a, 99 - > .active > a:hover, 100 - > .active > a:focus { 101 - color: @brand-strong; 102 - background: fade(@brand, 10%); 103 - text-decoration: none; 85 + strong { 86 + color: @brand-strong; 87 + } 104 104 105 - i { 106 - color: @brand-strong; 89 + small { 90 + color: @muted; 91 + } 107 107 } 108 108 } 109 109 110 110 .divider { 111 - margin: 7px 0;112 - background-color: fade(@brand, 16%);96 + margin: 8px 0; 97 + background-color: @line; 113 113 } 99 + 100 + .menu-icon { 101 + width: 34px; 102 + height: 34px; 103 + border-radius: 50%; 104 + background: fade(@brand, 8%); 105 + border: 1px solid fade(@brand, 18%); 106 + color: @brand; 107 + display: flex; 108 + align-items: center; 109 + justify-content: center; 110 + flex-shrink: 0; 111 + transition: color .15s ease, background .15s ease, border-color .15s ease; 112 + } 113 + 114 + .menu-text { 115 + display: flex; 116 + flex-direction: column; 117 + line-height: 1.25; 118 + 119 + strong { 120 + color: @brand; 121 + font-size: 14px; 122 + font-weight: 600; 123 + } 124 + 125 + small { 126 + color: @muted; 127 + font-size: 12px; 128 + margin-top: 2px; 129 + font-weight: 400; 130 + } 131 + } 114 114 } 115 115 116 -.agnease-products-dropdown, 117 -.agnease-resources-dropdown { 118 - min-width: 260px; 134 +/* Products dropdown can be slightly narrower for now */ 135 + 136 +.agnease-products-dropdown { 137 + min-width: 340px; 119 119 } 120 120 121 -/* Remove gray Bootstrap dropdown item states */ 122 -.dropdown-menu > li > a:hover, 123 -.dropdown-menu > li > a:focus { 124 - background-image: none; 140 +/* Mobile */ 141 + 142 +@media (max-width: 767px) { 143 + .agnease-services-dropdown, 144 + .agnease-resources-dropdown, 145 + .agnease-products-dropdown { 146 + min-width: 0; 147 + width: 100%; 148 + padding: 6px; 149 + border-radius: 0; 150 + border-left: 0; 151 + border-right: 0; 152 + box-shadow: none; 153 + 154 + > li > a { 155 + padding: 10px; 156 + } 157 + } 125 125 } 126 126 127 -/* ========== MobileMenu ========== */160 +/* ========== Compact Public Menu on Mobile ========== */ 128 128 129 129 @media (max-width: 767px) { 130 - .navbar-nav> li.agnease-menu-item>a,131 - .navbar-nav >li > a {132 - padding-top:8px;133 - padding-bottom:8px;163 + /* Prevent any menu element from creating horizontal scroll */ 164 + html, 165 + body { 166 + overflow-x: hidden; 134 134 } 168 + 169 + .agnease-services-dropdown, 170 + .agnease-products-dropdown, 171 + .agnease-resources-dropdown { 172 + width: 100% !important; 173 + min-width: 0 !important; 174 + max-width: 100% !important; 175 + left: auto !important; 176 + right: auto !important; 177 + } 135 135 136 - .agnease-dropdown { 137 - min-width: 0; 179 + .navbar, 180 + .navbar-collapse, 181 + .navbar-nav, 182 + .navbar-nav > li, 183 + .navbar-nav .dropdown-menu { 184 + max-width: 100%; 185 + } 186 + 187 + /* Make the main menu vertical inside the burger menu */ 188 + .navbar-nav { 189 + float: none !important; 138 138 width: 100%; 139 - padding: 4px 8px 8px 18px; 191 + margin: 0; 192 + } 193 + 194 + .navbar-nav > li { 195 + float: none !important; 196 + display: block; 197 + width: 100%; 198 + } 199 + 200 + .navbar-nav > li > a { 201 + display: block; 202 + width: 100%; 203 + padding: 11px 16px; 204 + font-size: 14px; 205 + font-weight: 600; 206 + line-height: 1.3; 207 + white-space: normal; 208 + } 209 + 210 + .navbar-nav > li > a .caret { 211 + float: right; 212 + margin-top: 7px; 213 + } 214 + 215 + /* Dropdowns become compact nested sections */ 216 + .navbar-nav .dropdown-menu { 217 + position: static !important; 218 + float: none !important; 219 + width: 100% !important; 220 + min-width: 0 !important; 221 + max-width: 100% !important; 222 + margin: 0; 223 + padding: 4px 0 8px; 140 140 border: 0; 141 141 border-radius: 0; 142 142 box-shadow: none; 143 - background: #fff; 227 + background: @brand-bg; 228 + } 144 144 145 - > li > a { 146 - padding: 8px 10px; 147 - white-space: normal; 148 - font-size: 14px; 149 - border-radius: 8px; 150 - color: @brand; 230 + .navbar-nav .dropdown-menu > li { 231 + width: 100%; 232 + } 151 151 152 - i { 153 - width: 16px; 154 - flex-basis: 16px; 155 - } 234 + .navbar-nav .dropdown-menu > li > a { 235 + display: block; 236 + width: 100%; 237 + padding: 8px 16px 8px 28px; 238 + white-space: normal; 239 + overflow-wrap: anywhere; 240 + color: @text; 241 + } 156 156 157 - &:hover, 158 - &:focus, 159 - &:active { 160 - color: @brand-strong; 161 - background: fade(@brand, 8%); 162 - } 163 - } 243 + .navbar-nav .dropdown-menu > li > a:hover, 244 + .navbar-nav .dropdown-menu > li > a:focus { 245 + background: @brand-soft; 246 + color: @brand-strong; 247 + } 164 164 165 - .divider { 166 - margin: 5px 0; 167 - background-color: fade(@brand, 16%); 168 - } 249 + /* Compact the rich dropdown layout on mobile */ 250 + .navbar-nav .dropdown-menu .menu-icon { 251 + display: none; 169 169 } 253 + 254 + .navbar-nav .dropdown-menu .menu-text { 255 + display: block; 256 + min-width: 0; 257 + } 258 + 259 + .navbar-nav .dropdown-menu .menu-text strong { 260 + display: block; 261 + font-size: 13px; 262 + line-height: 1.25; 263 + font-weight: 600; 264 + color: @text; 265 + } 266 + 267 + /* Hide descriptions on mobile to avoid a very tall / wide menu */ 268 + .navbar-nav .dropdown-menu .menu-text small { 269 + display: none; 270 + } 271 + 272 + .navbar-nav .dropdown-menu .divider { 273 + margin: 4px 16px; 274 + background-color: @line; 275 + } 276 + 277 + .navbar-nav .open > a, 278 + .navbar-nav .open > a:hover, 279 + .navbar-nav .open > a:focus { 280 + background: @brand-bg; 281 + color: @brand-strong; 282 + } 170 170 }