0 Votes

Changes for page Home

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

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

Summary

Details

Page properties
Content
... ... @@ -1,8 +1,85 @@
1 1  {{velocity}}
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 4  {{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>
5 5  
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>
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>
6 6  {{/html}}
7 7  #*
8 8  = XWiki Multi-Factor Authentication (MFA) Application =
XWiki.StyleSheetExtension[0]
Code
... ... @@ -1,48 +1,201 @@
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;
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);
9 9  }
10 10  
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}
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 +}
18 18  
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)}
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;
29 29  }
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 +}
30 30  
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}
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; }
41 41  
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 +
42 42  /* Buttons */
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)}
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 +}
48 48  
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,1 +1,0 @@
1 -CSS