Changes for page Home
Last modified by Alex Cotiugă on 2026/01/13 13:12
From version 9.1
edited by Alex Cotiugă
on 2025/11/24 07:19
on 2025/11/24 07:19
Change comment:
There is no comment for this version
To version 7.140
edited by Alex Cotiugă
on 2025/11/17 09:23
on 2025/11/17 09:23
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (0 modified, 1 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,7 +1,8 @@ 1 1 {{velocity}} 2 -#if ("$!xcontext.userReference" == '') 3 - #set ($discard = $xwiki.ssx.use('Main.WebHome')) 4 - {{html clean="false"}} 2 +#*== Professional XWiki Services for Secure and Scalable Business Solutions == 3 +Agnease helps organizations maintain, upgrade, and extend their XWiki environments with clarity and precision. Focusing on stability, performance, and long-term support we ensure your business knowledge and collaboration tools remain dependable, secure, and adaptable to growth.*# 4 +{{html clean="false"}} 5 +<main class="agnease-landing"> 5 5 ## HERO 6 6 <section class="hero hero-centered" aria-labelledby="hero-title"> 7 7 <div class="container hero-inner"> ... ... @@ -144,6 +144,123 @@ 144 144 </p> 145 145 </div> 146 146 </section> 147 - {{/html}} 148 -#end 148 +#* 149 + <!-- ================= METRICS ================= --> 150 + <section aria-labelledby="metrics-title"> 151 + <div class="container"> 152 + <h2 id="metrics-title">Delivery at a glance</h2> 153 + <div class="metrics" role="list"> 154 + <div class="metric" role="listitem"> 155 + <div class="num">8–12h</div> 156 + <div class="label">Typical LTS upgrade window</div> 157 + </div> 158 + <div class="metric" role="listitem"> 159 + <div class="num"><1h</div> 160 + <div class="label">Average service downtime during upgrades</div> 161 + </div> 162 + <div class="metric" role="listitem"> 163 + <div class="num">24–48h</div> 164 + <div class="label">First response SLA (plans)</div> 165 + </div> 166 + <div class="metric" role="listitem"> 167 + <div class="num">10+ yrs</div> 168 + <div class="label">XWiki expertise</div> 169 + </div> 170 + </div> 171 + <p class="lead" style="margin-top:.6rem">*for rehearsed, staged upgrades on supported environments.</p> 172 + </div> 173 + </section> 174 + 175 + <!-- ================= PROCESS ================= --> 176 + <section aria-labelledby="process-title"> 177 + <div class="container"> 178 + <h2 id="process-title">Process</h2> 179 + <p class="lead">Calm, predictable, and transparent from start to finish.</p> 180 + <div class="steps"> 181 + <div class="step"> 182 + <h3>1) Assess</h3> 183 + <p>Review environment, extensions, constraints, and risks with no surprises.</p> 184 + </div> 185 + <div class="step"> 186 + <h3>2) Plan</h3> 187 + <p>Agree scope, milestones, downtime windows, and rollback checkpoints.</p> 188 + </div> 189 + <div class="step"> 190 + <h3>3) Deliver</h3> 191 + <p>Execute, verify, document, and hand over with actionable notes.</p> 192 + </div> 193 + </div> 194 + </div> 195 + </section> 196 + 197 + <!-- ================= FAQ ================= --> 198 + <section class="faq" aria-labelledby="faq-title"> 199 + <div class="container"> 200 + <h2 id="faq-title">FAQ</h2> 201 + <details> 202 + <summary>How much downtime should we expect for an upgrade?</summary> 203 + <p>Most upgrades complete in a short maintenance window. For mission-critical wikis we rehearse and stage changes to minimize downtime.</p> 204 + </details> 205 + <details> 206 + <summary>Can you help if our wiki is already broken?</summary> 207 + <p>Yes. We start with an audit to stabilize the instance, recover missing features, and harden configuration.</p> 208 + </details> 209 + <details> 210 + <summary>Do you offer support plans?</summary> 211 + <p>Yes, from ad-hoc assistance to ongoing retainers with response-time guarantees and monthly health checks.</p> 212 + </details> 213 + </div> 214 + </section> 215 +*# 216 +#* <!-- ================= CTA ================= --> 217 + <section id="contact" aria-labelledby="contact-title" class="cta-section"> 218 + <div class="container"> 219 + <div class="row"> 220 + <div class="col-sm-12 text-center"> 221 + <h4 id="contact-title">Need a reliable plan for your XWiki?</h4> 222 + <p class="lead"> 223 + Keep your XWiki running smoothly and safely. Get in touch if you need assistance. 224 + </p> 225 + <a class="btn btn-primary" href="mailto:alex@agnease.com"> 226 + Contact Agnease 227 + </a> 228 + </div> 229 + </div> 230 + </div> 231 + </section> 232 + *# 233 +</main> 234 +{{/html}} 235 +#* 236 += XWiki Multi-Factor Authentication (MFA) Application = 237 + 238 +{{display reference="Extension.MFA Application.WebHome"/}} 239 +== Transform Your Business with Our Professional XWiki Solutions == 240 + 241 +* **XWiki Strategy and Optimization** 242 +Get expert advice on optimizing XWiki for your specific business needs. 243 +Receive tailored solutions to improve collaboration and knowledge management. 244 + 245 +* **Custom Development** 246 +We develop specific features based on your needs. 247 +Customize XWiki to match your unique workflows and processes. 248 + 249 +* **Open Source Development** 250 +We add new features, make improvements, and fix bugs on the XWiki platform. 251 +Contribute to the XWiki community by enhancing the platform’s capabilities. 252 + 253 +* **Installation and Upgrade** 254 +We handle installation and upgrades to ensure everything runs smoothly. 255 +Ensure a seamless transition with minimal disruption to your operations. 256 + 257 +* **Migration Services** 258 +Move from Confluence, MediaWiki, SharePoint, and other tools to XWiki with ease. 259 +Preserve your data integrity and structure during the migration process. 260 + 261 +* **Technical Support and Maintenance** 262 +We provide ongoing support and maintenance for your XWiki solution. 263 +Ensure your XWiki instance is always up-to-date and performing optimally. 264 + 265 +Contact us at [[contact@agnease.com>>mailto:contact@agnease.com]] 266 +*# 149 149 {{/velocity}}
- XWiki.StyleSheetExtension[0]
-
- Caching policy
-
... ... @@ -1,0 +1,1 @@ 1 +long - Code
-
... ... @@ -1,0 +1,274 @@ 1 +/* ========== Agnease Landing (no Bootstrap grid) ========== */ 2 +@brand: #00937D; 3 +@brand-strong: #007B6A; 4 +@text: #2D3A34; 5 +@muted: #5B6B64; 6 +@line: #E4ECE9; 7 +@radius: 16px; 8 +@shadow-sm: 0 6px 20px rgba(0,0,0,.06); 9 +@shadow: 0 12px 36px rgba(0,0,0,.08); 10 +@maxw: 1140px; 11 + 12 +.agnease-landing { 13 + color: @text; 14 + 15 + a { 16 + color: @brand; 17 + text-decoration: none; 18 + &:hover { 19 + color: @brand-strong; 20 + text-decoration: underline; 21 + } 22 + } 23 + 24 + img { 25 + max-width: 100%; 26 + height: auto; 27 + display: block; 28 + } 29 + 30 + .container { 31 + max-width: @maxw; 32 + margin: 0 auto; 33 + padding: 0 16px; 34 + } 35 + 36 + .lead { 37 + color: @muted; 38 + text-align: center; 39 + } 40 + 41 + section { 42 + padding: 32px 0; 43 + border-top: 1px solid @line; 44 + 45 + &:first-of-type { 46 + border-top: none; 47 + } 48 + } 49 + 50 + /* Buttons */ 51 + .btn { 52 + display: inline-flex; 53 + align-items: center; 54 + justify-content: center; 55 + padding: .85rem 1.1rem; 56 + border-radius: 12px; 57 + border: 2px solid transparent; 58 + font-weight: 650; 59 + letter-spacing: .2px; 60 + cursor: pointer; 61 + box-shadow: @shadow-sm; 62 + 63 + &:focus-visible { 64 + outline: 3px solid @brand; 65 + outline-offset: 2px; 66 + } 67 + 68 + &-primary { 69 + background: @brand; 70 + color: #fff; 71 + &:hover, 72 + &:focus { 73 + background: @brand-strong; 74 + color: #fff; 75 + } 76 + } 77 + } 78 + 79 + /* ===== HERO ===== */ 80 + .hero { 81 + overflow: hidden; 82 + background-repeat: no-repeat; 83 + background-attachment: scroll; 84 + 85 + &.hero-centered { 86 + text-align: center; 87 + background: 88 + radial-gradient(50rem 18rem at 50% -10%, #E7FFF8 0%, transparent 60%), 89 + radial-gradient(50rem 18rem at 50% 0%, #E8F6F3 0%, transparent 60%); 90 + display: flex; 91 + align-items: center; 92 + justify-content: center; 93 + min-height: 350px; 94 + } 95 + 96 + .hero-inner { 97 + max-width: 850px; 98 + margin: 0 auto; 99 + display: flex; 100 + flex-direction: column; 101 + align-items: center; 102 + gap: 1rem; 103 + } 104 + 105 + .hero-cta { 106 + display: flex; 107 + gap: 0.8rem; 108 + flex-wrap: wrap; 109 + justify-content: center; 110 + margin-top: 0.3rem; 111 + } 112 + 113 + .benefits { 114 + display: flex; 115 + flex-wrap: wrap; 116 + justify-content: center; 117 + list-style: none; 118 + padding: 0; 119 + margin: 0.8rem 0 0; 120 + color: @muted; 121 + font-size: 14px; 122 + 123 + li + li::before { 124 + content: "•"; 125 + margin: 0 5px; 126 + } 127 + 128 + @media (max-width: 640px) { 129 + li + li::before { 130 + content: none; 131 + } 132 + li:nth-child(1)::after, 133 + li:nth-child(3)::after { 134 + content: "•"; 135 + margin: 0 5px; 136 + } 137 + } 138 + } 139 + } 140 + 141 + /* ===== WHY CHOOSE (cards) ===== */ 142 + .widgets { 143 + margin-top: 12px; 144 + display: grid; 145 + grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); 146 + grid-gap: 16px; 147 + } 148 + 149 + .widget { 150 + padding: 18px; 151 + background: #fff; 152 + border: 1px solid @line; 153 + border-radius: @radius; 154 + box-shadow: @shadow-sm; 155 + transition: transform .18s ease, box-shadow .18s ease; 156 + display: flex; 157 + flex-direction: column; 158 + height: 100%; 159 + 160 + &:hover { 161 + transform: translateY(-2px); 162 + box-shadow: @shadow; 163 + } 164 + 165 + .icon { 166 + display: flex; 167 + align-items: center; 168 + gap: 10px; 169 + padding-bottom: 6px; 170 + margin-bottom: 8px; 171 + border-bottom: 1px solid fade(@line, 60%); 172 + i { color: @brand; } 173 + h4 { margin: 0; line-height: 1.2; color: @text; } 174 + } 175 + 176 + p { 177 + margin: 0; 178 + color: @muted; 179 + line-height: 1.45; 180 + } 181 + } 182 + 183 + /* ===== SERVICES ===== */ 184 + .services { 185 + .services-grid { 186 + margin-top: 20px; 187 + display: flex; 188 + flex-wrap: wrap; 189 + gap: 24px; 190 + } 191 + 192 + .service { 193 + /* 2 items per row: 50% minus half the gap so row fits in 100% */ 194 + flex: 0 1 calc(50% - 12px); 195 + display: flex; 196 + align-items: flex-start; 197 + gap: 16px; 198 + margin-bottom: 8px; 199 + 200 + .service-icon { 201 + width: 42px; 202 + height: 42px; 203 + border-radius: 50%; 204 + display: flex; 205 + align-items: center; 206 + justify-content: center; 207 + font-size: 18px; 208 + color: @brand; 209 + background: fade(@brand, 10%); 210 + flex-shrink: 0; 211 + margin-top: 3px; 212 + } 213 + 214 + .service-body { 215 + h4 { 216 + margin: 0 0 4px; 217 + font-size: 1.125rem; 218 + font-weight: 800; 219 + } 220 + 221 + p { 222 + margin: 0 0 6px; 223 + color: @text; 224 + line-height: 1.5; 225 + } 226 + 227 + ul { 228 + margin: .45rem 0 0; 229 + padding-left: 1.1rem; 230 + color: @muted; 231 + font-size: 13px; 232 + } 233 + 234 + li { 235 + margin: .25rem 0; 236 + line-height: 1.45; 237 + } 238 + } 239 + } 240 + 241 + /* Center the last item when odd: 242 + auto margins in a flex row push it to the middle */ 243 + .service-center { 244 + margin-left: auto; 245 + margin-right: auto; 246 + } 247 + 248 + /* Mobile: 1 per row */ 249 + @media (max-width: 767px) { 250 + .services-grid { 251 + gap: 16px; 252 + } 253 + .service { 254 + flex: 0 1 100%; 255 + } 256 + .service-center { 257 + margin-left: 0; 258 + margin-right: 0; 259 + } 260 + } 261 + } 262 + 263 + /* ===== CTA ===== */ 264 + .cta-section { 265 + padding: 24px 0 16px; 266 + 267 + .contact-inline { 268 + margin: 0; 269 + color: @muted; 270 + a { color: @brand; } 271 + } 272 + } 273 +} 274 + - Content Type
-
... ... @@ -1,0 +1,1 @@ 1 +LESS - Use this extension
-
... ... @@ -1,0 +1,1 @@ 1 +currentPage