0 Votes

Changes for page Home

Last modified by Alex Cotiugă on 2026/01/13 13:12

From version 7.52
edited by Alex Cotiugă
on 2025/11/13 12:37
Change comment: There is no comment for this version
To version 7.38
edited by Alex Cotiugă
on 2025/11/13 11:58
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -22,7 +22,7 @@
22 22   </div>
23 23   </section>
24 24   <!-- ========= WHY CHOOSE AGNEASE (widgets) ========= -->
25 - #set ($whySectionData = [{
25 + #set ($whyArray = [{
26 26   'title': 'Stability & security',
27 27   'icon': 'shield',
28 28   'content': 'Proven upgrade steps, rollback safety, and proactive hardening keep your wiki reliable.'
... ... @@ -44,7 +44,7 @@
44 44   <h2 id="why-title">Why choose Agnease</h2>
45 45   <p class="lead">10+ years of XWiki expertise with structured delivery and lasting collaboration</p>
46 46   <div class="widgets" role="list">
47 - #foreach ($entry in $whySectionData)
47 + #foreach ($entry in $whyArray)
48 48   <article class="widget" role="listitem">
49 49   <div class="icon" aria-hidden="true">
50 50   <i class="fa fa-$entry.icon"></i>
... ... @@ -57,90 +57,83 @@
57 57   </div>
58 58   </section>
59 59   <!-- ================= SERVICES ================= -->
60 - #set ($servicesSectionData = [{
61 - 'title': 'Upgrades',
62 - 'icon': 'refresh',
63 - 'content': 'Stay current with the latest XWiki LTS and keep your instance secure and stable.',
64 - 'items': [
65 - 'Audit setup, extensions, and configurations',
66 - 'Test upgrades with backups and validation',
67 - 'Safe production rollout with minimal downtime'
68 - ]
69 - }])
70 70   <section class="services" aria-labelledby="services-title">
71 71   <div class="container">
72 72   <h2 id="services-title">Services</h2>
73 - <p class="services-sub">All the XWiki services you need, delivered with precision and care</p>
63 + <p class="services-sub">
64 + All the XWiki services you need, delivered with precision and care
65 + </p>
66 +
74 74   <div class="services-grid">
75 - <!-- Row 1 -->
76 - #foreach ($entry in $servicesSectionData.entrySet())
77 - <article class="service">
78 - <i class="fa fa-$entry.icon" aria-hidden="true"></i>
79 - <div class="body">
80 - <h4>$entry.title</h4>
81 - <p>$entry.content</p>
82 - <ul>
83 - #foreach ($item in $entry.items)
84 - <li>$item</li>
85 - #end
86 - </ul>
87 - </div>
88 - </article>
89 - #end
68 + <!-- 1. Migrations -->
69 + <article class="service service--center">
70 + <i class="fa fa-exchange" aria-hidden="true"></i>
71 + <div class="body">
72 + <h3>Migrations</h3>
73 + <p>Move from Confluence, SharePoint, or MediaWiki to XWiki with full data integrity and structure.</p>
74 + <ul>
75 + <li>Preserve page hierarchy, attachments, and permissions</li>
76 + <li>Convert macros, categories, and metadata for XWiki</li>
77 + <li>Redirect old URLs and maintain SEO consistency</li>
78 + </ul>
79 + </div>
80 + </article>
90 90  
82 + <!-- 2. Upgrades -->
91 91   <article class="service">
84 + <i class="fa fa-refresh" aria-hidden="true"></i>
85 + <div class="body">
86 + <h3>Upgrades</h3>
87 + <p>Stay current with the latest XWiki LTS and keep your instance secure and stable.</p>
88 + <ul>
89 + <li>Audit existing setup, extensions, and configurations</li>
90 + <li>Perform test upgrades with backups and validation</li>
91 + <li>Deploy safely to production with minimal downtime</li>
92 + </ul>
93 + </div>
94 + </article>
95 +
96 + <!-- 3. Maintenance, Support & Recovery -->
97 + <article class="service">
92 92   <i class="fa fa-stethoscope" aria-hidden="true"></i>
93 93   <div class="body">
94 - <h3>Maintenance, Support &amp; Recovery</h3>
100 + <h3>Maintenance, Support & Recovery</h3>
95 95   <p>Ensure long-term stability and quick response when issues appear.</p>
96 96   <ul>
97 - <li>Monitoring and performance checks</li>
98 - <li>Security patching, log analysis, triage</li>
99 - <li>Issue recovery, data repair, hardening</li>
103 + <li>Continuous monitoring and performance checks</li>
104 + <li>Security patching, log analysis, and triage</li>
105 + <li>Issue recovery, data repair, and hardening</li>
100 100   </ul>
101 101   </div>
102 102   </article>
103 103  
104 - <!-- Row 2 -->
110 + <!-- 4. Development & Integrations -->
105 105   <article class="service">
106 106   <i class="fa fa-cogs" aria-hidden="true"></i>
107 107   <div class="body">
108 - <h3>Development &amp; Integrations</h3>
114 + <h3>Development & Integrations</h3>
109 109   <p>Extend and connect XWiki to fit your workflow and systems.</p>
110 110   <ul>
111 - <li>Custom apps, macros, automation</li>
112 - <li>SSO, REST APIs, LDAP, CRM links</li>
113 - <li>Maintainable extensions for long-term use</li>
117 + <li>Build custom apps, macros, and automation</li>
118 + <li>Integrate SSO, REST APIs, LDAP, and CRMs</li>
119 + <li>Develop maintainable extensions for long-term use</li>
114 114   </ul>
115 115   </div>
116 116   </article>
117 117  
124 + <!-- 5. Hosting & Deployment -->
118 118   <article class="service">
119 119   <i class="fa fa-cloud" aria-hidden="true"></i>
120 120   <div class="body">
121 - <h3>Hosting &amp; Deployment</h3>
128 + <h3>Hosting & Deployment</h3>
122 122   <p>Cloud-ready environments designed for reliability and performance.</p>
123 123   <ul>
124 - <li>Containerized deployment and TLS</li>
125 - <li>Backups, restore strategy, observability</li>
126 - <li>Optimization and load tuning</li>
131 + <li>Containerized deployments and environment setup</li>
132 + <li>Backup and restore strategies with observability</li>
133 + <li>Optimization and load-tuning for scaling teams</li>
127 127   </ul>
128 128   </div>
129 129   </article>
130 -
131 - <!-- Row 3 (single, centered) -->
132 - <article class="service service--center">
133 - <i class="fa fa-exchange" aria-hidden="true"></i>
134 - <div class="body">
135 - <h3>Migrations</h3>
136 - <p>Move from Confluence, SharePoint, or MediaWiki to XWiki with full data integrity and structure.</p>
137 - <ul>
138 - <li>Preserve hierarchy, attachments, and permissions</li>
139 - <li>Convert macros, categories, and metadata for XWiki</li>
140 - <li>Redirect old URLs and maintain SEO consistency</li>
141 - </ul>
142 - </div>
143 - </article>
144 144   </div>
145 145   </div>
146 146   </section>
XWiki.StyleSheetExtension[0]
Code
... ... @@ -22,7 +22,7 @@
22 22   h2 { font-size: clamp(1.4rem, 1.4vw + .8rem, 2rem); line-height: 1.2; margin: .2rem 0 .4rem; }
23 23   h3 { font-size: 1.12rem; margin: .2rem 0 .25rem; }*/
24 24   .lead { color: @muted; max-width: 72ch; }
25 - .container { max-width: @maxw; margin-top: 5px; padding: 0; overflow-x: clip;}
25 + .container { max-width: @maxw; margin-top: 5px; padding: 0;}
26 26  
27 27   /* Global sections */
28 28   section { padding: 32px 0; border-top: 1px solid @line; }
... ... @@ -179,113 +179,49 @@
179 179   }
180 180  
181 181   /* SERVICES */
182 - .services {
183 - h2 {
184 - margin: 0 0 .3rem;
185 - /* rely on global heading sizing */
186 - }
182 + /* Section header */
183 + /*.services { padding: 2.5rem 0; }
184 + .services h2 { margin:0 0 .3rem; font-size:1.75rem; font-weight:800; }
185 + .services-sub { margin:0 0 1.25rem; color:#5b6a72; }
186 +*/
187 + /* Two-column grid */
188 + .services-grid {
189 + display:grid;
190 + grid-template-columns: repeat(2, 1fr);
191 + gap: 24px 32px;
192 + }
187 187  
188 - .services-sub {
189 - margin: 0 0 1.75rem;
190 - color: @muted;
191 - }
194 + /* Service item = media block with icon badge */
195 + .service {
196 + display:grid;
197 + grid-template-columns: 44px 1fr;
198 + gap: 14px;
199 + padding: 18px 0;
200 + border-top: 1px solid rgba(0,0,0,0.08);
201 + }
202 + .service:nth-child(-n+2) { border-top: none; } /* remove top line for first row */
192 192  
193 - /* Grid: two columns, last item spans both */
194 - .services-grid {
195 - display: grid;
196 - grid-template-columns: repeat(2, minmax(0, 1fr));
197 - column-gap: 36px;
198 - row-gap: 32px;
199 - }
204 + .service > i {
205 + width:40px; height:40px; border-radius:50%;
206 + display:flex; align-items:center; justify-content:center;
207 + font-size:18px; color:#008e78; background:rgba(0,142,120,.09);
208 + margin-top:2px;
209 + }
200 200  
201 - .service {
202 - display: grid;
203 - grid-template-columns: 48px 1fr;
204 - gap: 16px;
205 - padding: 18px 0;
206 - border-top: 1px solid @line;
207 -
208 - /* first row: no top border */
209 - &:nth-of-type(-n + 2) {
210 - border-top: none;
211 - }
212 -
213 - /* icon badge */
214 - > i {
215 - width: 42px;
216 - height: 42px;
217 - border-radius: 50%;
218 - display: flex;
219 - align-items: center;
220 - justify-content: center;
221 - font-size: 18px;
222 - color: @brand;
223 - background: fade(@brand, 10%);
224 - margin-top: 3px;
225 - }
226 -
227 - .body {
228 - h3 {
229 - margin: 0 0 4px;
230 - font-size: 1.125rem;
231 - font-weight: 800;
232 - }
233 -
234 - p {
235 - margin: 0 0 6px;
236 - color: @text;
237 - line-height: 1.5;
238 - }
239 -
240 - ul {
241 - margin: .45rem 0 0;
242 - padding-left: 1.1rem;
243 - color: @muted;
244 - font-size: .95rem;
245 - }
246 -
247 - li {
248 - margin: .25rem 0;
249 - line-height: 1.45;
250 - }
251 - }
252 -
253 - /* last item (Migrations): centered single row */
254 - &.service--center {
255 - grid-column: 1 / -1;
256 - max-width: 680px;
257 - justify-self: center;
258 - border-top: 1px solid @line; // always show a separator above it
259 - }
260 - }
261 -
262 - /* Responsive */
263 - @media (max-width: 760px) {
264 - .services-grid {
265 - grid-template-columns: 1fr;
266 - row-gap: 20px;
267 - }
268 -
269 - .service {
270 - grid-template-columns: 40px 1fr;
271 -
272 - /* on mobile only the first service has no top border */
273 - &:nth-of-type(1) {
274 - border-top: none;
275 - }
276 -
277 - > i {
278 - width: 36px;
279 - height: 36px;
280 - font-size: 16px;
281 - }
282 -
283 - &.service--center {
284 - max-width: 100%;
285 - }
286 - }
287 - }
211 + /* .service .body h3 { margin:0 0 4px; font-size:1.125rem; font-weight:800; }
212 + .service .body p { margin:0 0 6px; color:#25333b; line-height:1.5; }
213 + .service .body ul { margin:.35rem 0 0; padding-left:1.15rem; }
214 + .service .body li { margin:.2rem 0; color:#2d3b43; }
215 +*/
216 + /* Mobile: single column */
217 + @media (max-width: 760px) {
218 + .services-grid { grid-template-columns: 1fr; gap: 10px 0; }
219 + .service { grid-template-columns: 38px 1fr; }
220 + .service > i { width:36px; height:36px; font-size:16px; }
221 + .service:nth-child(-n+2) { border-top: 1px solid rgba(0,0,0,0.08); }
222 + .service:first-child { border-top:none; }
288 288   }
224 +
289 289   /* METRICS */
290 290   .metrics {
291 291   display: grid; gap: 14px; grid-template-columns: repeat(2, 1fr);
... ... @@ -336,6 +336,12 @@
336 336   background-attachment: scroll;
337 337   }
338 338  
275 + /* Fix possible grid or card overshoot */
276 + .container {
277 + max-width: 100%;
278 + overflow-x: clip; /* hides subtle pixel overflow without scroll */
279 + }
280 +
339 339   /* Safety for large paddings/margins that might extend */
340 340   section, .widgets, .services, .metrics, .steps {
341 341   margin-left: auto;