Changes for page Public Web Site
Last modified by Agnease on 2026/07/03 16:14
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Attachments (0 modified, 1 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -2,94 +2,44 @@ 2 2 #macro (displayPublicContent) 3 3 #set ($discard = $xwiki.ssx.use('PublicWebSite.WebHome')) 4 4 {{html clean="false"}} 5 - <section class="hero hero-saas" id="top"> 6 - <div class="container"> 7 - <div class="hero-layout"> 8 - <div class="hero-copy"> 9 - <h1>Professional XWiki consulting <span>and engineering</span></h1> 10 - <p class="lead"> 11 - Agnease helps organizations upgrade, maintain, secure and extend production XWiki platforms with practical engineering support, custom development, integrations and long-term care. 12 - </p> 13 - <ul class="benefits"> 14 - <li>XWiki LTS upgrades</li> 15 - <li>Maintenance and support</li> 16 - <li>Custom XWiki development</li> 17 - <li>Migrations and integrations</li> 18 - </ul> 19 - <div class="hero-actions" id="hero-cta"> 20 - <a class="btn btn-primary" href="https://calendly.com/alex-agnease/30min?back=1&month=2026-06"> 21 - Book a free discussion 22 - </a> 23 - <a class="btn btn-secondary" href="$xwiki.getURL('services.WebHome')">View XWiki services</a> 24 - </div> 25 - </div> 26 - <div class="hero-visual" aria-hidden="true"> 27 - <div class="hero-browser"> 28 - <div class="hero-browser-top"> 29 - <div class="hero-dot"></div> 30 - <div class="hero-dot"></div> 31 - <div class="hero-dot"></div> 32 - <div class="hero-search"></div> 5 + <section class="hero hero-saas" id="top"> 6 + <div class="container"> 7 + <div class="hero-layout"> 8 + <div class="hero-copy"> 9 + <h1>Professional XWiki consulting <span>and engineering</span></h1> 10 + 11 + <p class="lead"> 12 + Agnease helps organizations upgrade, maintain, secure and extend production XWiki platforms with practical engineering support, custom development, integrations and long-term care. 13 + </p> 14 + 15 + <ul class="benefits"> 16 + <li>XWiki LTS upgrades</li> 17 + <li>Maintenance and support</li> 18 + <li>Custom XWiki development</li> 19 + <li>Migrations and integrations</li> 20 + </ul> 21 + 22 + <div class="hero-actions" id="hero-cta"> 23 + <a class="btn btn-primary" href="https://calendly.com/alex-agnease/30min?back=1&month=2026-06"> 24 + Book a free discussion 25 + </a> 26 + <a class="btn btn-secondary" href="$xwiki.getURL('services.WebHome')">View XWiki services</a> 33 33 </div> 34 - <div class="hero-browser-body"> 35 - <div class="hero-sidebar"> 36 - <div class="hero-nav-item"><span class="hero-nav-icon"></span>Home</div> 37 - <div class="hero-nav-item"><span class="hero-nav-icon"></span>Documentation</div> 38 - <div class="hero-nav-item"><span class="hero-nav-icon"></span>Processes</div> 39 - <div class="hero-nav-item"><span class="hero-nav-icon"></span>Policies</div> 40 - <div class="hero-nav-item"><span class="hero-nav-icon"></span>Teams</div> 41 - </div> 42 - <div class="hero-content-panel"> 43 - <div class="hero-panel-title">Production XWiki Platform</div> 44 - <div class="hero-skeleton"></div> 45 - <div class="hero-skeleton"></div> 46 - <div class="hero-skeleton short"></div> 47 - <div class="hero-dashboard-grid"> 48 - <div class="hero-mini-card"> 49 - <h4>Recent work</h4> 50 - <div class="hero-status-row"><span class="hero-status-dot"></span>LTS upgrade plan</div> 51 - <div class="hero-status-row"><span class="hero-status-dot"></span>Extension review</div> 52 - <div class="hero-status-row"><span class="hero-status-dot"></span>Production validation</div> 53 - </div> 54 - <div class="hero-mini-card"> 55 - <h4>Platform care</h4> 56 - <div class="hero-status-row"><span class="hero-status-dot"></span>Permissions</div> 57 - <div class="hero-status-row"><span class="hero-status-dot"></span>Authentication</div> 58 - <div class="hero-status-row"><span class="hero-status-dot"></span>Maintainability</div> 59 - </div> 60 - </div> 61 - </div> 62 - </div> 63 63 </div> 64 - <div class="hero-floating hero-upgrade-card"> 65 - <div class="hero-card-title">Upgrade with confidence</div> 66 - <div class="hero-version-flow"> 67 - <div class="hero-version">XWiki<br/>LTS</div> 68 - <div class="hero-arrow">→</div> 69 - <div class="hero-version">Staging</div> 70 - <div class="hero-arrow">→</div> 71 - <div class="hero-version active">Production</div> 72 - </div> 29 + 30 + <div class="hero-image-wrapper"> 31 + <img 32 + class="hero-image" 33 + src="$xwiki.getDocument('PublicWebSite.WebHome').getAttachmentURL('agnease-xwiki-hero.png')" 34 + alt="Illustration of a professional XWiki platform dashboard with upgrade, security and maintenance elements" 35 + width="1200" 36 + height="900" 37 + loading="eager" 38 + /> 73 73 </div> 74 - <div class="hero-floating hero-security-card"> 75 - <div class="hero-card-title">Security-aware maintenance</div> 76 - <ul> 77 - <li>Permissions review</li> 78 - <li>Authentication support</li> 79 - <li>Audit and traceability</li> 80 - </ul> 81 - </div> 82 - <div class="hero-flow"> 83 - <div class="hero-env">Review</div> 84 - <div class="hero-arrow">→</div> 85 - <div class="hero-env">Plan</div> 86 - <div class="hero-arrow">→</div> 87 - <div class="hero-env">Validate</div> 88 - </div> 89 89 </div> 90 90 </div> 91 - </div> 92 - </section> 42 + </section> 93 93 #* 94 94 <section class="hero hero-centered" aria-labelledby="hero-title"> 95 95 <div class="container hero-inner">
- agnease-xwiki-hero.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Admin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +981.8 KB - Content
- XWiki.StyleSheetExtension[0]
-
- code
-
... ... @@ -12,7 +12,7 @@ 12 12 @shadow: 0 12px 36px rgba(0, 0, 0, .08); 13 13 @maxw: 1140px; 14 14 */ 15 -@brand: #07 182d;15 +@brand: #00937D; 16 16 @brand-strong: #007B6A; 17 17 @brand-soft: #E7FFF8; 18 18 @brand-bg: #F7F9FC; ... ... @@ -164,16 +164,10 @@ 164 164 } 165 165 */ 166 166 .btn-secondary { 167 - color: @ brand;167 + color: @text; 168 168 background: #fff; 169 - border: 1px solid fade(@ brand, 35%);169 + border: 1px solid fade(@text, 35%); 170 170 171 - &:hover, 172 - &:focus { 173 - color: @brand-strong; 174 - border-color: @brand; 175 - background: @brand-bg; 176 - } 177 177 } 178 178 179 179 /* ========== Hero ========== */ ... ... @@ -1641,8 +1641,8 @@ 1641 1641 background-image: none !important; 1642 1642 } */ 1643 1643 1638 +/* ========== Main Page Hero / SaaS Layout ========== */ 1644 1644 1645 -/* ========== Hero ========== */ 1646 1646 #mainContentArea .hero.hero-saas { 1647 1647 min-height: auto; 1648 1648 padding: 60px 0 34px; ... ... @@ -1651,18 +1651,21 @@ 1651 1651 overflow: hidden; 1652 1652 background: transparent; 1653 1653 } 1648 + 1654 1654 #mainContentArea .hero-layout { 1655 1655 max-width: 1120px; 1656 1656 margin: 0 auto; 1657 1657 display: grid; 1658 - grid-template-columns: minmax(0, . 86fr) minmax(0, 1.14fr);1653 + grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); 1659 1659 gap: 56px; 1660 1660 align-items: center; 1661 1661 } 1662 -#mainContentArea .hero-copy, 1663 -#mainContentArea .hero.hero-saas .lead { 1657 + 1658 +#mainContentArea .hero-copy { 1659 + min-width: 0; 1664 1664 text-align: left; 1665 1665 } 1662 + 1666 1666 #mainContentArea .hero.hero-saas h1 { 1667 1667 max-width: 640px; 1668 1668 margin: 0 0 26px; ... ... @@ -1671,16 +1671,20 @@ 1671 1671 line-height: 1; 1672 1672 letter-spacing: -3px; 1673 1673 } 1671 + 1674 1674 #mainContentArea .hero.hero-saas h1 span { 1675 1675 color: @brand; 1676 1676 } 1675 + 1677 1677 #mainContentArea .hero.hero-saas .lead { 1678 1678 max-width: 590px; 1679 1679 margin: 0 0 28px; 1680 1680 color: #334155; 1680 + text-align: left; 1681 1681 font-size: 18px; 1682 1682 line-height: 1.6; 1683 1683 } 1684 + 1684 1684 #mainContentArea .hero.hero-saas .benefits { 1685 1685 max-width: 620px; 1686 1686 margin: 0 0 30px; ... ... @@ -1693,6 +1693,7 @@ 1693 1693 font-size: 15px; 1694 1694 text-align: left; 1695 1695 } 1697 + 1696 1696 #mainContentArea .hero.hero-saas .benefits li { 1697 1697 display: grid; 1698 1698 grid-template-columns: 18px minmax(0, 1fr); ... ... @@ -1701,6 +1701,7 @@ 1701 1701 margin: 0; 1702 1702 line-height: 1.45; 1703 1703 } 1706 + 1704 1704 #mainContentArea .hero.hero-saas .benefits li::before { 1705 1705 content: "✓"; 1706 1706 display: block; ... ... @@ -1711,212 +1711,100 @@ 1711 1711 text-align: left; 1712 1712 margin: 0; 1713 1713 } 1714 -#mainContentArea .hero-actions, 1715 -#mainContentArea #hero-cta { 1717 + 1718 +#mainContentArea .hero.hero-saas .hero-actions, 1719 +#mainContentArea .hero.hero-saas #hero-cta { 1716 1716 display: flex; 1717 1717 flex-wrap: wrap; 1718 1718 justify-content: flex-start; 1719 1719 gap: 12px; 1724 + margin-top: 0; 1720 1720 } 1721 -#mainContentArea .hero-visual { 1722 - position: relative; 1723 - min-height: 540px; 1724 -} 1725 -#mainContentArea .hero-browser, 1726 -#mainContentArea .hero-floating { 1727 - border: 1px solid @line; 1728 - background: fade(#fff, 94%); 1729 - box-shadow: @shadow; 1730 - backdrop-filter: blur(14px); 1731 -} 1732 -#mainContentArea .hero-browser { 1733 - position: absolute; 1734 - top: 8px; 1735 - right: 0; 1736 - width: 100%; 1737 - max-width: 720px; 1738 - overflow: hidden; 1739 - border-radius: 18px; 1740 - background: fade(#fff, 88%); 1741 -} 1742 -#mainContentArea .hero-browser-top { 1743 - height: 58px; 1726 + 1727 +#mainContentArea .hero-image-wrapper { 1728 + min-width: 0; 1744 1744 display: flex; 1730 + justify-content: center; 1745 1745 align-items: center; 1746 - gap: 10px; 1747 - padding: 0 24px; 1748 - border-bottom: 1px solid @line; 1749 - background: fade(#fff, 74%); 1750 1750 } 1751 -#mainContentArea .hero-dot, 1752 -#mainContentArea .hero-status-dot { 1753 - border-radius: 50%; 1733 + 1734 +#mainContentArea .hero-image { 1735 + display: block; 1736 + width: 100%; 1737 + max-width: 620px; 1738 + height: auto; 1739 + border: 0; 1754 1754 } 1755 -#mainContentArea .hero-dot { 1756 - width: 10px; 1757 - height: 10px; 1758 - background: #CBD5E1; 1741 + 1742 +/* ========== Main Page Hero Responsive ========== */ 1743 + 1744 +@media (max-width: 1100px) { 1745 + #mainContentArea .hero-layout { 1746 + max-width: 760px; 1747 + grid-template-columns: 1fr; 1748 + gap: 34px; 1749 + } 1750 + 1751 + #mainContentArea .hero-copy { 1752 + order: 1; 1753 + text-align: center; 1754 + } 1755 + 1756 + #mainContentArea .hero-image-wrapper { 1757 + order: 2; 1758 + } 1759 + 1760 + #mainContentArea .hero.hero-saas h1 { 1761 + margin-left: auto; 1762 + margin-right: auto; 1763 + text-align: center; 1764 + } 1765 + 1766 + #mainContentArea .hero.hero-saas .lead { 1767 + margin-left: auto; 1768 + margin-right: auto; 1769 + text-align: center; 1770 + } 1771 + 1772 + #mainContentArea .hero.hero-saas .benefits { 1773 + margin-left: auto; 1774 + margin-right: auto; 1775 + } 1776 + 1777 + #mainContentArea .hero.hero-saas .hero-actions, 1778 + #mainContentArea .hero.hero-saas #hero-cta { 1779 + justify-content: center; 1780 + } 1781 + 1782 + #mainContentArea .hero-image { 1783 + max-width: 620px; 1784 + } 1759 1759 } 1760 -#mainContentArea .hero-status-dot { 1761 - width: 8px; 1762 - height: 8px; 1763 - background: @brand; 1786 + 1787 +@media (max-width: 640px) { 1788 + #mainContentArea .hero.hero-saas { 1789 + padding: 42px 0 28px; 1790 + } 1791 + 1792 + #mainContentArea .hero-layout { 1793 + gap: 28px; 1794 + } 1795 + 1796 + #mainContentArea .hero.hero-saas h1 { 1797 + font-size: 42px; 1798 + letter-spacing: -1.5px; 1799 + } 1800 + 1801 + #mainContentArea .hero.hero-saas .lead { 1802 + font-size: 17px; 1803 + } 1804 + 1805 + #mainContentArea .hero.hero-saas .benefits { 1806 + grid-template-columns: 1fr; 1807 + } 1808 + 1809 + #mainContentArea .hero-image { 1810 + max-width: 100%; 1811 + } 1764 1764 } 1765 -#mainContentArea .hero-search { 1766 - margin-left: auto; 1767 - width: 170px; 1768 - height: 26px; 1769 - border: 1px solid #E2E8F0; 1770 - border-radius: 20px; 1771 - background: #F1F5F9; 1772 -} 1773 -#mainContentArea .hero-browser-body { 1774 - display: grid; 1775 - grid-template-columns: 150px minmax(0, 1fr); 1776 -} 1777 -#mainContentArea .hero-sidebar { 1778 - padding: 24px 18px; 1779 - border-right: 1px solid @line; 1780 - background: #F8FAFC; 1781 -} 1782 -#mainContentArea .hero-nav-item, 1783 -#mainContentArea .hero-status-row, 1784 -#mainContentArea .hero-version-flow, 1785 -#mainContentArea .hero-flow { 1786 - display: flex; 1787 - align-items: center; 1788 -} 1789 -#mainContentArea .hero-nav-item { 1790 - gap: 9px; 1791 - padding: 10px 8px; 1792 - color: #334155; 1793 - font-size: 13px; 1794 -} 1795 -#mainContentArea .hero-nav-icon { 1796 - width: 20px; 1797 - height: 20px; 1798 - border: 1px solid #CBD5E1; 1799 - border-radius: 5px; 1800 -} 1801 -#mainContentArea .hero-content-panel { 1802 - padding: 26px; 1803 -} 1804 -#mainContentArea .hero-panel-title, 1805 -#mainContentArea .hero-card-title { 1806 - color: @text; 1807 - font-weight: 800; 1808 -} 1809 -#mainContentArea .hero-panel-title { 1810 - margin-bottom: 18px; 1811 - font-size: 20px; 1812 -} 1813 -#mainContentArea .hero-skeleton { 1814 - height: 8px; 1815 - margin-bottom: 10px; 1816 - border-radius: 10px; 1817 - background: #E2E8F0; 1818 -} 1819 -#mainContentArea .hero-skeleton.short { 1820 - width: 64%; 1821 -} 1822 -#mainContentArea .hero-dashboard-grid { 1823 - margin-top: 28px; 1824 - display: grid; 1825 - grid-template-columns: repeat(2, minmax(0, 1fr)); 1826 - gap: 18px; 1827 -} 1828 -#mainContentArea .hero-mini-card { 1829 - padding: 18px; 1830 - border: 1px solid @line; 1831 - border-radius: 14px; 1832 - background: #fff; 1833 -} 1834 -#mainContentArea .hero-mini-card h4 { 1835 - margin: 0 0 14px; 1836 - font-size: 15px; 1837 -} 1838 -#mainContentArea .hero-status-row { 1839 - gap: 10px; 1840 - margin: 11px 0; 1841 - color: #475569; 1842 - font-size: 13px; 1843 -} 1844 -#mainContentArea .hero-floating { 1845 - position: absolute; 1846 - border-radius: 16px; 1847 -} 1848 -#mainContentArea .hero-upgrade-card { 1849 - left: 0; 1850 - bottom: 72px; 1851 - width: 320px; 1852 - padding: 20px; 1853 -} 1854 -#mainContentArea .hero-security-card { 1855 - right: 20px; 1856 - top: 260px; 1857 - width: 260px; 1858 - padding: 22px; 1859 -} 1860 -#mainContentArea .hero-security-card ul { 1861 - margin: 0; 1862 - padding: 0; 1863 - list-style: none; 1864 -} 1865 -#mainContentArea .hero-security-card li { 1866 - margin: 12px 0; 1867 - font-size: 14px; 1868 -} 1869 -#mainContentArea .hero-security-card li::before { 1870 - content: "✓"; 1871 - margin-right: 8px; 1872 - color: @brand; 1873 - font-weight: 900; 1874 -} 1875 -#mainContentArea .hero-card-title { 1876 - margin-bottom: 16px; 1877 -} 1878 -#mainContentArea .hero-version-flow { 1879 - gap: 8px; 1880 -} 1881 -#mainContentArea .hero-version { 1882 - width: 62px; 1883 - height: 54px; 1884 - padding: 0 8px; 1885 - display: grid; 1886 - place-items: center; 1887 - box-sizing: border-box; 1888 - border-radius: 8px; 1889 - background: #F1F5F9; 1890 - color: #334155; 1891 - text-align: center; 1892 - font-size: 13px; 1893 - line-height: 1.25; 1894 -} 1895 -#mainContentArea .hero-version.active { 1896 - width: 84px; 1897 - background: @text; 1898 - color: #fff; 1899 -} 1900 -#mainContentArea .hero-arrow { 1901 - color: #64748B; 1902 -} 1903 -#mainContentArea .hero-flow { 1904 - position: absolute; 1905 - right: 48px; 1906 - bottom: 18px; 1907 - gap: 12px; 1908 -} 1909 -#mainContentArea .hero-env { 1910 - min-width: 130px; 1911 - padding: 16px 20px; 1912 - border: 1px solid @line; 1913 - border-radius: 12px; 1914 - background: #fff; 1915 - color: #475569; 1916 - text-align: center; 1917 - text-transform: uppercase; 1918 - font-size: 12px; 1919 - letter-spacing: 1.3px; 1920 - box-shadow: 0 16px 40px rgba(15, 23, 42, .08); 1921 -} 1922 1922