Changes for page Home
Last modified by Alex Cotiugă on 2026/01/13 13:12
From version 5.2
edited by Alex Cotiugă
on 2025/11/12 13:58
on 2025/11/12 13:58
Change comment:
There is no comment for this version
To version 4.26
edited by Alex Cotiugă
on 2025/11/12 13:33
on 2025/11/12 13:33
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,101 +1,85 @@ 1 1 {{velocity}} 2 2 {{html clean="false"}} 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 & 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> 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> 32 32 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 & Migrations</h3> 41 - <p>Predictable paths to current LTS with rehearsed steps, backups, and rollback plans.</p> 42 - <ul><li>Version & extension audit</li><li>Pre-prod rehearsal</li><li>Rollback & backup plan</li></ul> 43 - </article> 44 - <article class="card"> 45 - <h3>Maintenance & 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 & review flows</li><li>Automation & 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 & Deployment</h3> 61 - <p>Cloud-ready setups with backups, observability, and performance tuning.</p> 62 - <ul><li>Architecture guidance</li><li>Backup & restore drills</li><li>Scaling & caching</li></ul> 63 - </article> 64 - <article class="card"> 65 - <h3>Audits & 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> 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> 72 72 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> 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 & Migrations</h3> 35 + <ul> 36 + <li>Path to current LTS</li> 37 + <li>Extension compatibility review</li> 38 + <li>Rollback & backup strategy</li> 39 + </ul> 40 + </article> 41 + <article> 42 + <h3>Maintenance & Support</h3> 43 + <ul> 44 + <li>Health checks & 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 & structured data</li> 54 + <li>Automation & 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 & Deployment</h3> 67 + <ul> 68 + <li>Cloud architecture</li> 69 + <li>Backups & observability</li> 70 + <li>Performance & scaling</li> 71 + </ul> 72 + </article> 73 + <article> 74 + <h3>Audits & 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> 99 99 {{/html}} 100 100 #* 101 101 = 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