Changes for page Public Web Site

Last modified by Agnease on 2026/05/30 16:24

From version 8.20
edited by Agnease
on 2026/05/19 03:38
Change comment: There is no comment for this version
To version 10.2
edited by Agnease
on 2026/05/19 03:53
Change comment: There is no comment for this version

Summary

Details

XWiki.StyleSheetExtension[1]
code
... ... @@ -1,16 +1,6 @@
1 1  /* ========== Agnease Public Top Menu ========== */
2 2  
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 {
3 +.agnease-menu-item {
14 14   .dropdown-toggle {
15 15   font-weight: inherit;
16 16   font-size: inherit;
... ... @@ -18,6 +18,8 @@
18 18  
19 19   .caret {
20 20   margin-left: 4px;
11 + border-top-color: @brand;
12 + border-bottom-color: @brand;
21 21   }
22 22  
23 23   &.open > .dropdown-toggle,
... ... @@ -28,6 +28,13 @@
28 28   background-color: transparent;
29 29   box-shadow: none;
30 30   }
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 + }
31 31  }
32 32  
33 33  /* Keep Agnease public top-level menu visually clean when hovered/open/focused */
... ... @@ -52,232 +52,139 @@
52 52  
53 53  /* Dropdown panels */
54 54  
55 -.agnease-services-dropdown,
56 -.agnease-resources-dropdown,
57 -.agnease-products-dropdown {
58 - min-width: 360px;
59 - padding: 10px;
60 - border: 1px solid @line;
54 +.agnease-dropdown {
55 + min-width: 270px;
56 + padding: 8px;
57 + border: 1px solid fade(@brand, 18%);
61 61   border-radius: 12px;
62 - box-shadow: 0 12px 36px rgba(0, 0, 0, .10);
59 + background: #fff;
60 + box-shadow: 0 12px 32px fade(@brand-strong, 12%);
63 63  
64 64   > li > a {
65 65   display: flex;
66 - align-items: flex-start;
67 - gap: 12px;
68 - padding: 10px 12px;
69 - border-radius: 10px;
70 - color: @text;
71 - white-space: normal;
64 + align-items: center;
65 + gap: 10px;
66 + padding: 9px 11px;
67 + border-radius: 9px;
68 + color: @brand;
69 + background: transparent;
70 + white-space: nowrap;
71 + font-size: 14px;
72 + font-weight: 700;
73 + line-height: 1.25;
72 72  
75 + i {
76 + width: 18px;
77 + flex: 0 0 18px;
78 + color: @brand;
79 + text-align: center;
80 + font-size: 14px;
81 + }
82 +
73 73   &:hover,
74 - &:focus {
84 + &:focus,
85 + &:active {
75 75   color: @brand-strong;
76 - background: @brand-bg;
87 + background: fade(@brand, 8%);
77 77   text-decoration: none;
89 + outline: none;
78 78  
79 - .menu-icon {
91 + i {
80 80   color: @brand-strong;
81 - background: fade(@brand, 14%);
82 - border-color: fade(@brand, 28%);
83 83   }
94 + }
95 + }
84 84  
85 - strong {
86 - color: @brand-strong;
87 - }
97 + > .active > a,
98 + > .active > a:hover,
99 + > .active > a:focus {
100 + color: @brand-strong;
101 + background: fade(@brand, 10%);
102 + text-decoration: none;
88 88  
89 - small {
90 - color: @muted;
91 - }
104 + i {
105 + color: @brand-strong;
92 92   }
93 93   }
94 94  
95 95   .divider {
96 - margin: 8px 0;
97 - background-color: @line;
110 + margin: 7px 0;
111 + background-color: fade(@brand, 16%);
98 98   }
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 - }
132 132  }
133 133  
134 -/* Products dropdown can be slightly narrower for now */
135 -
136 -.agnease-products-dropdown {
137 - min-width: 340px;
115 +.agnease-products-dropdown,
116 +.agnease-resources-dropdown {
117 + min-width: 260px;
138 138  }
139 139  
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 - }
120 +/* Remove gray Bootstrap dropdown item states */
121 +.dropdown-menu > li > a:hover,
122 +.dropdown-menu > li > a:focus {
123 + background-image: none;
158 158  }
159 159  
160 -/* ========== Compact Public Menu on Mobile ========== */
126 +/* ========== Mobile Menu ========== */
161 161  
162 162  @media (max-width: 767px) {
163 - /* Prevent any menu element from creating horizontal scroll */
164 - html,
165 - body {
166 - overflow-x: hidden;
167 - }
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 - }
178 -
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;
190 - width: 100%;
191 - margin: 0;
192 - }
193 -
194 - .navbar-nav > li {
195 - float: none !important;
196 - display: block;
197 - width: 100%;
198 - }
199 -
129 + .navbar-nav > li.agnease-menu-item > a,
200 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;
131 + padding-top: 8px;
132 + padding-bottom: 8px;
208 208   }
209 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;
135 + .agnease-dropdown {
136 + min-width: 0;
137 + width: 100%;
138 + padding: 4px 8px 8px 18px;
224 224   border: 0;
225 225   border-radius: 0;
226 226   box-shadow: none;
227 - background: @brand-bg;
228 - }
142 + background: #fff;
229 229  
230 - .navbar-nav .dropdown-menu > li {
231 - width: 100%;
232 - }
144 + > li > a {
145 + padding: 8px 10px;
146 + white-space: normal;
147 + font-size: 14px;
148 + border-radius: 8px;
149 + color: @brand;
233 233  
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 - }
151 + i {
152 + width: 16px;
153 + flex-basis: 16px;
154 + }
242 242  
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 - }
156 + &:hover,
157 + &:focus,
158 + &:active {
159 + color: @brand-strong;
160 + background: fade(@brand, 8%);
161 + }
162 + }
248 248  
249 - /* Compact the rich dropdown layout on mobile */
250 - .navbar-nav .dropdown-menu .menu-icon {
251 - display: none;
164 + .divider {
165 + margin: 5px 0;
166 + background-color: fade(@brand, 16%);
167 + }
252 252   }
169 +}
170 +/* Remove gray background from opened top-level public menu items */
253 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 - }
172 +.site-nav .dropdown.open > a,
173 +.site-nav .dropdown.open > a:hover,
174 +.site-nav .dropdown.open > a:focus,
175 +.site-nav .agnease-menu-item.open > a,
176 +.site-nav .agnease-menu-item.open > a:hover,
177 +.site-nav .agnease-menu-item.open > a:focus,
178 +.navbar-nav > li.dropdown.open > a,
179 +.navbar-nav > li.dropdown.open > a:hover,
180 +.navbar-nav > li.dropdown.open > a:focus,
181 +.navbar-nav > li.agnease-menu-item.open > a,
182 +.navbar-nav > li.agnease-menu-item.open > a:hover,
183 +.navbar-nav > li.agnease-menu-item.open > a:focus {
184 + color: @brand-strong;
185 + background: transparent !important;
186 + background-color: transparent !important;
187 + background-image: none !important;
188 + box-shadow: none !important;
283 283  }