Changes for page Public Web Site

Last modified by Agnease on 2026/07/03 16:14

From version 28.28
edited by Agnease
on 2026/07/03 13:25
Change comment: There is no comment for this version
To version 11.2
edited by Agnease
on 2026/05/22 08:21
Change comment: There is no comment for this version

Summary

Details

Page properties
Default language
... ... @@ -1,0 +1,1 @@
1 +en
Hidden
... ... @@ -1,1 +1,1 @@
1 -true
1 +false
Content
... ... @@ -2,69 +2,34 @@
2 2  #macro (displayPublicContent)
3 3   #set ($discard = $xwiki.ssx.use('PublicWebSite.WebHome'))
4 4   {{html clean="false"}}
5 - <section class="hero hero-saas" id="top">
6 - <div class="container">
7 - <div class="hero-layout">
8 - <div class="hero-copy">
9 - <h1>Professional XWiki consulting <span>and engineering</span></h1>
10 10  
11 - <p class="lead">
12 - Agnease helps organizations upgrade, maintain, secure and extend production XWiki platforms with practical engineering support, custom development, integrations and long-term care.
13 - </p>
14 -
15 - <ul class="benefits">
16 - <li>XWiki LTS upgrades</li>
17 - <li>Maintenance and support</li>
18 - <li>Custom XWiki development</li>
19 - <li>Migrations and integrations</li>
20 - </ul>
21 -
22 - <div class="hero-actions" id="hero-cta">
23 - <a class="btn btn-primary" href="https://calendly.com/alex-agnease/30min?back=1&month=2026-06">
24 - Book a free discussion
25 - </a>
26 - <a class="btn btn-secondary" href="$xwiki.getURL('services.WebHome')">View XWiki services</a>
27 - </div>
28 - </div>
29 -
30 - <div class="hero-image-wrapper">
31 - <img
32 - class="hero-image"
33 - src="$xwiki.getDocument('PublicWebSite.WebHome').getAttachmentURL('agnease-xwiki-hero.png')"
34 - alt="Illustration of a professional XWiki platform dashboard with upgrade, security and maintenance elements"
35 - width="1200"
36 - height="900"
37 - loading="eager"
38 - />
39 - </div>
40 - </div>
41 - </div>
42 - </section>
43 -#*
44 44   <section class="hero hero-centered" aria-labelledby="hero-title">
45 45   <div class="container hero-inner">
46 - <h1 id="hero-title">Professional XWiki consulting and engineering</h1>
8 + <div class="hero-kicker">
9 + <i class="fa fa-shield" aria-hidden="true"></i>
10 + Your trusted partner for professional XWiki services
11 + </div>
47 47  
13 + <h1 id="hero-title">Reliable XWiki engineering for organizations that depend on their knowledge platform</h1>
14 +
48 48   <p class="lead">
49 - Agnease helps organizations upgrade, maintain, secure and extend production XWiki platforms with practical
50 - engineering support, custom development, integrations and long-term care.
16 + Agnease helps companies keep XWiki secure, stable, up-to-date and adapted to real business processes.
51 51   </p>
52 52  
53 53   <ul class="benefits">
54 - <li>XWiki LTS upgrades</li>
55 - <li>Maintenance and support</li>
56 - <li>Custom XWiki development</li>
57 - <li>Migrations and integrations</li>
20 + <li>Safe LTS upgrades</li>
21 + <li>Support and recovery</li>
22 + <li>Custom XWiki applications</li>
23 + <li>Integrations and migrations</li>
58 58   </ul>
59 59  
60 60   <div class="hero-actions">
61 - <a class="btn btn-primary" href="https://calendly.com/alex-agnease/30min?back=1&month=2026-06">Book a free discussion</a>
62 - ##<a class="btn btn-primary" href="$xwiki.getURL('contact.WebHome')">Request a consultation</a>
27 + <a class="btn btn-primary" href="$xwiki.getURL('contact.WebHome')">Request a consultation</a>
63 63   <a class="btn btn-secondary" href="$xwiki.getURL('services.WebHome')">View XWiki services</a>
64 64   </div>
65 65   </div>
66 66   </section>
67 -*#
32 +
68 68   <section class="trust-strip" aria-label="Agnease experience">
69 69   <div class="container">
70 70   <ul>
... ... @@ -78,28 +78,26 @@
78 78  
79 79   <section aria-labelledby="platform-title">
80 80   <div class="container">
81 - <h2 id="platform-title">XWiki support for production knowledge platforms</h2>
46 + <h2 id="platform-title">When XWiki becomes business-critical, it needs professional care</h2>
82 82   <p class="section-intro">
83 - XWiki often grows from a documentation space into a business-critical knowledge platform.
84 - When it supports intranets, procedures, workflows, audits or integrations, it needs structured technical care
85 - for upgrades, security, permissions and maintainability.
48 + Many organizations start with XWiki as a documentation platform. Over time, it becomes a knowledge base,
49 + intranet, SOP portal, workflow system, audit trail or integration hub. At that point, upgrades, security,
50 + performance, permissions and maintainability are no longer optional technical details.
86 86   </p>
87 87  
88 88   <div class="pathways">
89 89   <article class="pathway-card">
90 - <div class="card-heading">
91 - <div class="pathway-icon">
92 - <i class="fa fa-refresh" aria-hidden="true"></i>
93 - </div>
94 - <h3>Upgrade XWiki safely</h3>
55 + <div class="pathway-icon">
56 + <i class="fa fa-refresh" aria-hidden="true"></i>
95 95   </div>
58 + <h3>Keep XWiki current</h3>
96 96   <p>
97 - Plan and execute XWiki LTS upgrades with compatibility checks, staging validation and rollback planning.
60 + Plan and execute safe upgrades to supported XWiki versions, with compatibility checks and rollback planning.
98 98   </p>
99 99   <ul>
100 100   <li>LTS upgrade planning</li>
101 101   <li>Extension and custom code review</li>
102 - <li>Staging and production validation</li>
65 + <li>Production rollout validation</li>
103 103   </ul>
104 104   <p class="card-link">
105 105   <a href="$xwiki.getURL('services.xwiki-upgrades')">View upgrade services</a>
... ... @@ -107,19 +107,17 @@
107 107   </article>
108 108  
109 109   <article class="pathway-card">
110 - <div class="card-heading">
111 - <div class="pathway-icon">
112 - <i class="fa fa-life-ring" aria-hidden="true"></i>
113 - </div>
114 - <h3>Maintain XWiki reliably</h3>
73 + <div class="pathway-icon">
74 + <i class="fa fa-life-ring" aria-hidden="true"></i>
115 115   </div>
76 + <h3>Keep XWiki reliable</h3>
116 116   <p>
117 - Keep production XWiki instances stable with troubleshooting, maintenance planning, recovery support and security-aware care.
78 + Get long-term technical care for instances that need to stay stable, secure and recoverable.
118 118   </p>
119 119   <ul>
120 120   <li>Troubleshooting and recovery</li>
121 121   <li>Performance and log analysis</li>
122 - <li>Upgrade and maintenance planning</li>
83 + <li>Security-aware maintenance</li>
123 123   </ul>
124 124   <p class="card-link">
125 125   <a href="$xwiki.getURL('services.xwiki-maintenance-support')">View support services</a>
... ... @@ -127,19 +127,17 @@
127 127   </article>
128 128  
129 129   <article class="pathway-card">
130 - <div class="card-heading">
131 - <div class="pathway-icon">
132 - <i class="fa fa-cogs" aria-hidden="true"></i>
133 - </div>
134 - <h3>Extend XWiki for your processes</h3>
91 + <div class="pathway-icon">
92 + <i class="fa fa-cogs" aria-hidden="true"></i>
135 135   </div>
94 + <h3>Adapt XWiki to your business</h3>
136 136   <p>
137 - Build custom XWiki applications, workflows, dashboards and integrations around real business needs.
96 + Build workflows, custom applications, dashboards, integrations and automation around your processes.
138 138   </p>
139 139   <ul>
140 140   <li>Custom XWiki applications</li>
141 141   <li>Workflows and approvals</li>
142 - <li>APIs, SSO, LDAP and integrations</li>
101 + <li>SSO, LDAP, APIs and integrations</li>
143 143   </ul>
144 144   <p class="card-link">
145 145   <a href="$xwiki.getURL('services.xwiki-development-integrations')">View development services</a>
... ... @@ -149,64 +149,33 @@
149 149   </div>
150 150   </section>
151 151  
152 - <section class="contrast-band" aria-labelledby="industry-trust-title">
153 - <div class="container">
154 - <div class="contrast-panel">
155 - <h2 id="industry-trust-title">Trusted XWiki expertise for business-critical platforms</h2>
156 -
157 - <p class="section-intro">
158 - Experience supporting XWiki platforms used in healthcare, financial services, scientific research,
159 - government institutions, transportation, software development, compliance programs and regulated environments.
160 - </p>
161 -
162 - <div class="contrast-tags" aria-label="Industries and environments supported">
163 - <span>Healthcare</span>
164 - <span>Financial services</span>
165 - <span>Scientific research</span>
166 - <span>Government institutions</span>
167 - <span>Transportation</span>
168 - <span>Software development</span>
169 - <span>Compliance programs</span>
170 - <span>Regulated environments</span>
171 - </div>
172 -
173 - <p class="contrast-support">
174 - Organizations rely on these platforms to manage documentation, workflows, compliance processes,
175 - research knowledge and critical business information. From upgrades and authentication integrations
176 - to workflow systems and long-term maintenance, Agnease helps keep XWiki secure, stable and ready for the future.
177 - </p>
178 - </div>
179 - </div>
180 - </section>
181 -
182 182   <section class="split-section" aria-labelledby="why-title">
183 183   <div class="container">
184 184   <div class="split-grid">
185 185   <div class="split-copy">
186 - <h2 id="why-title">Why work with an XWiki specialist</h2>
115 + <h2 id="why-title">Why choose Agnease</h2>
187 187   <p>
188 - XWiki projects often involve more than pages. Production platforms may include custom code,
189 - extensions, authentication, permissions, workflows, integrations, compliance documentation
190 - and business-critical knowledge.
117 + Agnease brings more than 11 years of hands-on XWiki expertise to organizations that need reliable
118 + knowledge platforms, secure upgrades, custom applications, integrations, migrations and long-term support.
191 191   </p>
192 192   <p>
193 - Agnease brings 11+ years of hands-on XWiki experience to help reduce risk, support long-term reliability
194 - and leave the platform easier to maintain after the work is complete.
121 + The approach is practical and engineering-focused: understand the current system, reduce risk,
122 + document the work and leave your XWiki easier to maintain.
195 195   </p>
196 196   </div>
197 197  
198 198   <ol class="process-list">
199 199   <li>
200 - <strong>Review the XWiki environment</strong>
201 - Version, extensions, infrastructure, authentication, permissions, custom code and critical features.
128 + <strong>Review the current situation</strong>
129 + Version, extensions, infrastructure, authentication, custom code and business-critical features.
202 202   </li>
203 203   <li>
204 - <strong>Define the safest next steps</strong>
205 - Scope, risks, dependencies, effort, rollback options and validation requirements.
132 + <strong>Define a safe path forward</strong>
133 + Clear scope, expected effort, risks, rollback options and recommended next steps.
206 206   </li>
207 207   <li>
208 - <strong>Implement, validate and document</strong>
209 - Controlled changes, testing, production validation and notes for future maintenance.
136 + <strong>Deliver and document the work</strong>
137 + Practical implementation, validation and documentation for future maintenance.
210 210   </li>
211 211   </ol>
212 212   </div>
... ... @@ -215,9 +215,9 @@
215 215  
216 216   <section class="resource-strip homepage-resource-strip" aria-labelledby="resources-title">
217 217   <div class="container">
218 - <h2 id="resources-title">XWiki resources for safer long-term maintenance</h2>
146 + <h2 id="resources-title">Useful XWiki resources</h2>
219 219   <p class="section-intro">
220 - Practical articles about XWiki upgrades, customization and production platform care.
148 + Practical guidance for organizations running XWiki in production.
221 221   </p>
222 222  
223 223   <div class="resource-grid">
... ... @@ -224,17 +224,17 @@
224 224   <article class="resource-card">
225 225   <h4>Why upgrade your XWiki instance?</h4>
226 226   <p>
227 - Learn why regular XWiki upgrades reduce security exposure, compatibility issues and long-term maintenance risk.
155 + A business-focused explanation of why regular LTS upgrades reduce security, compatibility and maintenance risk.
228 228   </p>
229 - <a href="$xwiki.getURL('resources.why-upgrade-xwiki')">Read the article</a>
157 + <a href="$xwiki.getURL('resources.why-upgrade-xwiki')">Read the resource</a>
230 230   </article>
231 231  
232 232   <article class="resource-card">
233 233   <h4>XWiki upgrade services</h4>
234 234   <p>
235 - See how XWiki upgrades can be planned, tested and validated for production instances with customizations and integrations.
163 + How Agnease approaches safe XWiki upgrades for real production environments with customizations and integrations.
236 236   </p>
237 - <a href="$xwiki.getURL('services.xwiki-upgrades')">View upgrade services</a>
165 + <a href="$xwiki.getURL('services.xwiki-upgrades')">View the service</a>
238 238   </article>
239 239   </div>
240 240   </div>
... ... @@ -243,10 +243,10 @@
243 243   <section class="cta-section" aria-labelledby="contact-title">
244 244   <div class="container">
245 245   <div class="cta-panel">
246 - <h2 id="contact-title">Need XWiki consulting or support?</h2>
174 + <h2 id="contact-title">Need help with XWiki?</h2>
247 247   <p>
248 - Send your current XWiki version, the issue you are facing, or the type of project you want to build.
249 - A short description is enough to define practical next steps.
176 + Send your current XWiki version, the problem you are facing, or the type of project you want to build.
177 + A short description is enough to start the conversation.
250 250   </p>
251 251   <a class="btn btn-primary" href="$xwiki.getURL('contact.WebHome')">Contact Agnease</a>
252 252   </div>
agnease-xwiki-hero.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.Admin
Size
... ... @@ -1,1 +1,0 @@
1 -981.8 KB
Content
Agnease.Code.SEODetailsClass[0]
metaDescription
... ... @@ -1,1 +1,0 @@
1 -Agnease provides professional XWiki consulting, LTS upgrades, maintenance, custom development, migrations, integrations and security-aware support for production XWiki platforms.
metaTitle
... ... @@ -1,1 +1,0 @@
1 -Professional XWiki Consulting, Upgrades and Development | Agnease
XWiki.StyleSheetExtension[0]
code
... ... @@ -1,5 +1,5 @@
1 1  /* ========== Agnease Public Website ========== */
2 -/*
2 +
3 3  @brand: #00937D;
4 4  @brand-strong: #007B6A;
5 5  @brand-soft: #E7FFF8;
... ... @@ -11,23 +11,7 @@
11 11  @shadow-sm: 0 6px 20px rgba(0, 0, 0, .06);
12 12  @shadow: 0 12px 36px rgba(0, 0, 0, .08);
13 13  @maxw: 1140px;
14 -*/
15 -@brand: #00937D;
16 -@brand-strong: #007B6A;
17 -@brand-soft: #E7FFF8;
18 -@brand-bg: #F7F9FC;
19 -@text: #07182D;
20 -@text-soft: #10243D;
21 -@muted: #64748B;
22 -@line: #E6EBF2;
23 -@radius: 18px;
24 -@shadow-sm: 0 18px 45px rgba(15, 23, 42, .06);
25 -@shadow: 0 30px 80px rgba(15, 23, 42, .12);
26 -@maxw: 1140px;
27 27  
28 -@section-padding: 30px 0;
29 -@section-padding-mobile: 28px 0;
30 -
31 31  /* ========== Base ========== */
32 32  
33 33  #mainContentArea {
... ... @@ -47,7 +47,7 @@
47 47  }
48 48  
49 49  section {
50 - padding: @section-padding;
34 + padding: 42px 0;
51 51   border-top: 1px solid @line;
52 52  
53 53   &:first-of-type {
... ... @@ -150,7 +150,7 @@
150 150  
151 151  /* ========== Buttons ========== */
152 152  
153 -/*.btn-primary {
137 +.btn-primary {
154 154   background: @brand;
155 155   border-color: @brand;
156 156   color: #fff;
... ... @@ -162,12 +162,18 @@
162 162   color: #fff;
163 163   }
164 164  }
165 -*/
149 +
166 166  .btn-secondary {
167 - color: @text;
151 + color: @brand;
168 168   background: #fff;
169 - border: 1px solid fade(@text, 35%);
153 + border: 1px solid fade(@brand, 35%);
170 170  
155 + &:hover,
156 + &:focus {
157 + color: @brand-strong;
158 + border-color: @brand;
159 + background: @brand-bg;
160 + }
171 171  }
172 172  
173 173  /* ========== Hero ========== */
... ... @@ -179,6 +179,9 @@
179 179  
180 180   &.hero-centered {
181 181   text-align: center;
172 + background:
173 + radial-gradient(50rem 18rem at 50% -10%, @brand-soft 0%, transparent 60%),
174 + radial-gradient(50rem 18rem at 50% 0%, #E8F6F3 0%, transparent 60%);
182 182   display: flex;
183 183   align-items: center;
184 184   justify-content: center;
... ... @@ -201,10 +201,9 @@
201 201   }
202 202  
203 203   .lead {
204 - max-width: 820px;
197 + max-width: 760px;
205 205   font-size: 19px;
206 206   line-height: 1.55;
207 - margin-top: 12px;
208 208   }
209 209  
210 210   .benefits {
... ... @@ -238,6 +238,13 @@
238 238   font-weight: 700;
239 239  }
240 240  
233 +.hero-support {
234 + max-width: 760px;
235 + margin: 14px auto 0;
236 + color: @muted;
237 + line-height: 1.55;
238 +}
239 +
241 241  .hero-actions,
242 242  #hero-cta {
243 243   display: flex;
... ... @@ -247,112 +247,35 @@
247 247   margin-top: 22px;
248 248  }
249 249  
250 -/* ========== Contrast Band ========== */
249 +/* ========== Trust Strip ========== */
251 251  
252 -.contrast-band {
253 - position: relative;
254 - overflow: hidden;
255 - padding: 54px 0;
256 - border-top: 0;
257 - background:
258 - radial-gradient(circle at 18% 18%, fade(@brand, 22%) 0%, transparent 28%),
259 - radial-gradient(circle at 86% 12%, fade(@brand, 16%) 0%, transparent 30%),
260 - linear-gradient(135deg, @text 0%, @text-soft 100%);
261 - color: #fff;
251 +.trust-strip {
252 + padding: 18px 0;
253 + border-top: 1px solid @line;
254 + border-bottom: 1px solid @line;
255 + background: #fff;
262 262  
263 - /*
264 - * Full-bleed background without changing layout width.
265 - * This extends the dark surface beyond a fixed-width parent
266 - * without using 100vw or negative margins.
267 - */
268 - box-shadow: 0 0 0 100vmax @text;
269 - clip-path: inset(0 -100vmax);
270 -}
257 + ul {
258 + max-width: 960px;
259 + margin: 0 auto;
260 + padding: 0;
261 + list-style: none;
262 + display: flex;
263 + justify-content: center;
264 + gap: 22px;
265 + flex-wrap: wrap;
266 + color: @muted;
267 + font-size: 13px;
268 + }
271 271  
272 -.contrast-band::before {
273 - content: "";
274 - position: absolute;
275 - inset: 0;
276 - background:
277 - linear-gradient(90deg, fade(#fff, 4%) 1px, transparent 1px),
278 - linear-gradient(180deg, fade(#fff, 4%) 1px, transparent 1px);
279 - background-size: 52px 52px;
280 - opacity: .38;
281 - pointer-events: none;
282 -}
283 -
284 -.contrast-band .container {
285 - position: relative;
286 - z-index: 1;
287 -}
288 -
289 -.contrast-panel {
290 - max-width: 1040px;
291 - margin: 0 auto;
292 - text-align: center;
293 -}
294 -
295 -.contrast-band h2 {
296 - max-width: 860px;
297 - margin: 0 auto 12px;
298 - color: #fff;
299 -}
300 -
301 -.contrast-band .section-intro {
302 - max-width: 840px;
303 - margin: 0 auto 26px;
304 - color: #D9E3EE;
305 -}
306 -
307 -.contrast-tags {
308 - max-width: 940px;
309 - margin: 0 auto;
310 - display: flex;
311 - flex-wrap: wrap;
312 - justify-content: center;
313 - gap: 10px;
314 -}
315 -
316 -.contrast-tags span {
317 - display: inline-flex;
318 - align-items: center;
319 - padding: 8px 13px;
320 - border: 1px solid fade(#fff, 18%);
321 - border-radius: 999px;
322 - background: fade(#fff, 8%);
323 - color: #F8FAFC;
324 - font-size: 13px;
325 - font-weight: 700;
326 - line-height: 1.2;
327 -}
328 -
329 -.contrast-tags span::before {
330 - content: "";
331 - width: 7px;
332 - height: 7px;
333 - margin-right: 8px;
334 - border-radius: 50%;
335 - background: @brand;
336 - box-shadow: 0 0 0 4px fade(@brand, 18%);
337 -}
338 -
339 -.contrast-support {
340 - max-width: 860px;
341 - margin: 30px auto 0;
342 - color: #D9E3EE;
343 - text-align: center;
344 - font-size: 15px;
345 - line-height: 1.7;
346 -}
347 -
348 -@media (max-width: 640px) {
349 - .contrast-band {
350 - padding: 40px 0;
270 + li {
271 + display: flex;
272 + align-items: center;
273 + gap: 7px;
351 351   }
352 352  
353 - .contrast-tags span {
354 - font-size: 12px;
355 - padding: 8px 11px;
276 + i {
277 + color: @brand;
356 356   }
357 357  }
358 358  
... ... @@ -374,7 +374,7 @@
374 374  .services-grid {
375 375   grid-template-columns: repeat(3, minmax(0, 1fr));
376 376   max-width: 1040px;
377 - margin-top: 22px;
299 + margin-top: 26px;
378 378  }
379 379  
380 380  .resource-grid {
... ... @@ -403,6 +403,7 @@
403 403  .pathway-card,
404 404  .service-card,
405 405  .resource-card {
328 + background: #fff;
406 406   border: 1px solid @line;
407 407   border-radius: @radius;
408 408   box-shadow: @shadow-sm;
... ... @@ -450,13 +450,6 @@
450 450   flex-direction: column;
451 451   min-height: 100%;
452 452  
453 - .card-heading {
454 - display: flex;
455 - align-items: center;
456 - gap: 14px;
457 - margin-bottom: 14px;
458 - }
459 -
460 460   .pathway-icon {
461 461   width: 52px;
462 462   height: 52px;
... ... @@ -466,12 +466,12 @@
466 466   justify-content: center;
467 467   color: @brand;
468 468   background: fade(@brand, 10%);
385 + margin-bottom: 18px;
469 469   font-size: 19px;
470 - flex-shrink: 0;
471 471   }
472 472  
473 473   h3 {
474 - margin: 0;
390 + margin: 0 0 10px;
475 475   color: @text;
476 476   font-size: 22px;
477 477   line-height: 1.25;
... ... @@ -524,6 +524,7 @@
524 524   align-items: flex-start;
525 525   gap: 16px;
526 526   padding: 22px;
443 + background: #fff;
527 527   border: 1px solid @line;
528 528   border-radius: @radius;
529 529   box-shadow: @shadow-sm;
... ... @@ -611,6 +611,7 @@
611 611   position: relative;
612 612   padding: 16px 16px 16px 58px;
613 613   margin-bottom: 12px;
531 + background: #fff;
614 614   border: 1px solid @line;
615 615   border-radius: @radius;
616 616   box-shadow: @shadow-sm;
... ... @@ -669,6 +669,31 @@
669 669   }
670 670  }
671 671  
590 +.resource-content {
591 + order: 1;
592 +}
593 +
594 +.resource-sidebar {
595 + order: 2;
596 +}
597 +
598 +@media (max-width: 767px) {
599 + .resource-layout {
600 + display: flex;
601 + flex-direction: column;
602 + }
603 +
604 + .resource-sidebar {
605 + order: 0;
606 + position: static;
607 + width: 100%;
608 + }
609 +
610 + .resource-content {
611 + order: 1;
612 + }
613 +}
614 +
672 672  /* ========== Homepage Resource Strip ========== */
673 673  
674 674  .homepage-resource-strip {
... ... @@ -677,7 +677,7 @@
677 677  
678 678   .resource-grid {
679 679   max-width: 1040px;
680 - margin: 22px auto 0;
623 + margin: 26px auto 0;
681 681   display: grid;
682 682   grid-template-columns: repeat(2, minmax(0, 1fr));
683 683   grid-gap: 22px;
... ... @@ -742,8 +742,8 @@
742 742  
743 743  /* ========== CTA ========== */
744 744  
745 -#mainContentArea .cta-section {
746 - padding: 44px 0 56px;
688 +.cta-section {
689 + padding: 32px 0 24px;
747 747  
748 748   .contact-inline {
749 749   margin: 0;
... ... @@ -755,114 +755,27 @@
755 755   }
756 756  }
757 757  
758 -#mainContentArea .cta-panel {
759 - position: relative;
760 - overflow: hidden;
761 - max-width: 1040px;
701 +.cta-panel {
702 + max-width: 860px;
762 762   margin: 0 auto;
763 - padding: 48px 40px;
764 - border: 0;
765 - border-radius: 26px;
704 + padding: 32px;
705 + border-radius: @radius;
706 + border: 1px solid fade(@brand, 20%);
766 766   background:
767 - radial-gradient(circle at 88% 10%, fade(@brand, 24%) 0%, transparent 30%),
768 - linear-gradient(135deg, @text 0%, @text-soft 100%);
769 - color: #fff;
770 - box-shadow: @shadow;
708 + radial-gradient(34rem 12rem at 50% 0%, @brand-soft 0%, #fff 70%);
709 + box-shadow: @shadow-sm;
771 771   text-align: center;
772 -}
773 773  
774 -#mainContentArea .cta-panel::before {
775 - content: "";
776 - position: absolute;
777 - inset: 0;
778 - background:
779 - linear-gradient(90deg, fade(#fff, 4%) 1px, transparent 1px),
780 - linear-gradient(180deg, fade(#fff, 4%) 1px, transparent 1px);
781 - background-size: 48px 48px;
782 - opacity: .4;
783 - pointer-events: none;
784 -}
712 + h2 {
713 + margin-top: 0;
714 + }
785 785  
786 -#mainContentArea .cta-panel h2,
787 -#mainContentArea .cta-panel p,
788 -#mainContentArea .cta-panel .btn {
789 - position: relative;
790 - z-index: 1;
791 -}
792 -
793 -#mainContentArea .cta-panel h2 {
794 - max-width: 760px;
795 - margin: 0 auto 16px;
796 - color: #fff;
797 -}
798 -
799 -#mainContentArea .cta-panel p {
800 - max-width: 760px;
801 - margin: 0 auto 28px;
802 - color: #DBE4EF;
803 - font-size: 16px;
804 - line-height: 1.6;
805 -}
806 -
807 -#mainContentArea .cta-panel .btn-primary {
808 - border-color: #fff;
809 - background: #fff;
810 - color: @text;
811 - box-shadow: 0 18px 42px rgba(0, 0, 0, .18);
812 -}
813 -
814 -#mainContentArea .cta-panel .btn-primary:hover,
815 -#mainContentArea .cta-panel .btn-primary:focus {
816 - border-color: #fff;
817 - background: #fff;
818 - color: @brand-strong;
819 - text-decoration: none;
820 -}
821 -
822 -.resource-inline-cta {
823 - display: flex;
824 - align-items: center;
825 - justify-content: space-between;
826 - gap: 22px;
827 - margin: 30px 0;
828 - padding: 20px 22px;
829 - border: 1px solid fade(@brand, 22%);
830 - border-radius: @radius;
831 - background: @brand-bg;
832 - box-shadow: @shadow-sm;
833 -
834 834   p {
835 - margin: 0;
836 836   color: @muted;
837 837   line-height: 1.55;
838 838   }
839 -
840 - strong {
841 - color: @text;
842 - }
843 -
844 - .btn {
845 - flex-shrink: 0;
846 - }
847 847  }
848 848  
849 -@media (max-width: 767px) {
850 - .resource-inline-cta {
851 - display: block;
852 - text-align: center;
853 -
854 - p {
855 - margin-bottom: 14px;
856 - }
857 -
858 - .btn {
859 - display: inline-block;
860 - margin-left: auto;
861 - margin-right: auto;
862 - }
863 - }
864 -}
865 -
866 866  /* ========== Responsive ========== */
867 867  
868 868  @media (max-width: 980px) {
... ... @@ -929,7 +929,7 @@
929 929  
930 930  @media (max-width: 640px) {
931 931   section {
932 - padding: @section-padding-mobile;
788 + padding: 34px 0;
933 933   }
934 934  
935 935   .widgets,
... ... @@ -950,25 +950,22 @@
950 950   gap: 14px;
951 951   }
952 952  
953 - #mainContentArea .cta-panel {
954 - padding: 30px 22px;
955 - border-radius: 20px;
809 + .cta-panel {
810 + padding: 24px 20px;
956 956   }
957 -
958 - #mainContentArea .cta-panel .btn-primary {
959 - width: 100%;
960 - }
961 961  }
962 -
963 963  /* ========== Resource / Article Pages ========== */
964 964  
965 965  .resource-page {
966 - padding-top: 0;
816 + padding-top: 34px;
967 967  }
968 968  
969 969  .resource-header {
970 - padding: @section-padding;
820 + padding: 40px 0 30px;
971 971   border-top: none;
822 + background:
823 + radial-gradient(50rem 18rem at 50% -10%, @brand-soft 0%, transparent 60%),
824 + radial-gradient(50rem 18rem at 50% 0%, #E8F6F3 0%, transparent 60%);
972 972  
973 973   h1 {
974 974   margin: 0 auto 14px;
... ... @@ -987,18 +987,14 @@
987 987  }
988 988  
989 989  .resource-layout {
990 - display: block;
843 + display: grid;
844 + grid-template-columns: minmax(0, 760px) 280px;
845 + gap: 42px;
991 991   max-width: 1080px;
992 992   margin: 0 auto;
993 - padding-top: 28px;
848 + align-items: start;
994 994  }
995 995  
996 -.resource-layout::after {
997 - content: "";
998 - display: block;
999 - clear: both;
1000 -}
1001 -
1002 1002  .resource-content {
1003 1003   color: @text;
1004 1004   font-size: 16px;
... ... @@ -1046,45 +1046,6 @@
1046 1046   }
1047 1047  }
1048 1048  
1049 -.resource-note.related-resources {
1050 - p {
1051 - margin-bottom: 10px;
1052 - }
1053 -
1054 - ul {
1055 - margin: 0;
1056 - padding-left: 20px;
1057 - }
1058 -
1059 - li {
1060 - margin: 6px 0;
1061 - color: @muted;
1062 - }
1063 -}
1064 -
1065 -.resource-faq-item {
1066 - display: flow-root;
1067 - border-bottom: 1px solid @line;
1068 - padding: 12px 0;
1069 -
1070 - summary {
1071 - cursor: pointer;
1072 - font-weight: 700;
1073 - color: @text;
1074 - line-height: 1.4;
1075 - }
1076 -
1077 - summary:hover,
1078 - summary:focus {
1079 - color: @brand-strong;
1080 - }
1081 -
1082 - p {
1083 - margin: 10px 0 4px;
1084 - color: @muted;
1085 - }
1086 -}
1087 -
1088 1088  .resource-checklist {
1089 1089   margin: 18px 0 24px;
1090 1090   padding: 0;
... ... @@ -1107,15 +1107,12 @@
1107 1107  }
1108 1108  
1109 1109  .resource-sidebar {
1110 - float: right;
1111 - width: 280px;
1112 - margin-left: 42px;
1113 - margin-bottom: 28px;
1114 1114   position: sticky;
1115 1115   top: 96px;
1116 1116   border: 1px solid @line;
1117 1117   border-radius: @radius;
1118 1118   padding: 18px;
925 + background: #fff;
1119 1119   box-shadow: @shadow-sm;
1120 1120  
1121 1121   h4 {
... ... @@ -1139,14 +1139,8 @@
1139 1139  }
1140 1140  
1141 1141  .resource-cta {
1142 - display: flex;
1143 - flex-direction: column;
1144 - align-items: center;
1145 - text-align: center;
1146 -
1147 - max-width: 820px;
1148 - margin: 42px auto 0;
1149 - padding: 28px 30px;
949 + margin-top: 36px;
950 + padding: 22px;
1150 1150   border: 1px solid fade(@brand, 20%);
1151 1151   border-radius: @radius;
1152 1152   background: @brand-bg;
... ... @@ -1153,51 +1153,26 @@
1153 1153  
1154 1154   h3 {
1155 1155   margin-top: 0;
1156 - margin-bottom: 10px;
1157 1157   }
1158 1158  
1159 1159   p {
1160 - max-width: 680px;
1161 - margin-left: auto;
1162 - margin-right: auto;
1163 1163   color: @muted;
1164 1164   }
1165 -
1166 - .btn {
1167 - margin-top: 8px;
1168 - }
1169 1169  }
1170 1170  
1171 -.resource-note,
1172 -.resource-checklist,
1173 -.resource-cta {
1174 - display: flow-root;
1175 -}
1176 -
1177 -@media (max-width: 767px) {
1178 - .resource-cta {
1179 - padding: 24px 20px;
1180 - }
1181 -}
1182 -
1183 1183  @media (max-width: 900px) {
1184 1184   .resource-layout {
1185 - padding-top: 22px;
966 + grid-template-columns: 1fr;
1186 1186   }
1187 1187  
1188 1188   .resource-sidebar {
1189 - float: none;
1190 - width: 100%;
1191 - margin-left: 0;
1192 - margin-bottom: 24px;
1193 1193   position: static;
1194 1194   }
1195 1195  }
1196 -
1197 1197  /* ========== Products / Extensions Pages ========== */
1198 1198  
1199 1199  .product-index-section {
1200 - padding: @section-padding;
976 + padding: 52px 0 56px;
1201 1201  
1202 1202   h2 {
1203 1203   margin-bottom: 10px;
... ... @@ -1205,39 +1205,30 @@
1205 1205  }
1206 1206  
1207 1207  .product-card-grid {
1208 - max-width: 980px;
1209 - margin: 26px auto 0;
984 + max-width: 840px;
985 + margin: 28px auto 0;
1210 1210   display: grid;
1211 1211   grid-template-columns: 1fr;
1212 - grid-gap: 22px;
988 + grid-gap: 18px;
1213 1213  }
1214 1214  
1215 1215  .product-card {
1216 - position: relative;
992 + background: #fff;
1217 1217   border: 1px solid @line;
1218 1218   border-radius: @radius;
1219 1219   box-shadow: @shadow-sm;
1220 - padding: 32px;
996 + padding: 28px;
1221 1221   display: grid;
1222 - grid-template-columns: 70px 1fr;
1223 - grid-gap: 24px;
998 + grid-template-columns: 68px 1fr;
999 + grid-gap: 22px;
1224 1224   align-items: start;
1225 - overflow: hidden;
1226 1226  
1227 - &:before {
1228 - content: "";
1229 - position: absolute;
1230 - inset: 0 auto 0 0;
1231 - width: 5px;
1232 - background: linear-gradient(180deg, @brand 0%, @brand-strong 100%);
1233 - }
1234 -
1235 1235   .product-card-icon {
1236 1236   width: 58px;
1237 1237   height: 58px;
1238 1238   border-radius: 50%;
1239 1239   background: fade(@brand, 10%);
1240 - border: 1px solid fade(@brand, 22%);
1007 + border: 1px solid fade(@brand, 20%);
1241 1241   color: @brand;
1242 1242   display: flex;
1243 1243   align-items: center;
... ... @@ -1246,15 +1246,11 @@
1246 1246   flex-shrink: 0;
1247 1247   }
1248 1248  
1249 - .product-card-body {
1250 - min-width: 0;
1251 - }
1252 -
1253 1253   h3 {
1254 1254   margin: 0 0 10px;
1255 1255   color: @text;
1256 - font-size: 25px;
1257 - line-height: 1.22;
1019 + font-size: 23px;
1020 + line-height: 1.25;
1258 1258   font-weight: 800;
1259 1259   }
1260 1260  
... ... @@ -1263,36 +1263,25 @@
1263 1263   line-height: 1.6;
1264 1264   }
1265 1265  
1266 - .product-card-description {
1267 - max-width: 760px;
1268 - margin: 0 0 14px;
1269 - font-size: 16px;
1029 + .card-link {
1030 + margin: 0;
1031 +
1032 + a {
1033 + font-weight: 700;
1034 + }
1270 1270   }
1271 1271  }
1272 1272  
1273 1273  .product-card-kicker {
1274 - display: inline-flex;
1275 - align-items: center;
1276 - gap: 7px;
1277 - width: fit-content;
1278 1278   margin-bottom: 10px;
1279 1279   padding: 5px 10px;
1280 - border: 1px solid fade(@brand, 24%);
1281 - border-radius: 999px;
1282 - background: fade(@brand, 8%);
1283 - color: @brand-strong;
1284 1284   font-size: 12px;
1285 - font-weight: 800;
1286 1286   text-transform: uppercase;
1287 1287   letter-spacing: .04em;
1288 -
1289 - i {
1290 - color: @brand;
1291 - }
1292 1292  }
1293 1293  
1294 1294  .product-highlights {
1295 - margin: 14px 0 22px;
1047 + margin: 14px 0 20px;
1296 1296   padding-left: 18px;
1297 1297   color: @muted;
1298 1298  
... ... @@ -1302,58 +1302,12 @@
1302 1302   }
1303 1303  }
1304 1304  
1305 -.product-card-actions {
1306 - display: flex;
1307 - align-items: center;
1308 - gap: 16px;
1309 - flex-wrap: wrap;
1310 -
1311 - .btn {
1312 - font-weight: 700;
1313 - }
1314 -}
1315 -
1316 -.product-card-contact {
1317 - color: @brand;
1318 - font-weight: 700;
1319 - text-decoration: underline;
1320 -
1321 - &:hover,
1322 - &:focus {
1323 - color: @brand-strong;
1324 - }
1325 -}
1326 -
1327 -@media (max-width: 640px) {
1328 - .product-card {
1329 - grid-template-columns: 1fr;
1330 - padding: 26px 22px;
1331 - text-align: left;
1332 -
1333 - &:before {
1334 - width: 4px;
1335 - }
1336 -
1337 - .product-card-icon {
1338 - margin-bottom: 2px;
1339 - }
1340 -
1341 - h3 {
1342 - font-size: 22px;
1343 - }
1344 - }
1345 -
1346 - .product-card-actions {
1347 - gap: 12px;
1348 - }
1349 -}
1350 -
1351 1351  /* ========== Individual Product Pages ========== */
1352 1352  
1353 1353  .product-layout {
1354 1354   display: grid;
1355 - grid-template-columns: minmax(0, 1.12fr) minmax(280px, .88fr);
1356 - grid-gap: 32px;
1061 + grid-template-columns: 1.1fr .9fr;
1062 + grid-gap: 36px;
1357 1357   max-width: 1040px;
1358 1358   margin: 0 auto;
1359 1359   align-items: start;
... ... @@ -1361,8 +1361,8 @@
1361 1361  
1362 1362  .product-summary-card,
1363 1363  .product-info-card,
1364 -.product-feature,
1365 1365  .product-gallery-panel {
1071 + background: #fff;
1366 1366   border: 1px solid @line;
1367 1367   border-radius: @radius;
1368 1368   box-shadow: @shadow-sm;
... ... @@ -1369,18 +1369,16 @@
1369 1369  }
1370 1370  
1371 1371  .product-summary-card {
1372 - padding: 28px;
1078 + padding: 26px;
1373 1373  
1374 1374   h2 {
1375 1375   text-align: left;
1376 1376   margin-top: 0;
1377 - margin-bottom: 14px;
1378 - line-height: 1.25;
1379 1379   }
1380 1380  
1381 1381   p {
1382 1382   color: @muted;
1383 - line-height: 1.62;
1087 + line-height: 1.6;
1384 1384   }
1385 1385  
1386 1386   p:last-child {
... ... @@ -1389,19 +1389,13 @@
1389 1389  }
1390 1390  
1391 1391  .product-info-card {
1392 - padding: 24px;
1096 + padding: 22px;
1393 1393  
1394 1394   h3 {
1395 1395   margin-top: 0;
1396 1396   margin-bottom: 12px;
1397 - line-height: 1.3;
1398 1398   }
1399 1399  
1400 - p {
1401 - color: @muted;
1402 - line-height: 1.55;
1403 - }
1404 -
1405 1405   ul {
1406 1406   margin: 0;
1407 1407   padding-left: 20px;
... ... @@ -1410,37 +1410,25 @@
1410 1410  
1411 1411   li {
1412 1412   margin: 8px 0;
1413 - line-height: 1.3;
1111 + line-height: 1.45;
1414 1414   }
1415 1415  }
1416 1416  
1417 -.product-card-note {
1418 - margin: 0 0 14px;
1419 - color: @muted;
1420 - line-height: 1.55;
1421 -}
1422 -
1423 1423  .product-feature-grid {
1424 1424   display: grid;
1425 1425   grid-template-columns: repeat(3, minmax(0, 1fr));
1426 - grid-gap: 20px;
1118 + grid-gap: 18px;
1427 1427   max-width: 1040px;
1428 - margin: 24px auto 0;
1120 + margin: 26px auto 0;
1429 1429  }
1430 1430  
1431 1431  .product-feature {
1432 - padding: 24px;
1433 - min-width: 0;
1434 - min-height: 100%;
1124 + background: #fff;
1125 + border: 1px solid @line;
1126 + border-radius: @radius;
1127 + box-shadow: @shadow-sm;
1128 + padding: 22px;
1435 1435  
1436 - .card-heading,
1437 - .feature-heading {
1438 - display: flex;
1439 - align-items: center;
1440 - gap: 14px;
1441 - margin-bottom: 14px;
1442 - }
1443 -
1444 1444   .feature-icon {
1445 1445   width: 46px;
1446 1446   height: 46px;
... ... @@ -1450,12 +1450,12 @@
1450 1450   display: flex;
1451 1451   align-items: center;
1452 1452   justify-content: center;
1139 + margin-bottom: 14px;
1453 1453   font-size: 18px;
1454 - flex-shrink: 0;
1455 1455   }
1456 1456  
1457 1457   h3 {
1458 - margin: 0;
1144 + margin: 0 0 8px;
1459 1459   color: @text;
1460 1460   font-size: 18px;
1461 1461   line-height: 1.25;
... ... @@ -1464,56 +1464,10 @@
1464 1464   p {
1465 1465   margin: 0;
1466 1466   color: @muted;
1467 - line-height: 1.52;
1153 + line-height: 1.5;
1468 1468   }
1469 1469  }
1470 1470  
1471 -.product-gallery-caption {
1472 - max-width: 820px;
1473 - margin: 12px auto 0;
1474 - color: @muted;
1475 - font-size: 14px;
1476 - line-height: 1.5;
1477 - text-align: center;
1478 -}
1479 -
1480 -/* Keep the default XWiki gallery style.
1481 - Only add spacing before it and center it. */
1482 -.gallery.xGallery {
1483 - margin: 25px auto;
1484 - width: 920px;
1485 - height: 518px;
1486 -}
1487 -
1488 -.product-section-muted {
1489 - background:
1490 - radial-gradient(42rem 16rem at 50% 0%, @brand-bg 0%, transparent 65%);
1491 -}
1492 -
1493 -/* Compact process list when used inside a product card. */
1494 -.product-summary-card .process-list {
1495 - margin-top: 16px;
1496 -
1497 - li {
1498 - padding: 13px 14px 13px 50px;
1499 - margin-bottom: 10px;
1500 - box-shadow: none;
1501 - }
1502 -
1503 - li:before {
1504 - left: 14px;
1505 - top: 14px;
1506 - width: 24px;
1507 - height: 24px;
1508 - font-size: 12px;
1509 - }
1510 -
1511 - strong {
1512 - margin-bottom: 2px;
1513 - }
1514 -}
1515 -
1516 -/* Kept for older product pages that still use a screenshot placeholder/panel. */
1517 1517  .product-gallery-panel {
1518 1518   max-width: 1040px;
1519 1519   margin: 20px auto 0;
... ... @@ -1546,6 +1546,11 @@
1546 1546   justify-content: center;
1547 1547  }
1548 1548  
1189 +.product-section-muted {
1190 + background:
1191 + radial-gradient(42rem 16rem at 50% 0%, @brand-bg 0%, transparent 65%);
1192 +}
1193 +
1549 1549  @media (max-width: 980px) {
1550 1550   .product-layout,
1551 1551   .product-feature-grid {
... ... @@ -1574,359 +1574,142 @@
1574 1574   .product-gallery-panel {
1575 1575   padding: 20px;
1576 1576   }
1577 -
1578 - .product-feature {
1579 - .card-heading,
1580 - .feature-heading {
1581 - gap: 12px;
1582 - }
1583 -
1584 - .feature-icon {
1585 - width: 42px;
1586 - height: 42px;
1587 - font-size: 16px;
1588 - }
1589 - }
1590 -
1591 - .gallery.xGallery {
1592 - margin-top: 22px !important;
1593 - }
1594 -
1595 - .product-gallery-caption {
1596 - margin-top: 10px;
1597 - padding: 0 14px;
1598 - }
1599 -
1600 - .product-summary-card .process-list li {
1601 - padding-left: 46px;
1602 - }
1603 1603  }
1604 -
1605 1605  /* ========== Resources Index ========== */
1606 1606  
1607 1607  .resources-index-page {
1608 -
1609 - .services-grid {
1610 - grid-template-columns: repeat(2, minmax(0, 1fr));
1611 - }
1226 + padding: 56px 0 72px;
1227 + background: @brand-bg;
1612 1612  }
1613 1613  
1614 -@media (max-width: 980px) {
1615 - .resources-index-page {
1616 - .services-grid {
1617 - grid-template-columns: 1fr;
1618 - }
1619 - }
1230 +.resources-intro {
1231 + max-width: 820px;
1232 + margin: 0 auto 32px;
1233 + text-align: center;
1620 1620  }
1621 1621  
1622 -@media (max-width: 767px) {
1623 - .resources-index-page {
1624 - padding: @section-padding-mobile;
1625 - }
1236 +.resources-intro p {
1237 + color: @muted;
1238 + font-size: 17px;
1239 + line-height: 1.7;
1240 + margin: 0;
1626 1626  }
1627 1627  
1628 -.resource-faq-item {
1629 - border-bottom: 1px solid @line;
1630 - padding: 12px 0;
1631 -
1632 - summary {
1633 - cursor: pointer;
1634 - font-weight: 700;
1635 - color: @text;
1636 - }
1637 -
1638 - p {
1639 - margin: 10px 0 4px;
1640 - color: @muted;
1641 - }
1243 +.resources-grid {
1244 + display: grid;
1245 + grid-template-columns: repeat(2, minmax(0, 1fr));
1246 + gap: 24px;
1247 + margin-bottom: 36px;
1642 1642  }
1643 1643  
1644 -/* ========== Global Theme Background ========== */
1645 -
1646 -html,
1647 -body {
1648 - min-height: 100%;
1250 +.resource-card {
1251 + display: flex;
1252 + gap: 18px;
1253 + background: #fff;
1254 + border: 1px solid @line;
1255 + border-radius: @radius;
1256 + box-shadow: @shadow-sm;
1257 + padding: 24px;
1649 1649  }
1650 1650  
1651 -body {
1652 - color: @text;
1653 - background:
1654 - radial-gradient(circle at 12% 8%, rgba(0, 147, 125, 0.08) 0, transparent 26%),
1655 - radial-gradient(circle at 90% 28%, rgba(7, 24, 45, 0.05) 0, transparent 30%),
1656 - linear-gradient(180deg, #fff 0, @brand-bg 42%, #fff 100%) !important;
1657 - background-attachment: fixed;
1658 -}
1659 -
1660 -#mainContentArea {
1661 - padding: 0;
1662 - overflow-x: hidden;
1663 -}
1664 -
1665 -/* ========== Main Page Hero / SaaS Layout ========== */
1666 -
1667 -#mainContentArea .hero.hero-saas {
1668 - min-height: auto;
1669 - padding: 60px 0 34px;
1260 +.resource-card-icon {
1261 + flex: 0 0 46px;
1262 + width: 46px;
1263 + height: 46px;
1264 + border-radius: 14px;
1265 + background: @brand-soft;
1266 + color: @brand-strong;
1670 1670   display: flex;
1671 1671   align-items: center;
1672 - overflow: hidden;
1673 - background: transparent;
1269 + justify-content: center;
1270 + font-size: 20px;
1674 1674  }
1675 1675  
1676 -#mainContentArea .hero-layout {
1677 - max-width: 1120px;
1678 - margin: 0 auto;
1679 - display: grid;
1680 - grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
1681 - gap: 56px;
1682 - align-items: center;
1273 +.resource-card-label {
1274 + color: @brand-strong;
1275 + font-size: 13px;
1276 + font-weight: 700;
1277 + text-transform: uppercase;
1278 + letter-spacing: .04em;
1279 + margin-bottom: 8px;
1683 1683  }
1684 1684  
1685 -#mainContentArea .hero-copy {
1686 - min-width: 0;
1687 - text-align: left;
1282 +.resource-card h2 {
1283 + font-size: 22px;
1284 + line-height: 1.25;
1285 + margin: 0 0 12px;
1688 1688  }
1689 1689  
1690 -#mainContentArea .hero.hero-saas h1 {
1691 - max-width: 640px;
1692 - margin: 0 0 26px;
1693 - font-size: 60px;
1694 - font-weight: 800;
1695 - line-height: 1;
1696 - letter-spacing: -3px;
1288 +.resource-card h2 a {
1289 + color: @text;
1290 + text-decoration: none;
1697 1697  }
1698 1698  
1699 -#mainContentArea .hero.hero-saas h1 span {
1700 - color: @brand;
1293 +.resource-card h2 a:hover {
1294 + color: @brand-strong;
1295 + text-decoration: none;
1701 1701  }
1702 1702  
1703 -#mainContentArea .hero.hero-saas .lead {
1704 - max-width: 590px;
1705 - margin: 0 0 28px;
1706 - color: #334155;
1707 - text-align: left;
1708 - font-size: 18px;
1709 - line-height: 1.6;
1710 -}
1711 -
1712 -#mainContentArea .hero.hero-saas .benefits {
1713 - max-width: 620px;
1714 - margin: 0 0 30px;
1715 - padding: 0;
1716 - display: grid;
1717 - grid-template-columns: repeat(2, minmax(0, 1fr));
1718 - gap: 10px 24px;
1719 - list-style: none;
1720 - color: #475569;
1298 +.resource-card p {
1299 + color: @muted;
1721 1721   font-size: 15px;
1722 - text-align: left;
1301 + line-height: 1.65;
1302 + margin: 0 0 16px;
1723 1723  }
1724 1724  
1725 -#mainContentArea .hero.hero-saas .benefits li {
1726 - display: grid;
1727 - grid-template-columns: 18px minmax(0, 1fr);
1728 - column-gap: 8px;
1729 - align-items: start;
1730 - margin: 0;
1731 - line-height: 1.45;
1305 +.resource-card-link {
1306 + color: @brand-strong;
1307 + font-weight: 700;
1308 + text-decoration: none;
1732 1732  }
1733 1733  
1734 -#mainContentArea .hero.hero-saas .benefits li::before {
1735 - content: "✓";
1736 - display: block;
1737 - width: 18px;
1311 +.resource-card-link:hover {
1738 1738   color: @brand;
1739 - font-weight: 900;
1740 - line-height: 1.45;
1741 - text-align: left;
1742 - margin: 0;
1313 + text-decoration: none;
1743 1743  }
1744 1744  
1745 -#mainContentArea .hero.hero-saas .hero-actions,
1746 -#mainContentArea .hero.hero-saas #hero-cta {
1747 - display: flex;
1748 - flex-wrap: wrap;
1749 - justify-content: flex-start;
1750 - gap: 12px;
1751 - margin-top: 0;
1316 +.resources-next {
1317 + max-width: 820px;
1318 + margin: 0 auto 32px;
1319 + text-align: center;
1752 1752  }
1753 1753  
1754 -#mainContentArea .hero-image-wrapper {
1755 - min-width: 0;
1756 - display: flex;
1757 - justify-content: center;
1758 - align-items: center;
1322 +.resources-next h2 {
1323 + font-size: 26px;
1324 + margin: 0 0 10px;
1759 1759  }
1760 1760  
1761 -#mainContentArea .hero-image {
1762 - display: block;
1763 - width: 100%;
1764 - max-width: 620px;
1765 - height: auto;
1766 - border: 0;
1327 +.resources-next p {
1328 + color: @muted;
1329 + font-size: 16px;
1330 + line-height: 1.7;
1331 + margin: 0;
1767 1767  }
1768 1768  
1769 -/* ========== Main Page Hero Responsive ========== */
1770 -
1771 -@media (max-width: 1100px) {
1772 - #mainContentArea .hero-layout {
1773 - max-width: 760px;
1774 - grid-template-columns: 1fr;
1775 - gap: 34px;
1334 +@media (max-width: 767px) {
1335 + .resources-index-page {
1336 + padding: 36px 0 52px;
1776 1776   }
1777 1777  
1778 - #mainContentArea .hero-copy {
1779 - order: 1;
1780 - text-align: center;
1339 + .resources-intro {
1340 + text-align: left;
1341 + margin-bottom: 24px;
1781 1781   }
1782 1782  
1783 - #mainContentArea .hero-image-wrapper {
1784 - order: 2;
1785 - }
1786 -
1787 - #mainContentArea .hero.hero-saas h1 {
1788 - margin-left: auto;
1789 - margin-right: auto;
1790 - text-align: center;
1791 - }
1792 -
1793 - #mainContentArea .hero.hero-saas .lead {
1794 - margin-left: auto;
1795 - margin-right: auto;
1796 - text-align: center;
1797 - }
1798 -
1799 - #mainContentArea .hero.hero-saas .benefits {
1800 - margin-left: auto;
1801 - margin-right: auto;
1802 - }
1803 -
1804 - #mainContentArea .hero.hero-saas .hero-actions,
1805 - #mainContentArea .hero.hero-saas #hero-cta {
1806 - justify-content: center;
1807 - }
1808 -
1809 - #mainContentArea .hero-image {
1810 - max-width: 620px;
1811 - }
1812 -}
1813 -
1814 -@media (max-width: 640px) {
1815 - #mainContentArea .hero.hero-saas {
1816 - padding: 42px 0 28px;
1817 - }
1818 -
1819 - #mainContentArea .hero-layout {
1820 - gap: 28px;
1821 - }
1822 -
1823 - #mainContentArea .hero.hero-saas h1 {
1824 - font-size: 42px;
1825 - letter-spacing: -1.5px;
1826 - }
1827 -
1828 - #mainContentArea .hero.hero-saas .lead {
1829 - font-size: 17px;
1830 - }
1831 -
1832 - #mainContentArea .hero.hero-saas .benefits {
1344 + .resources-grid {
1833 1833   grid-template-columns: 1fr;
1346 + gap: 18px;
1834 1834   }
1835 1835  
1836 - #mainContentArea .hero-image {
1837 - max-width: 100%;
1349 + .resource-card {
1350 + padding: 20px;
1838 1838   }
1839 -}
1840 1840  
1841 -/* ========== Accessibility / Contrast Improvements ========== */
1842 -
1843 -/* Make the global background softer and less distracting. */
1844 -body {
1845 - background:
1846 - radial-gradient(circle at 12% 8%, rgba(0, 147, 125, 0.035) 0, transparent 26%),
1847 - radial-gradient(circle at 90% 28%, rgba(7, 24, 45, 0.025) 0, transparent 30%),
1848 - linear-gradient(180deg, #fff 0, @brand-bg 42%, #fff 100%) !important;
1849 - background-attachment: scroll;
1850 -}
1851 -
1852 -/* Keep the article area readable while preserving the page background around it. */
1853 -#mainContentArea .resource-layout {
1854 - padding: 28px;
1855 - border: 1px solid fade(@line, 85%);
1856 - border-radius: @radius;
1857 - background: rgba(255, 255, 255, .88);
1858 - box-shadow: @shadow-sm;
1859 -}
1860 -
1861 -/* Ensure all reusable cards have a real surface, not transparent over the gradient. */
1862 -#mainContentArea .widget,
1863 -#mainContentArea .pathway-card,
1864 -#mainContentArea .service-card,
1865 -#mainContentArea .resource-card,
1866 -#mainContentArea .services .service,
1867 -#mainContentArea .product-card,
1868 -#mainContentArea .product-feature,
1869 -#mainContentArea .product-summary-card,
1870 -#mainContentArea .product-info-card {
1871 - background: #fff;
1872 -}
1873 -
1874 -/* Make notes more readable and visually stronger. */
1875 -#mainContentArea .resource-note {
1876 - border: 1px solid fade(@brand, 18%);
1877 - border-left: 4px solid @brand;
1878 - background: #fff;
1879 - box-shadow: 0 10px 28px rgba(15, 23, 42, .045);
1880 -}
1881 -
1882 -/* Keep the sidebar clearly separated from the background. */
1883 -#mainContentArea .resource-sidebar {
1884 - background: #fff;
1885 -}
1886 -
1887 -/* Make CTA panels stand out more clearly. */
1888 -#mainContentArea .resource-cta,
1889 -#mainContentArea .resource-inline-cta {
1890 - background: #fff;
1891 -}
1892 -
1893 -/* Improve table readability on long resource pages. */
1894 -#mainContentArea .resource-content table {
1895 - background: #fff;
1896 -}
1897 -
1898 -#mainContentArea .resource-content table th {
1899 - color: @text;
1900 - background: #F8FAFC;
1901 -}
1902 -
1903 -#mainContentArea .resource-content table td {
1904 - color: @text-soft;
1905 -}
1906 -
1907 -/* Slightly improve paragraph/list contrast in long articles. */
1908 -#mainContentArea .resource-content p,
1909 -#mainContentArea .resource-content li {
1910 - color: @text-soft;
1911 -}
1912 -
1913 -#mainContentArea .resource-content .resource-note p,
1914 -#mainContentArea .resource-content .resource-checklist li,
1915 -#mainContentArea .resource-content .process-list li {
1916 - color: @muted;
1917 -}
1918 -
1919 -@media (max-width: 900px) {
1920 - #mainContentArea .resource-layout {
1921 - padding: 22px;
1353 + .resource-card h2 {
1354 + font-size: 20px;
1922 1922   }
1923 -}
1924 1924  
1925 -@media (max-width: 640px) {
1926 - #mainContentArea .resource-layout {
1927 - padding: 18px;
1928 - border-radius: 14px;
1357 + .resources-next {
1358 + text-align: left;
1929 1929   }
1930 1930  }
1931 -
1932 -
XWiki.StyleSheetExtension[1]
code
... ... @@ -1,8 +1,14 @@
1 1  /* ========== Agnease Public Top Menu ========== */
2 +
3 +/* Desktop alignment */
4 +#menuview .navbar-nav {
5 + float: right !important;
6 +}
7 +
2 2  /* Top-level menu items */
3 3  
4 -#menuview .agnease-menu-item,
5 -#menuview .agnease-menu-link {
10 +.agnease-menu-item,
11 +.agnease-menu-link {
6 6   > a,
7 7   > .dropdown-toggle {
8 8   color: @brand;
... ... @@ -11,7 +11,6 @@
11 11   padding-left: 16px;
12 12   padding-right: 16px;
13 13   text-decoration: none;
14 - background: transparent;
15 15   }
16 16  
17 17   > a:hover,
... ... @@ -22,7 +22,6 @@
22 22   color: @brand-strong;
23 23   text-decoration: none;
24 24   outline: none;
25 - background: transparent;
26 26   }
27 27  
28 28   .caret {
... ... @@ -43,7 +43,7 @@
43 43  
44 44  /* Dropdown panel */
45 45  
46 -#menuview .agnease-dropdown {
50 +.agnease-dropdown {
47 47   min-width: 310px;
48 48   padding: 10px 8px;
49 49   border: 1px solid fade(@brand, 18%);
... ... @@ -62,7 +62,6 @@
62 62   font-weight: 600;
63 63   line-height: 1.3;
64 64   text-decoration: none;
65 - background: transparent;
66 66  
67 67   i {
68 68   width: 20px;
... ... @@ -78,7 +78,6 @@
78 78   color: @brand-strong;
79 79   text-decoration: none;
80 80   outline: none;
81 - background: transparent;
82 82  
83 83   i {
84 84   color: @brand-strong;
... ... @@ -88,7 +88,6 @@
88 88  
89 89   > .active > a {
90 90   color: @brand-strong;
91 - background: transparent;
92 92  
93 93   i {
94 94   color: @brand-strong;
... ... @@ -104,33 +104,23 @@
104 104  /* Mobile */
105 105  
106 106  @media (max-width: 767px) {
107 - #menuview {
108 + .site-nav {
108 108   margin-left: 0;
109 - width: 100%;
110 + justify-content: center;
111 + flex-wrap: wrap;
110 110   }
111 111  
112 - #menuview .navbar-nav {
113 - float: none;
114 - margin: 0;
115 - width: 100%;
116 - text-align: center;
114 + .agnease-menu-item,
115 + .agnease-menu-link {
116 + > a,
117 + > .dropdown-toggle {
118 + font-size: 16px;
119 + padding-top: 9px;
120 + padding-bottom: 9px;
121 + }
117 117   }
118 118  
119 - #menuview .navbar-nav > li {
120 - float: none;
121 - display: inline-block;
122 - }
123 -
124 - #menuview .navbar-nav > li.agnease-menu-item > a,
125 - #menuview .navbar-nav > li.agnease-menu-link > a,
126 - #menuview .navbar-nav > li.agnease-menu-item > .dropdown-toggle,
127 - #menuview .navbar-nav > li.agnease-menu-link > .dropdown-toggle {
128 - font-size: 16px;
129 - padding: 10px 10px;
130 - text-align: center;
131 - }
132 -
133 - #menuview .agnease-dropdown {
124 + .agnease-dropdown {
134 134   min-width: 0;
135 135   width: 100%;
136 136   padding: 4px 8px 8px 18px;
... ... @@ -138,7 +138,6 @@
138 138   border-radius: 0;
139 139   box-shadow: none;
140 140   background: transparent;
141 - text-align: left;
142 142  
143 143   > li > a {
144 144   padding: 8px 10px;
XWiki.XWikiRights[0]
allow
... ... @@ -1,0 +1,1 @@
1 +Allow
groups
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiAllGroup
levels
... ... @@ -1,0 +1,1 @@
1 +view
users
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiGuest