0 Votes

Changes for page Home

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

From version 4.26
edited by Alex Cotiugă
on 2025/11/12 13:33
Change comment: There is no comment for this version
To version 5.2
edited by Alex Cotiugă
on 2025/11/12 13:58
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,85 +1,101 @@
1 1  {{velocity}}
2 2  {{html clean="false"}}
3 -<section id="overview" aria-labelledby="overview-title">
4 - <h1 id="overview-title">Professional XWiki Services for Secure and Scalable Business Solutions</h1>
5 - <p>
6 - Agnease helps organizations maintain, upgrade, and extend their XWiki environments with clarity and precision.
7 - Focusing on stability, performance, and long-term support we ensure your business knowledge and
8 - collaboration tools remain dependable, secure, and adaptable to growth.
9 - </p>
10 -</section>
3 +<div id="contentcontainer" class="agnease">
4 + <!-- “Hero” equivalent -->
5 + <section class="hero">
6 + <div class="container grid grid-2">
7 + <div>
8 + <div class="badges">
9 + <span class="chip">Professional XWiki Services</span>
10 + <span class="chip">Secure &amp; Scalable</span>
11 + </div>
12 + <h1>Engineering reliability in every XWiki environment</h1>
13 + <p class="lead">Upgrades, maintenance, integrations, and custom development — delivered with clarity and low risk. Agnease keeps XWiki stable, secure, and ready to grow.</p>
14 + <div class="hero-cta">
15 + <a class="btn btn-primary" href="#contact">Request a proposal</a>
16 + <a class="btn btn-ghost" href="#services">View services</a>
17 + </div>
18 + </div>
19 + <div>
20 + <div class="card">
21 + <h3>At a glance</h3>
22 + <ul>
23 + <li>Low-downtime LTS upgrades</li>
24 + <li>Support plans with SLAs</li>
25 + <li>SSO/OIDC, Stripe, REST integrations</li>
26 + <li>Audits, recovery, performance tuning</li>
27 + </ul>
28 + </div>
29 + </div>
30 + </div>
31 + </section>
11 11  
12 -<section id="pillars" aria-labelledby="pillars-title">
13 - <h2 id="pillars-title">What you can expect</h2>
14 - <div class="pillars">
15 - <article>
16 - <h3>Stability</h3>
17 - <p>LTS upgrades, dependency reviews, and rehearsed changes to keep systems available.</p>
18 - </article>
19 - <article>
20 - <h3>Security</h3>
21 - <p>Timely patches, configuration hardening, and access controls aligned with best practices.</p>
22 - </article>
23 - <article>
24 - <h3>Clarity</h3>
25 - <p>Documented plans, transparent estimates, and actionable handovers for your team.</p>
26 - </article>
27 - </div>
28 -</section>
33 + <!-- Services -->
34 + <section id="services">
35 + <div class="container">
36 + <h2>Services</h2>
37 + <p class="lead">Everything your XWiki needs — from a single expert partner.</p>
38 + <div class="grid grid-3">
39 + <article class="card">
40 + <h3>Upgrades &amp; Migrations</h3>
41 + <p>Predictable paths to current LTS with rehearsed steps, backups, and rollback plans.</p>
42 + <ul><li>Version &amp; extension audit</li><li>Pre-prod rehearsal</li><li>Rollback &amp; backup plan</li></ul>
43 + </article>
44 + <article class="card">
45 + <h3>Maintenance &amp; Support</h3>
46 + <p>Health checks, security patches, bug triage, and fast incident investigation.</p>
47 + <ul><li>Monthly health report</li><li>Security updates applied</li><li>Response-time guarantees</li></ul>
48 + </article>
49 + <article class="card">
50 + <h3>Custom Development</h3>
51 + <p>Macros, forms, workflows, and structured data to match how your teams work.</p>
52 + <ul><li>Task &amp; review flows</li><li>Automation &amp; notifications</li><li>UI/UX improvements</li></ul>
53 + </article>
54 + <article class="card">
55 + <h3>Integrations</h3>
56 + <p>Connect XWiki with identity and business tools using maintainable patterns.</p>
57 + <ul><li>SSO / OIDC / SAML</li><li>Stripe payments</li><li>REST / Webhooks</li></ul>
58 + </article>
59 + <article class="card">
60 + <h3>Hosting &amp; Deployment</h3>
61 + <p>Cloud-ready setups with backups, observability, and performance tuning.</p>
62 + <ul><li>Architecture guidance</li><li>Backup &amp; restore drills</li><li>Scaling &amp; caching</li></ul>
63 + </article>
64 + <article class="card">
65 + <h3>Audits &amp; Recovery</h3>
66 + <p>Stabilize failing instances, recover features, and harden configuration.</p>
67 + <ul><li>Root-cause analysis</li><li>Configuration hardening</li><li>Actionable report</li></ul>
68 + </article>
69 + </div>
70 + </div>
71 + </section>
29 29  
30 -<section id="services" aria-labelledby="services-title">
31 - <h2 id="services-title">Services</h2>
32 - <div class="services-grid">
33 - <article>
34 - <h3>Upgrades &amp; Migrations</h3>
35 - <ul>
36 - <li>Path to current LTS</li>
37 - <li>Extension compatibility review</li>
38 - <li>Rollback &amp; backup strategy</li>
39 - </ul>
40 - </article>
41 - <article>
42 - <h3>Maintenance &amp; Support</h3>
43 - <ul>
44 - <li>Health checks &amp; monitoring</li>
45 - <li>Security updates</li>
46 - <li>Incident investigation</li>
47 - </ul>
48 - </article>
49 - <article>
50 - <h3>Custom Development</h3>
51 - <ul>
52 - <li>Macros and applications</li>
53 - <li>Forms &amp; structured data</li>
54 - <li>Automation &amp; notifications</li>
55 - </ul>
56 - </article>
57 - <article>
58 - <h3>Integrations</h3>
59 - <ul>
60 - <li>SSO / OIDC / SAML</li>
61 - <li>Stripe payments</li>
62 - <li>REST / Webhooks</li>
63 - </ul>
64 - </article>
65 - <article>
66 - <h3>Hosting &amp; Deployment</h3>
67 - <ul>
68 - <li>Cloud architecture</li>
69 - <li>Backups &amp; observability</li>
70 - <li>Performance &amp; scaling</li>
71 - </ul>
72 - </article>
73 - <article>
74 - <h3>Audits &amp; Recovery</h3>
75 - <ul>
76 - <li>Root-cause analysis</li>
77 - <li>Configuration hardening</li>
78 - <li>Remediation roadmap</li>
79 - </ul>
80 - </article>
81 - </div>
82 -</section>
73 + <!-- Process -->
74 + <section>
75 + <div class="container">
76 + <h2>Process</h2>
77 + <p class="lead">Calm, predictable, and transparent from start to finish.</p>
78 + <div class="steps">
79 + <div class="step"><h3>1) Assess</h3><p>Review environment, extensions, constraints, and risks.</p></div>
80 + <div class="step"><h3>2) Plan</h3><p>Agree scope, milestones, downtime windows, and rollback checkpoints.</p></div>
81 + <div class="step"><h3>3) Deliver</h3><p>Execute, verify, document, and hand over.</p></div>
82 + </div>
83 + </div>
84 + </section>
85 +
86 + <!-- CTA band -->
87 + <section id="contact">
88 + <div class="container">
89 + <div class="cta-band">
90 + <div>
91 + <h3>Need a reliable plan for your XWiki?</h3>
92 + <p class="lead" style="margin:0">Upgrades, support, and integrations handled with low risk and clear communication.</p>
93 + </div>
94 + <a class="btn btn-primary" href="mailto:hello@agnease.com">Contact Agnease</a>
95 + </div>
96 + </div>
97 + </section>
98 +</div>
83 83  {{/html}}
84 84  #*
85 85  = XWiki Multi-Factor Authentication (MFA) Application =
XWiki.StyleSheetExtension[0]
Code
... ... @@ -1,201 +1,48 @@
1 -/* ============================
2 - Agnease Theme (scoped)
3 - ============================ */
4 -#contentcontainer {
5 - --brand: #00937D; /* Primary UI color (accessible vs white) */
6 - --brand-strong: #007B6A; /* Hover/active */
7 - --text: #2D3A34; /* Body text */
8 - --muted: #5B6B64; /* Secondary text */
9 - --panel: #F7F9F8; /* Light panels / chips */
10 - --line: #E4ECE9; /* Subtle borders */
11 - --success: #4CAF50;
12 - --warning: #F9A825;
13 - --danger: #E53935;
14 - --info: #0277BD;
15 - --radius: 14px;
16 - --radius-sm: 10px;
17 - --shadow: 0 8px 24px rgba(0,0,0,.06);
1 +/* Page: XWiki.AgneaseTheme (SSX) */
2 +#contentcontainer.agnease {
3 + --brand:#00937D; --brand-strong:#007B6A;
4 + --text:#2D3A34; --muted:#5B6B64;
5 + --panel:#F7F9F8; --line:#E4ECE9;
6 + --radius:14px; --radius-sm:10px;
7 + --shadow:0 10px 30px rgba(0,0,0,.08);
8 + color:var(--text); font:16px/1.6 Inter, Segoe UI, Roboto, system-ui, -apple-system, Arial, sans-serif;
18 18  }
19 19  
20 -/* Base text & links */
21 -#contentcontainer {
22 - color: var(--text);
23 -}
24 -#contentcontainer a {
25 - color: var(--brand);
26 - text-decoration: none;
27 -}
28 -#contentcontainer a:hover {
29 - color: var(--brand-strong);
30 - text-decoration: underline;
31 -}
11 +/* Headings & links */
12 +#contentcontainer.agnease h1{font-size:clamp(1.8rem,2.5vw + .8rem,3rem);line-height:1.15;margin:.2rem 0 .5rem}
13 +#contentcontainer.agnease h2{font-size:clamp(1.4rem,1.4vw + .8rem,2rem);line-height:1.2;margin:.2rem 0 .4rem}
14 +#contentcontainer.agnease h3{font-size:1.1rem;margin:.2rem 0 .3rem}
15 +#contentcontainer.agnease .lead{color:var(--muted);max-width:72ch;margin:.35rem 0 .7rem}
16 +#contentcontainer.agnease a{color:var(--brand)}
17 +#contentcontainer.agnease a:hover{color:var(--brand-strong);text-decoration:underline}
32 32  
33 -/* Headings & helpers */
34 -#contentcontainer .eyebrow {
35 - display: inline-block;
36 - font-size: 0.8rem;
37 - font-weight: 700;
38 - text-transform: uppercase;
39 - letter-spacing: 0.14em;
40 - color: var(--brand);
41 - margin: 0 0 .4rem;
19 +/* Sections & grid */
20 +#contentcontainer.agnease section{padding:64px 0;border-top:1px solid var(--line)}
21 +#contentcontainer.agnease section:first-child{border-top:none}
22 +#contentcontainer.agnease .container{max-width:1140px;margin:auto;padding:0 20px}
23 +#contentcontainer.agnease .grid{display:grid;gap:18px}
24 +#contentcontainer.agnease .grid-2{grid-template-columns:1fr}
25 +#contentcontainer.agnease .grid-3{grid-template-columns:1fr}
26 +@media (min-width:840px){
27 + #contentcontainer.agnease .grid-2{grid-template-columns:1.1fr .9fr}
28 + #contentcontainer.agnease .grid-3{grid-template-columns:repeat(3,1fr)}
42 42  }
43 -#contentcontainer h1,
44 -#contentcontainer h2,
45 -#contentcontainer h3 {
46 - margin: .25rem 0 .5rem;
47 - line-height: 1.2;
48 -}
49 -#contentcontainer .lead {
50 - color: var(--muted);
51 - max-width: 72ch;
52 -}
53 53  
54 -/* Layout utilities */
55 -#contentcontainer section {
56 - padding: 2.5rem 0;
57 - border-top: 1px solid var(--line);
58 -}
59 -#contentcontainer .cards,
60 -#contentcontainer .pillars,
61 -#contentcontainer .services-grid,
62 -#contentcontainer .process-steps,
63 -#contentcontainer .highlights {
64 - display: grid;
65 - gap: 1rem;
66 -}
67 -#contentcontainer .cards-3,
68 -#contentcontainer .services-grid { grid-template-columns: 1fr; }
69 -#contentcontainer .pillars { grid-template-columns: 1fr; }
70 -#contentcontainer .process-steps { counter-reset: step; list-style: none; padding: 0; }
31 +/* Components (chips, cards, steps, CTA band) */
32 +#contentcontainer.agnease .chip{display:inline-block;background:var(--panel);border:1px solid var(--line);padding:.35rem .65rem;border-radius:999px;font-size:.82rem;color:var(--text)}
33 +#contentcontainer.agnease .card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:transform .18s ease, box-shadow .18s ease}
34 +#contentcontainer.agnease .card:hover{transform:translateY(-2px)}
35 +#contentcontainer.agnease .card p{color:var(--muted);margin:0}
36 +#contentcontainer.agnease .card ul{margin:.6rem 0 0;padding-left:1.1rem;color:var(--muted)}
37 +#contentcontainer.agnease .steps{display:grid;gap:16px;grid-template-columns:1fr}
38 +@media (min-width:840px){ #contentcontainer.agnease .steps{grid-template-columns:repeat(3,1fr)} }
39 +#contentcontainer.agnease .step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
40 +#contentcontainer.agnease .cta-band{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}
71 71  
72 -@media (min-width: 740px) {
73 - #contentcontainer .pillars { grid-template-columns: repeat(3, 1fr); }
74 - #contentcontainer .cards-3,
75 - #contentcontainer .services-grid { grid-template-columns: repeat(3, 1fr); }
76 -}
77 -
78 -/* Cards & articles */
79 -#contentcontainer .card,
80 -#contentcontainer .services-grid > article,
81 -#contentcontainer .pillars > article {
82 - background: #fff;
83 - border: 1px solid var(--line);
84 - border-radius: var(--radius);
85 - padding: 1rem 1.1rem;
86 - box-shadow: var(--shadow);
87 -}
88 -#contentcontainer .card h3,
89 -#contentcontainer .services-grid h3,
90 -#contentcontainer .pillars h3 {
91 - margin: .25rem 0 .35rem;
92 - font-size: 1.05rem;
93 -}
94 -#contentcontainer .card p,
95 -#contentcontainer .services-grid p,
96 -#contentcontainer .pillars p {
97 - margin: 0;
98 - color: var(--muted);
99 -}
100 -#contentcontainer .card ul,
101 -#contentcontainer .services-grid ul {
102 - margin: .6rem 0 0;
103 - padding-left: 1.1rem;
104 - color: var(--muted);
105 -}
106 -
107 -/* Process steps */
108 -#contentcontainer .process-steps > li {
109 - background: #fff;
110 - border: 1px solid var(--line);
111 - border-radius: var(--radius);
112 - padding: 1rem 1.1rem;
113 - box-shadow: var(--shadow);
114 -}
115 -#contentcontainer .process-steps > li h3 {
116 - margin: 0 0 .25rem;
117 -}
118 -
119 -/* Highlights list */
120 -#contentcontainer .highlights {
121 - grid-template-columns: 1fr;
122 -}
123 -@media (min-width: 740px) {
124 - #contentcontainer .highlights {
125 - grid-template-columns: repeat(2, 1fr);
126 - }
127 -}
128 -#contentcontainer .highlights li {
129 - background: var(--panel);
130 - border: 1px solid var(--line);
131 - border-radius: var(--radius-sm);
132 - padding: .7rem .9rem;
133 -}
134 -
135 135  /* Buttons */
136 -#contentcontainer .btn {
137 - display: inline-flex;
138 - align-items: center;
139 - gap: .55rem;
140 - padding: .78rem 1rem;
141 - border-radius: 12px;
142 - font-weight: 650;
143 - letter-spacing: .2px;
144 - cursor: pointer;
145 - border: 2px solid transparent;
146 - box-shadow: var(--shadow);
147 -}
148 -#contentcontainer .btn-primary {
149 - background: var(--brand);
150 - color: #fff;
151 -}
152 -#contentcontainer .btn-primary:hover {
153 - background: var(--brand-strong);
154 -}
155 -#contentcontainer .btn-ghost {
156 - background: #fff;
157 - color: var(--brand);
158 - border-color: var(--brand);
159 -}
160 -#contentcontainer .btn-ghost:hover {
161 - color: var(--brand-strong);
162 - border-color: var(--brand-strong);
163 -}
43 +#contentcontainer.agnease .btn{display:inline-flex;align-items:center;gap:.55rem;padding:.85rem 1.1rem;border-radius:12px;border:2px solid transparent;font-weight:650;letter-spacing:.2px;cursor:pointer;box-shadow:var(--shadow)}
44 +#contentcontainer.agnease .btn-primary{background:var(--brand);color:#fff}
45 +#contentcontainer.agnease .btn-primary:hover{background:var(--brand-strong)}
46 +#contentcontainer.agnease .btn-ghost{background:#fff;color:var(--brand);border-color:var(--brand)}
47 +#contentcontainer.agnease .btn-ghost:hover{color:var(--brand-strong);border-color:var(--brand-strong)}
164 164  
165 -/* Forms */
166 -#contentcontainer .contact-form .form-row {
167 - display: grid;
168 - gap: .4rem;
169 - margin-bottom: .9rem;
170 -}
171 -#contentcontainer .contact-form label {
172 - font-weight: 600;
173 -}
174 -#contentcontainer .contact-form input,
175 -#contentcontainer .contact-form textarea {
176 - width: 100%;
177 - padding: .75rem .9rem;
178 - border: 1px solid var(--line);
179 - border-radius: var(--radius-sm);
180 - color: var(--text);
181 - background: #fff;
182 - font: inherit;
183 -}
184 -#contentcontainer .contact-form input:focus,
185 -#contentcontainer .contact-form textarea:focus,
186 -#contentcontainer a:focus {
187 - outline: 3px solid var(--brand);
188 - outline-offset: 2px;
189 -}
190 -
191 -/* Small helpers */
192 -#contentcontainer .benefits {
193 - display: flex;
194 - flex-wrap: wrap;
195 - gap: .6rem 1rem;
196 - padding-left: 0;
197 - list-style: none;
198 - color: var(--muted);
199 -}
200 -#contentcontainer .cta-line { margin-top: .8rem; }
201 -
Content Type
... ... @@ -1,0 +1,1 @@
1 +CSS