0 Votes

Changes for page Home

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

From version 4.32
edited by Alex Cotiugă
on 2025/11/12 13:47
Change comment: There is no comment for this version
To version 4.29
edited by Alex Cotiugă
on 2025/11/12 13:42
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,153 +1,85 @@
1 1  {{velocity}}
2 2  {{html clean="false"}}
3 -<div class="agnease-landing">
4 - <!-- HERO -->
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">
14 - Upgrades, maintenance, integrations, and custom development — delivered with clarity and low risk.
15 - Agnease keeps XWiki stable, secure, and ready to grow with your business.
16 - </p>
17 - <div class="hero-cta">
18 - <a class="btn btn-primary" href="#contact">Request a proposal</a>
19 - <a class="btn btn-ghost" href="#services">See services</a>
20 - </div>
21 - </div>
22 - <div>
23 - <!-- Optional illustration/metrics area -->
24 - <div class="card">
25 - <h3>At a glance</h3>
26 - <ul>
27 - <li>Low-downtime LTS upgrades</li>
28 - <li>Support plans with clear SLAs</li>
29 - <li>SSO/OIDC, Stripe, REST integrations</li>
30 - <li>Audits, recovery, performance tuning</li>
31 - </ul>
32 - </div>
33 - </div>
34 - </div>
35 - </section>
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>
36 36  
37 - <!-- TRUST BAR -->
38 - <section class="trust">
39 - <div class="container">
40 - <p class="lead">Trusted by teams who rely on XWiki every day</p>
41 - <div class="trust-list">
42 - <div class="trust-item">Client A</div>
43 - <div class="trust-item">Client B</div>
44 - <div class="trust-item">Client C</div>
45 - <div class="trust-item">Client D</div>
46 - <div class="trust-item">Client E</div>
47 - </div>
48 - </div>
49 - </section>
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>
50 50  
51 - <!-- SERVICES -->
52 - <section id="services">
53 - <div class="container">
54 - <h2>Services</h2>
55 - <p class="lead">Everything your XWiki needs — from a single expert partner.</p>
56 - <div class="grid grid-3">
57 - <article class="card">
58 - <h3>Upgrades &amp; Migrations</h3>
59 - <p>Predictable paths to current LTS with rehearsed steps, backups, and rollback plans.</p>
60 - <ul>
61 - <li>Version &amp; extension audit</li>
62 - <li>Pre-prod rehearsal</li>
63 - <li>Change log &amp; rollback plan</li>
64 - </ul>
65 - </article>
66 - <article class="card">
67 - <h3>Maintenance &amp; Support</h3>
68 - <p>Health checks, security patches, bug triage, and fast incident investigation.</p>
69 - <ul>
70 - <li>Monthly health report</li>
71 - <li>Security updates applied</li>
72 - <li>Response-time guarantees</li>
73 - </ul>
74 - </article>
75 - <article class="card">
76 - <h3>Custom Development</h3>
77 - <p>Macros, forms, workflows, and structured data to match how your teams work.</p>
78 - <ul>
79 - <li>Task &amp; review workflows</li>
80 - <li>Automation &amp; notifications</li>
81 - <li>UI/UX improvements</li>
82 - </ul>
83 - </article>
84 - <article class="card">
85 - <h3>Integrations</h3>
86 - <p>Connect XWiki with identity and business tools using maintainable patterns.</p>
87 - <ul>
88 - <li>SSO / OIDC / SAML</li>
89 - <li>Stripe payments</li>
90 - <li>REST / Webhooks</li>
91 - </ul>
92 - </article>
93 - <article class="card">
94 - <h3>Hosting &amp; Deployment</h3>
95 - <p>Cloud-ready setups with backups, observability, and performance tuning.</p>
96 - <ul>
97 - <li>Architecture guidance</li>
98 - <li>Backup &amp; restore drills</li>
99 - <li>Scaling &amp; caching</li>
100 - </ul>
101 - </article>
102 - <article class="card">
103 - <h3>Audits &amp; Recovery</h3>
104 - <p>Stabilize failing instances, recover features, and harden configuration.</p>
105 - <ul>
106 - <li>Root-cause analysis</li>
107 - <li>Configuration hardening</li>
108 - <li>Actionable report</li>
109 - </ul>
110 - </article>
111 - </div>
112 - </div>
113 - </section>
114 -
115 - <!-- PROCESS -->
116 - <section>
117 - <div class="container">
118 - <h2>Process</h2>
119 - <p class="lead">Calm, predictable, and transparent from start to finish.</p>
120 - <div class="steps">
121 - <div class="step">
122 - <h3>1) Assess</h3>
123 - <p>Environment review, requirements, constraints, and risks — no surprises.</p>
124 - </div>
125 - <div class="step">
126 - <h3>2) Plan</h3>
127 - <p>Scope, milestones, downtime windows, and rollback checkpoints agreed upfront.</p>
128 - </div>
129 - <div class="step">
130 - <h3>3) Deliver</h3>
131 - <p>Careful execution, verification, and documentation with a clean handover.</p>
132 - </div>
133 - </div>
134 - </div>
135 - </section>
136 -
137 - <!-- FINAL CTA -->
138 - <section>
139 - <div class="container">
140 - <div class="cta-band">
141 - <div>
142 - <h3>Need a reliable plan for your XWiki?</h3>
143 - <p class="lead" style="margin:0">Upgrades, support, and integrations handled with low risk and clear communication.</p>
144 - </div>
145 - <a class="btn btn-primary" href="#contact">Contact Agnease</a>
146 - </div>
147 - </div>
148 - </section>
149 -</div>
150 -
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>
151 151  {{/html}}
152 152  #*
153 153  = XWiki Multi-Factor Authentication (MFA) Application =
XWiki.StyleSheetExtension[0]
Code
... ... @@ -1,92 +1,113 @@
1 -/* ===== Agnease Landing (scoped) ===== */
2 -.agnease-landing {
1 +/* ============================
2 + Agnease – UI polish pack
3 + (scoped to #contentcontainer)
4 + ============================ */
5 +#contentcontainer{
3 3   --brand:#00937D;
4 4   --brand-strong:#007B6A;
5 5   --text:#2D3A34;
6 6   --muted:#5B6B64;
7 - --bg:#FFFFFF;
8 8   --panel:#F7F9F8;
9 9   --line:#E4ECE9;
10 10   --radius:14px;
11 11   --radius-sm:10px;
12 - --shadow:0 10px 30px rgba(0,0,0,.08);
13 - color:var(--text);
14 - font:16px/1.6 Inter, Segoe UI, Roboto, system-ui, -apple-system, Arial, sans-serif;
14 + --shadow-sm:0 4px 16px rgba(0,0,0,.05);
15 + --shadow:0 10px 32px rgba(0,0,0,.08);
15 15  }
16 16  
17 -.agnease-landing a{color:var(--brand);text-decoration:none}
18 -.agnease-landing a:hover{color:var(--brand-strong);text-decoration:underline}
19 -.agnease-landing h1{font-size:clamp(1.8rem,2.5vw + .8rem,3rem);line-height:1.15;margin:.2rem 0 .5rem}
20 -.agnease-landing h2{font-size:clamp(1.4rem,1.4vw + .8rem,2rem);line-height:1.2;margin:.2rem 0 .4rem}
21 -.agnease-landing h3{font-size:1.1rem;margin:.2rem 0 .25rem}
22 -.agnease-landing .lead{color:var(--muted);max-width:72ch;margin:.35rem 0 .7rem}
18 +/* 1) Typographic rhythm */
19 +#contentcontainer h1{font-size:clamp(1.6rem,2.2vw + .8rem,2.4rem);line-height:1.15;margin:.3rem 0 .4rem}
20 +#contentcontainer h2{font-size:clamp(1.3rem,1.2vw + .8rem,1.8rem);line-height:1.2;margin:.2rem 0 .35rem}
21 +#contentcontainer h3{font-size:1.08rem;margin:.2rem 0 .2rem}
22 +#contentcontainer p{margin:.35rem 0 .9rem;color:var(--text)}
23 +#contentcontainer .lead{color:var(--muted);max-width:72ch}
23 23  
24 -.agnease-landing section{padding:64px 0;border-top:1px solid var(--line)}
25 -.agnease-landing section:first-child{border-top:none}
25 +/* 2) Section spacing + subtle separators */
26 +#contentcontainer section{padding:2.2rem 0;border-top:1px solid var(--line)}
27 +#contentcontainer section:first-child{border-top:none;padding-top:1.6rem}
26 26  
27 -.agnease-landing .container{max-width:1140px;margin:auto;padding:0 20px}
28 -.agnease-landing .grid{display:grid;gap:18px}
29 -.agnease-landing .grid-2{grid-template-columns:1fr}
30 -.agnease-landing .grid-3{grid-template-columns:1fr}
31 -@media (min-width:840px){
32 - .agnease-landing .grid-2{grid-template-columns:1.1fr .9fr}
33 - .agnease-landing .grid-3{grid-template-columns:repeat(3,1fr)}
29 +/* 3) Eyebrow + links */
30 +#contentcontainer .eyebrow{
31 + display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.14em;
32 + text-transform:uppercase;color:var(--brand);margin:0 0 .35rem
34 34  }
34 +#contentcontainer a{color:var(--brand);text-decoration:none}
35 +#contentcontainer a:hover{color:var(--brand-strong);text-decoration:underline}
35 35  
36 -/* Buttons */
37 -.agnease-landing .btn{
38 - display:inline-flex;align-items:center;gap:.55rem;
39 - padding:.85rem 1.1rem;border-radius:12px;border:2px solid transparent;
40 - font-weight:650;letter-spacing:.2px;cursor:pointer;box-shadow:var(--shadow)
37 +/* 4) Grids */
38 +#contentcontainer .pillars,
39 +#contentcontainer .services-grid,
40 +#contentcontainer .cards,
41 +#contentcontainer .process-steps{display:grid;gap:1rem}
42 +#contentcontainer .pillars{grid-template-columns:1fr}
43 +#contentcontainer .services-grid{grid-template-columns:1fr}
44 +@media (min-width:780px){
45 + #contentcontainer .pillars{grid-template-columns:repeat(3,1fr)}
46 + #contentcontainer .services-grid{grid-template-columns:repeat(3,1fr)}
41 41  }
42 -.agnease-landing .btn-primary{background:var(--brand);color:#fff}
43 -.agnease-landing .btn-primary:hover{background:var(--brand-strong)}
44 -.agnease-landing .btn-ghost{background:#fff;color:var(--brand);border-color:var(--brand)}
45 -.agnease-landing .btn-ghost:hover{color:var(--brand-strong);border-color:var(--brand-strong)}
46 46  
47 -/* Hero */
48 -.agnease-landing .hero{
49 - background:
50 - radial-gradient(60rem 24rem at 10% -10%, #E7FFF8 0%, transparent 60%),
51 - radial-gradient(60rem 24rem at 90% -20%, #E8F6F3 0%, transparent 60%);
49 +/* 5) Cards / articles */
50 +#contentcontainer .pillars > article,
51 +#contentcontainer .services-grid > article,
52 +#contentcontainer .card{
53 + background:#fff;border:1px solid var(--line);border-radius:var(--radius);
54 + padding:1rem 1.1rem;box-shadow:var(--shadow-sm);transition:transform .18s ease, box-shadow .18s ease
52 52  }
53 -.agnease-landing .hero .badges{display:flex;flex-wrap:wrap;gap:.5rem}
54 -.agnease-landing .chip{
55 - display:inline-block;background:var(--panel);border:1px solid var(--line);
56 - padding:.35rem .65rem;border-radius:999px;font-size:.82rem;color:var(--text)
56 +#contentcontainer .services-grid > article:hover,
57 +#contentcontainer .pillars > article:hover{
58 + transform:translateY(-2px);box-shadow:var(--shadow)
57 57  }
58 -.agnease-landing .hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
60 +#contentcontainer .services-grid h3,
61 +#contentcontainer .pillars h3{font-weight:700}
62 +#contentcontainer .services-grid p,
63 +#contentcontainer .pillars p{color:var(--muted);margin:0}
59 59  
60 -/* Trust bar */
61 -.agnease-landing .trust{
62 - background:#fff;
65 +/* 6) Lists inside cards */
66 +#contentcontainer .services-grid ul{margin:.6rem 0 0;padding-left:1.15rem;color:var(--muted)}
67 +#contentcontainer .services-grid li{margin:.15rem 0}
68 +#contentcontainer .benefits,
69 +#contentcontainer .highlights{display:flex;flex-wrap:wrap;gap:.55rem 1rem;padding-left:0;list-style:none;color:var(--muted)}
70 +#contentcontainer .highlights li{
71 + background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.55rem .8rem
63 63  }
64 -.agnease-landing .trust-list{
65 - display:grid;gap:14px;grid-template-columns:repeat(2,1fr)
73 +
74 +/* 7) CTA buttons (if used inside this container) */
75 +#contentcontainer .btn{
76 + display:inline-flex;align-items:center;gap:.55rem;
77 + padding:.78rem 1rem;border-radius:12px;font-weight:650;letter-spacing:.2px;
78 + border:2px solid transparent;box-shadow:var(--shadow-sm);cursor:pointer
66 66  }
67 -@media (min-width:720px){ .agnease-landing .trust-list{grid-template-columns:repeat(5,1fr)} }
68 -.agnease-landing .trust-item{
69 - background:var(--panel);border:1px solid var(--line);border-radius:12px;
70 - padding:.7rem;text-align:center;color:var(--muted)
71 -}
80 +#contentcontainer .btn-primary{background:var(--brand);color:#fff}
81 +#contentcontainer .btn-primary:hover{background:var(--brand-strong)}
82 +#contentcontainer .btn-ghost{background:#fff;color:var(--brand);border-color:var(--brand)}
83 +#contentcontainer .btn-ghost:hover{color:var(--brand-strong);border-color:var(--brand-strong)}
84 +#contentcontainer .btn:focus-visible{outline:3px solid var(--brand);outline-offset:2px}
72 72  
73 -/* Services cards */
74 -.agnease-landing .card{
86 +/* 8) Process steps */
87 +#contentcontainer .process-steps{list-style:none;padding:0;grid-template-columns:1fr}
88 +@media (min-width:780px){#contentcontainer .process-steps{grid-template-columns:repeat(3,1fr)}}
89 +#contentcontainer .process-steps > li{
75 75   background:#fff;border:1px solid var(--line);border-radius:var(--radius);
76 - padding:18px;box-shadow:var(--shadow);transition:transform .18s ease, box-shadow .18s ease
91 + padding:1rem 1.1rem;box-shadow:var(--shadow-sm)
77 77  }
78 -.agnease-landing .card:hover{transform:translateY(-2px)}
79 -.agnease-landing .card p{color:var(--muted);margin:0}
80 -.agnease-landing .card ul{margin:.6rem 0 0;padding-left:1.1rem;color:var(--muted)}
81 81  
82 -/* Process steps */
83 -.agnease-landing .steps{display:grid;gap:16px;grid-template-columns:1fr}
84 -@media (min-width:840px){ .agnease-landing .steps{grid-template-columns:repeat(3,1fr)} }
85 -.agnease-landing .step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
94 +/* 9) Details/FAQ */
95 +#contentcontainer details{border:1px solid var(--line);border-radius:var(--radius-sm);padding:.75rem .9rem;background:#fff;margin:.6rem 0}
96 +#contentcontainer details summary{cursor:pointer;font-weight:650}
97 +#contentcontainer details[open]{box-shadow:var(--shadow-sm)}
86 86  
87 -/* CTA band */
88 -.agnease-landing .cta-band{
89 - background:#fff;border:1px solid var(--line);border-radius:var(--radius);
90 - padding:20px;box-shadow:var(--shadow);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px
99 +/* 10) Forms (contact) */
100 +#contentcontainer .contact-form .form-row{display:grid;gap:.4rem;margin-bottom:.9rem}
101 +#contentcontainer .contact-form label{font-weight:600}
102 +#contentcontainer .contact-form input,
103 +#contentcontainer .contact-form textarea{
104 + width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);
105 + color:var(--text);background:#fff;font:inherit
91 91  }
107 +#contentcontainer .contact-form input:focus,
108 +#contentcontainer .contact-form textarea:focus{outline:3px solid var(--brand);outline-offset:2px}
92 92  
110 +/* 11) Small niceties */
111 +#contentcontainer .cta-line{margin-top:.8rem}
112 +#contentcontainer .service-summary{padding-left:1.1rem;color:var(--muted)}
113 +
Content Type
... ... @@ -1,1 +1,1 @@
1 -CSS
1 +LESS