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, 0 added, 1 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -2,44 +2,94 @@ 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 - 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> 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> 27 27 </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> 28 28 </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 - /> 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> 39 39 </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> 40 40 </div> 41 41 </div> 42 - </section> 91 + </div> 92 + </section> 43 43 #* 44 44 <section class="hero hero-centered" aria-labelledby="hero-title"> 45 45 <div class="container hero-inner">
- agnease-xwiki-hero.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Admin - Size
-
... ... @@ -1,1 +1,0 @@ 1 -981.8 KB - Content
- XWiki.StyleSheetExtension[0]
-
- code
-
... ... @@ -168,6 +168,12 @@ 168 168 background: #fff; 169 169 border: 1px solid fade(@text, 35%); 170 170 171 + &:hover, 172 + &:focus { 173 + color: @text; 174 + border-color: @text; 175 + background: #fff; 176 + } 171 171 } 172 172 173 173 /* ========== Hero ========== */ ... ... @@ -1635,8 +1635,8 @@ 1635 1635 background-image: none !important; 1636 1636 } */ 1637 1637 1638 -/* ========== Main Page Hero / SaaS Layout ========== */ 1639 1639 1645 +/* ========== Hero ========== */ 1640 1640 #mainContentArea .hero.hero-saas { 1641 1641 min-height: auto; 1642 1642 padding: 60px 0 34px; ... ... @@ -1645,21 +1645,18 @@ 1645 1645 overflow: hidden; 1646 1646 background: transparent; 1647 1647 } 1648 - 1649 1649 #mainContentArea .hero-layout { 1650 1650 max-width: 1120px; 1651 1651 margin: 0 auto; 1652 1652 display: grid; 1653 - grid-template-columns: minmax(0, . 9fr) minmax(0, 1.1fr);1658 + grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr); 1654 1654 gap: 56px; 1655 1655 align-items: center; 1656 1656 } 1657 - 1658 -#mainContentArea .hero-copy { 1659 - min-width: 0; 1662 +#mainContentArea .hero-copy, 1663 +#mainContentArea .hero.hero-saas .lead { 1660 1660 text-align: left; 1661 1661 } 1662 - 1663 1663 #mainContentArea .hero.hero-saas h1 { 1664 1664 max-width: 640px; 1665 1665 margin: 0 0 26px; ... ... @@ -1668,20 +1668,16 @@ 1668 1668 line-height: 1; 1669 1669 letter-spacing: -3px; 1670 1670 } 1671 - 1672 1672 #mainContentArea .hero.hero-saas h1 span { 1673 1673 color: @brand; 1674 1674 } 1675 - 1676 1676 #mainContentArea .hero.hero-saas .lead { 1677 1677 max-width: 590px; 1678 1678 margin: 0 0 28px; 1679 1679 color: #334155; 1680 - text-align: left; 1681 1681 font-size: 18px; 1682 1682 line-height: 1.6; 1683 1683 } 1684 - 1685 1685 #mainContentArea .hero.hero-saas .benefits { 1686 1686 max-width: 620px; 1687 1687 margin: 0 0 30px; ... ... @@ -1694,7 +1694,6 @@ 1694 1694 font-size: 15px; 1695 1695 text-align: left; 1696 1696 } 1697 - 1698 1698 #mainContentArea .hero.hero-saas .benefits li { 1699 1699 display: grid; 1700 1700 grid-template-columns: 18px minmax(0, 1fr); ... ... @@ -1703,7 +1703,6 @@ 1703 1703 margin: 0; 1704 1704 line-height: 1.45; 1705 1705 } 1706 - 1707 1707 #mainContentArea .hero.hero-saas .benefits li::before { 1708 1708 content: "✓"; 1709 1709 display: block; ... ... @@ -1714,130 +1714,212 @@ 1714 1714 text-align: left; 1715 1715 margin: 0; 1716 1716 } 1717 - 1718 -#mainContentArea .hero.hero-saas .hero-actions, 1719 -#mainContentArea .hero.hero-saas #hero-cta { 1714 +#mainContentArea .hero-actions, 1715 +#mainContentArea #hero-cta { 1720 1720 display: flex; 1721 1721 flex-wrap: wrap; 1722 1722 justify-content: flex-start; 1723 1723 gap: 12px; 1724 - margin-top: 0; 1725 1725 } 1726 - 1727 -#mainContentArea .hero-image-wrapper { 1728 - min-width: 0; 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; 1729 1729 display: flex; 1730 - justify-content: center; 1731 1731 align-items: center; 1746 + gap: 10px; 1747 + padding: 0 24px; 1748 + border-bottom: 1px solid @line; 1749 + background: fade(#fff, 74%); 1732 1732 } 1733 - 1734 -#mainContentArea .hero-image { 1735 - display: block; 1736 - width: 100%; 1737 - max-width: 620px; 1738 - height: auto; 1739 - border: 0; 1751 +#mainContentArea .hero-dot, 1752 +#mainContentArea .hero-status-dot { 1753 + border-radius: 50%; 1740 1740 } 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 - } 1755 +#mainContentArea .hero-dot { 1756 + width: 10px; 1757 + height: 10px; 1758 + background: #CBD5E1; 1785 1785 } 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 - } 1760 +#mainContentArea .hero-status-dot { 1761 + width: 8px; 1762 + height: 8px; 1763 + background: @brand; 1812 1812 } 1813 - 1814 -#mainContentArea .resource-content .resources-grid .resource-card { 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 { 1815 1815 display: grid; 1816 - grid-template-columns: 44px minmax(0, 1fr); 1817 - column-gap: 14px; 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; 1818 1818 align-items: center; 1819 1819 } 1820 - 1821 - #mainContentArea.resource-content.resources-grid .resource-card.service-icon {1822 - grid-column: 1;1823 - grid-row: 1;1824 - margin:0;1789 +#mainContentArea .hero-nav-item { 1790 + gap: 9px; 1791 + padding: 10px 8px; 1792 + color: #334155; 1793 + font-size: 13px; 1825 1825 } 1826 - 1827 -#mainContentArea .resource-content .resources-grid .resource-card .service-body { 1828 - display: contents; 1795 +#mainContentArea .hero-nav-icon { 1796 + width: 20px; 1797 + height: 20px; 1798 + border: 1px solid #CBD5E1; 1799 + border-radius: 5px; 1829 1829 } 1830 - 1831 -#mainContentArea .resource-content .resources-grid .resource-card .service-body h4 { 1832 - grid-column: 2; 1833 - grid-row: 1; 1834 - align-self: center; 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 { 1835 1835 margin: 0; 1862 + padding: 0; 1863 + list-style: none; 1836 1836 } 1837 - 1838 -#mainContentArea .resource-content .resources-grid .resource-card .service-body p { 1839 - grid-column: 1 / -1; 1840 - grid-row: 2; 1841 - margin: 14px 0 0; 1865 +#mainContentArea .hero-security-card li { 1866 + margin: 12px 0; 1867 + font-size: 14px; 1842 1842 } 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 +} 1843 1843