@affinda/wc 0.0.15 → 0.0.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (760) hide show
  1. package/dist/affinda/af-aspect-ratio.entry.esm.js.map +1 -1
  2. package/dist/affinda/af-button.entry.esm.js.map +1 -1
  3. package/dist/affinda/af-card.entry.esm.js.map +1 -1
  4. package/dist/affinda/af-checkbox.entry.esm.js.map +1 -0
  5. package/dist/affinda/af-client-carousel.entry.esm.js.map +1 -1
  6. package/dist/affinda/af-feature-accordion.entry.esm.js.map +1 -1
  7. package/dist/affinda/af-feature-card.entry.esm.js.map +1 -0
  8. package/dist/affinda/af-feature-grid.entry.esm.js.map +1 -0
  9. package/dist/affinda/af-fieldset.entry.esm.js.map +1 -0
  10. package/dist/affinda/af-grid-callout.entry.esm.js.map +1 -0
  11. package/dist/affinda/af-heading.af-logo.af-nav-item.af-navbar.af-text.entry.esm.js.map +1 -1
  12. package/dist/affinda/af-hero-section.entry.esm.js.map +1 -1
  13. package/dist/affinda/af-icon-box.entry.esm.js.map +1 -0
  14. package/dist/affinda/af-icon-button.entry.esm.js.map +1 -1
  15. package/dist/affinda/af-icon-text.entry.esm.js.map +1 -0
  16. package/dist/affinda/af-icon.entry.esm.js.map +1 -0
  17. package/dist/affinda/af-illustrated-card.entry.esm.js.map +1 -0
  18. package/dist/affinda/af-image.entry.esm.js.map +1 -0
  19. package/dist/affinda/af-in-page-banner.entry.esm.js.map +1 -0
  20. package/dist/affinda/af-input.entry.esm.js.map +1 -0
  21. package/dist/affinda/af-logo-well.entry.esm.js.map +1 -1
  22. package/dist/affinda/af-nav-card.entry.esm.js.map +1 -0
  23. package/dist/affinda/af-nav-menu-nest.entry.esm.js.map +1 -0
  24. package/dist/affinda/af-nav-menu.entry.esm.js.map +1 -0
  25. package/dist/affinda/af-number-badge.entry.esm.js.map +1 -0
  26. package/dist/affinda/af-progress-line.entry.esm.js.map +1 -0
  27. package/dist/affinda/af-radio.entry.esm.js.map +1 -0
  28. package/dist/affinda/af-section.entry.esm.js.map +1 -1
  29. package/dist/affinda/af-split-section.entry.esm.js.map +1 -0
  30. package/dist/affinda/af-switch.entry.esm.js.map +1 -0
  31. package/dist/affinda/af-tab-bar.entry.esm.js.map +1 -0
  32. package/dist/affinda/af-tab.entry.esm.js.map +1 -0
  33. package/dist/affinda/af-tag.entry.esm.js.map +1 -0
  34. package/dist/affinda/af-testimonial-carousel.entry.esm.js.map +1 -1
  35. package/dist/affinda/af-testimonial-stat.entry.esm.js.map +1 -1
  36. package/dist/affinda/af-testimonial.entry.esm.js.map +1 -1
  37. package/dist/affinda/af-text-image-nest.entry.esm.js.map +1 -0
  38. package/dist/affinda/af-text-image.entry.esm.js.map +1 -0
  39. package/dist/affinda/af-textarea.entry.esm.js.map +1 -0
  40. package/dist/affinda/af-typography-lockup.entry.esm.js.map +1 -1
  41. package/dist/affinda/af-video-container.entry.esm.js.map +1 -0
  42. package/dist/affinda/affinda.css +1 -1
  43. package/dist/affinda/affinda.esm.js +1 -1
  44. package/dist/affinda/index.esm.js +1 -1
  45. package/dist/affinda/index.esm.js.map +1 -1
  46. package/dist/affinda/p-0cd160a4.entry.js +2 -0
  47. package/dist/affinda/p-0cd160a4.entry.js.map +1 -0
  48. package/dist/affinda/p-10801ee1.entry.js +2 -0
  49. package/dist/affinda/p-10801ee1.entry.js.map +1 -0
  50. package/dist/affinda/p-1d65fd18.entry.js +2 -0
  51. package/dist/affinda/p-1d65fd18.entry.js.map +1 -0
  52. package/dist/affinda/p-1d9e532f.entry.js +2 -0
  53. package/dist/affinda/p-231ba1d0.entry.js +2 -0
  54. package/dist/affinda/p-231ba1d0.entry.js.map +1 -0
  55. package/dist/affinda/p-2b4dc22c.entry.js +2 -0
  56. package/dist/affinda/p-2b4dc22c.entry.js.map +1 -0
  57. package/dist/affinda/{p-fb4e3a8d.entry.js → p-31d4c1a4.entry.js} +2 -2
  58. package/dist/affinda/p-3d3c9f62.entry.js +2 -0
  59. package/dist/affinda/p-3d3c9f62.entry.js.map +1 -0
  60. package/dist/affinda/p-3f691578.entry.js +2 -0
  61. package/dist/affinda/p-3f691578.entry.js.map +1 -0
  62. package/dist/affinda/p-425253ee.entry.js +2 -0
  63. package/dist/affinda/{p-9071c2a7.entry.js.map → p-425253ee.entry.js.map} +1 -1
  64. package/dist/affinda/p-44b25840.entry.js +2 -0
  65. package/dist/affinda/p-44b25840.entry.js.map +1 -0
  66. package/dist/affinda/p-45e1923c.entry.js +2 -0
  67. package/dist/affinda/p-45e1923c.entry.js.map +1 -0
  68. package/dist/affinda/p-52ab3bf0.entry.js +2 -0
  69. package/dist/affinda/p-52ab3bf0.entry.js.map +1 -0
  70. package/dist/affinda/p-53ae16fe.entry.js +2 -0
  71. package/dist/affinda/p-53b5149d.entry.js +2 -0
  72. package/dist/affinda/p-53b5149d.entry.js.map +1 -0
  73. package/dist/affinda/p-57713942.entry.js +2 -0
  74. package/dist/affinda/p-57713942.entry.js.map +1 -0
  75. package/dist/affinda/p-5bbf2c8c.entry.js +2 -0
  76. package/dist/affinda/p-5bbf2c8c.entry.js.map +1 -0
  77. package/dist/affinda/p-697bf0b7.entry.js +2 -0
  78. package/dist/affinda/p-697bf0b7.entry.js.map +1 -0
  79. package/dist/affinda/p-6b2d0ff4.entry.js +2 -0
  80. package/dist/affinda/p-6b2d0ff4.entry.js.map +1 -0
  81. package/dist/affinda/p-71144002.entry.js +2 -0
  82. package/dist/affinda/p-71144002.entry.js.map +1 -0
  83. package/dist/affinda/{p-ec7721cc.entry.js → p-72f02343.entry.js} +2 -2
  84. package/dist/affinda/p-77bf8a81.entry.js +2 -0
  85. package/dist/affinda/p-77bf8a81.entry.js.map +1 -0
  86. package/dist/affinda/p-7f20fbe0.entry.js +2 -0
  87. package/dist/affinda/p-7f20fbe0.entry.js.map +1 -0
  88. package/dist/affinda/p-81571029.entry.js +2 -0
  89. package/dist/affinda/p-81571029.entry.js.map +1 -0
  90. package/dist/affinda/p-85a78bcf.entry.js +2 -0
  91. package/dist/affinda/p-85a78bcf.entry.js.map +1 -0
  92. package/dist/affinda/p-861f4f57.entry.js +2 -0
  93. package/dist/affinda/p-861f4f57.entry.js.map +1 -0
  94. package/dist/affinda/p-864778d0.entry.js +2 -0
  95. package/dist/affinda/p-864778d0.entry.js.map +1 -0
  96. package/dist/affinda/p-8ea22b5d.entry.js +2 -0
  97. package/dist/affinda/p-8ea22b5d.entry.js.map +1 -0
  98. package/dist/affinda/{p-bd30e86a.entry.js → p-96eac3af.entry.js} +2 -2
  99. package/dist/affinda/p-98901734.entry.js +2 -0
  100. package/dist/affinda/p-98901734.entry.js.map +1 -0
  101. package/dist/affinda/p-9f470d8b.entry.js +2 -0
  102. package/dist/affinda/p-9f470d8b.entry.js.map +1 -0
  103. package/dist/affinda/p-BmU_CFQ4.js +3 -0
  104. package/dist/affinda/p-BmU_CFQ4.js.map +1 -0
  105. package/dist/affinda/p-a36abb83.entry.js +2 -0
  106. package/dist/affinda/{p-fc2cb8d1.entry.js.map → p-a36abb83.entry.js.map} +1 -1
  107. package/dist/affinda/p-a4e4eb4d.entry.js +2 -0
  108. package/dist/affinda/{p-d3b2ab0e.entry.js.map → p-a4e4eb4d.entry.js.map} +1 -1
  109. package/dist/affinda/p-a6365e94.entry.js +2 -0
  110. package/dist/affinda/p-a6365e94.entry.js.map +1 -0
  111. package/dist/affinda/p-aaa28806.entry.js +2 -0
  112. package/dist/affinda/p-aaa28806.entry.js.map +1 -0
  113. package/dist/affinda/{p-806d129e.entry.js → p-acbbe39a.entry.js} +2 -2
  114. package/dist/affinda/p-b17735c9.entry.js +2 -0
  115. package/dist/affinda/p-b17735c9.entry.js.map +1 -0
  116. package/dist/affinda/p-b3b0ed0c.entry.js +2 -0
  117. package/dist/affinda/p-b3b0ed0c.entry.js.map +1 -0
  118. package/dist/affinda/p-be049760.entry.js +2 -0
  119. package/dist/affinda/p-be049760.entry.js.map +1 -0
  120. package/dist/affinda/p-c0ee2420.entry.js +2 -0
  121. package/dist/affinda/p-c0ee2420.entry.js.map +1 -0
  122. package/dist/affinda/{p-3a9646e6.entry.js → p-c11088fa.entry.js} +2 -2
  123. package/dist/affinda/p-c298b370.entry.js +2 -0
  124. package/dist/affinda/p-c298b370.entry.js.map +1 -0
  125. package/dist/affinda/p-c3e31251.entry.js +2 -0
  126. package/dist/affinda/p-c3e31251.entry.js.map +1 -0
  127. package/dist/affinda/p-ce3356f1.entry.js +2 -0
  128. package/dist/affinda/p-ce3356f1.entry.js.map +1 -0
  129. package/dist/affinda/p-df148383.entry.js +2 -0
  130. package/dist/affinda/{p-350ac7a5.entry.js.map → p-df148383.entry.js.map} +1 -1
  131. package/dist/affinda/{p-f8ac0120.entry.js → p-e5af21c2.entry.js} +2 -2
  132. package/dist/affinda/p-e5d9913c.entry.js +2 -0
  133. package/dist/affinda/p-e5d9913c.entry.js.map +1 -0
  134. package/dist/affinda/p-ea06c83b.entry.js +2 -0
  135. package/dist/affinda/p-ea06c83b.entry.js.map +1 -0
  136. package/dist/affinda/p-f45b0060.entry.js +2 -0
  137. package/dist/affinda/{p-050f98cd.entry.js.map → p-f45b0060.entry.js.map} +1 -1
  138. package/dist/cjs/af-aspect-ratio.cjs.entry.js +2 -2
  139. package/dist/cjs/af-aspect-ratio.entry.cjs.js.map +1 -1
  140. package/dist/cjs/af-button-group.cjs.entry.js +2 -2
  141. package/dist/cjs/af-button.cjs.entry.js +25 -12
  142. package/dist/cjs/af-button.entry.cjs.js.map +1 -1
  143. package/dist/cjs/af-card.cjs.entry.js +17 -7
  144. package/dist/cjs/af-card.entry.cjs.js.map +1 -1
  145. package/dist/cjs/af-checkbox.cjs.entry.js +58 -0
  146. package/dist/cjs/af-checkbox.entry.cjs.js.map +1 -0
  147. package/dist/cjs/af-client-carousel.cjs.entry.js +5 -7
  148. package/dist/cjs/af-client-carousel.entry.cjs.js.map +1 -1
  149. package/dist/cjs/af-color-swatch.cjs.entry.js +1 -1
  150. package/dist/cjs/af-contact-item.cjs.entry.js +2 -2
  151. package/dist/cjs/af-container.cjs.entry.js +1 -1
  152. package/dist/cjs/af-feature-accordion.cjs.entry.js +4 -4
  153. package/dist/cjs/af-feature-accordion.entry.cjs.js.map +1 -1
  154. package/dist/cjs/af-feature-card.cjs.entry.js +59 -0
  155. package/dist/cjs/af-feature-card.entry.cjs.js.map +1 -0
  156. package/dist/cjs/af-feature-grid.cjs.entry.js +93 -0
  157. package/dist/cjs/af-feature-grid.entry.cjs.js.map +1 -0
  158. package/dist/cjs/af-fieldset.cjs.entry.js +37 -0
  159. package/dist/cjs/af-fieldset.entry.cjs.js.map +1 -0
  160. package/dist/cjs/af-footer-column.cjs.entry.js +2 -2
  161. package/dist/cjs/af-footer-link.cjs.entry.js +2 -2
  162. package/dist/cjs/af-footer.cjs.entry.js +2 -2
  163. package/dist/cjs/af-grid-callout.cjs.entry.js +51 -0
  164. package/dist/cjs/af-grid-callout.entry.cjs.js.map +1 -0
  165. package/dist/cjs/af-heading.af-logo.af-nav-item.af-navbar.af-text.entry.cjs.js.map +1 -1
  166. package/dist/cjs/af-heading_5.cjs.entry.js +67 -27
  167. package/dist/cjs/af-hero-section.cjs.entry.js +11 -5
  168. package/dist/cjs/af-hero-section.entry.cjs.js.map +1 -1
  169. package/dist/cjs/af-icon-box.cjs.entry.js +30 -0
  170. package/dist/cjs/af-icon-box.entry.cjs.js.map +1 -0
  171. package/dist/cjs/af-icon-button.cjs.entry.js +6 -3
  172. package/dist/cjs/af-icon-button.entry.cjs.js.map +1 -1
  173. package/dist/cjs/af-icon-text.cjs.entry.js +36 -0
  174. package/dist/cjs/af-icon-text.entry.cjs.js.map +1 -0
  175. package/dist/cjs/af-icon.cjs.entry.js +352 -0
  176. package/dist/cjs/af-icon.entry.cjs.js.map +1 -0
  177. package/dist/cjs/af-illustrated-card.cjs.entry.js +36 -0
  178. package/dist/cjs/af-illustrated-card.entry.cjs.js.map +1 -0
  179. package/dist/cjs/af-image.cjs.entry.js +18 -0
  180. package/dist/cjs/af-image.entry.cjs.js.map +1 -0
  181. package/dist/cjs/af-in-page-banner.cjs.entry.js +47 -0
  182. package/dist/cjs/af-in-page-banner.entry.cjs.js.map +1 -0
  183. package/dist/cjs/af-input.cjs.entry.js +104 -0
  184. package/dist/cjs/af-input.entry.cjs.js.map +1 -0
  185. package/dist/cjs/af-logo-well.cjs.entry.js +3 -3
  186. package/dist/cjs/af-logo-well.entry.cjs.js.map +1 -1
  187. package/dist/cjs/af-nav-card.cjs.entry.js +37 -0
  188. package/dist/cjs/af-nav-card.entry.cjs.js.map +1 -0
  189. package/dist/cjs/af-nav-menu-nest.cjs.entry.js +43 -0
  190. package/dist/cjs/af-nav-menu-nest.entry.cjs.js.map +1 -0
  191. package/dist/cjs/af-nav-menu.cjs.entry.js +41 -0
  192. package/dist/cjs/af-nav-menu.entry.cjs.js.map +1 -0
  193. package/dist/cjs/af-number-badge.cjs.entry.js +42 -0
  194. package/dist/cjs/af-number-badge.entry.cjs.js.map +1 -0
  195. package/dist/cjs/af-progress-line.cjs.entry.js +33 -0
  196. package/dist/cjs/af-progress-line.entry.cjs.js.map +1 -0
  197. package/dist/cjs/af-radio.cjs.entry.js +43 -0
  198. package/dist/cjs/af-radio.entry.cjs.js.map +1 -0
  199. package/dist/cjs/af-section.cjs.entry.js +6 -6
  200. package/dist/cjs/af-section.entry.cjs.js.map +1 -1
  201. package/dist/cjs/af-social-link.cjs.entry.js +2 -2
  202. package/dist/cjs/af-split-section.cjs.entry.js +41 -0
  203. package/dist/cjs/af-split-section.entry.cjs.js.map +1 -0
  204. package/dist/cjs/af-switch.cjs.entry.js +48 -0
  205. package/dist/cjs/af-switch.entry.cjs.js.map +1 -0
  206. package/dist/cjs/af-tab-bar.cjs.entry.js +88 -0
  207. package/dist/cjs/af-tab-bar.entry.cjs.js.map +1 -0
  208. package/dist/cjs/af-tab.cjs.entry.js +64 -0
  209. package/dist/cjs/af-tab.entry.cjs.js.map +1 -0
  210. package/dist/cjs/af-tag.cjs.entry.js +37 -0
  211. package/dist/cjs/af-tag.entry.cjs.js.map +1 -0
  212. package/dist/cjs/af-testimonial-carousel.cjs.entry.js +27 -15
  213. package/dist/cjs/af-testimonial-carousel.entry.cjs.js.map +1 -1
  214. package/dist/cjs/af-testimonial-stat.cjs.entry.js +3 -3
  215. package/dist/cjs/af-testimonial-stat.entry.cjs.js.map +1 -1
  216. package/dist/cjs/af-testimonial.cjs.entry.js +27 -3
  217. package/dist/cjs/af-testimonial.entry.cjs.js.map +1 -1
  218. package/dist/cjs/af-text-image-nest.cjs.entry.js +30 -0
  219. package/dist/cjs/af-text-image-nest.entry.cjs.js.map +1 -0
  220. package/dist/cjs/af-text-image.cjs.entry.js +63 -0
  221. package/dist/cjs/af-text-image.entry.cjs.js.map +1 -0
  222. package/dist/cjs/af-textarea.cjs.entry.js +93 -0
  223. package/dist/cjs/af-textarea.entry.cjs.js.map +1 -0
  224. package/dist/cjs/af-typography-lockup.cjs.entry.js +7 -7
  225. package/dist/cjs/af-typography-lockup.entry.cjs.js.map +1 -1
  226. package/dist/cjs/af-video-container.cjs.entry.js +35 -0
  227. package/dist/cjs/af-video-container.entry.cjs.js.map +1 -0
  228. package/dist/cjs/affinda.cjs.js +2 -2
  229. package/dist/cjs/{index-DfEVhbS6.js → index-ybEiHT0b.js} +130 -6
  230. package/dist/cjs/index-ybEiHT0b.js.map +1 -0
  231. package/dist/cjs/index.cjs.js +23 -1
  232. package/dist/cjs/index.cjs.js.map +1 -1
  233. package/dist/cjs/loader.cjs.js +2 -2
  234. package/dist/collection/assets/backgrounds/wave-overlay-inkwell.svg +3 -0
  235. package/dist/collection/assets/backgrounds/wave-overlay-mist-green.svg +3 -0
  236. package/dist/collection/assets/backgrounds/wave-overlay-soft-clay.svg +3 -0
  237. package/dist/collection/assets/backgrounds/wave-overlay-white-ivory.svg +3 -0
  238. package/dist/collection/collection-manifest.json +28 -2
  239. package/dist/collection/components/af-aspect-ratio/af-aspect-ratio.css +2 -0
  240. package/dist/collection/components/af-button/af-button.css +177 -64
  241. package/dist/collection/components/af-button/af-button.js +50 -42
  242. package/dist/collection/components/af-button/af-button.js.map +1 -1
  243. package/dist/collection/components/af-button-group/af-button-group.js +1 -1
  244. package/dist/collection/components/af-card/af-card.css +96 -65
  245. package/dist/collection/components/af-card/af-card.js +32 -33
  246. package/dist/collection/components/af-card/af-card.js.map +1 -1
  247. package/dist/collection/components/af-checkbox/af-checkbox.css +96 -0
  248. package/dist/collection/components/af-checkbox/af-checkbox.js +186 -0
  249. package/dist/collection/components/af-checkbox/af-checkbox.js.map +1 -0
  250. package/dist/collection/components/af-client-carousel/af-client-carousel.css +77 -32
  251. package/dist/collection/components/af-client-carousel/af-client-carousel.js +21 -33
  252. package/dist/collection/components/af-client-carousel/af-client-carousel.js.map +1 -1
  253. package/dist/collection/components/af-contact-item/af-contact-item.js +1 -1
  254. package/dist/collection/components/af-feature-accordion/af-feature-accordion.css +21 -35
  255. package/dist/collection/components/af-feature-accordion/af-feature-accordion.js +15 -5
  256. package/dist/collection/components/af-feature-accordion/af-feature-accordion.js.map +1 -1
  257. package/dist/collection/components/af-feature-card/af-feature-card.css +219 -0
  258. package/dist/collection/components/af-feature-card/af-feature-card.js +199 -0
  259. package/dist/collection/components/af-feature-card/af-feature-card.js.map +1 -0
  260. package/dist/collection/components/af-feature-grid/af-feature-grid.css +119 -0
  261. package/dist/collection/components/af-feature-grid/af-feature-grid.js +156 -0
  262. package/dist/collection/components/af-feature-grid/af-feature-grid.js.map +1 -0
  263. package/dist/collection/components/af-fieldset/af-fieldset.css +61 -0
  264. package/dist/collection/components/af-fieldset/af-fieldset.js +109 -0
  265. package/dist/collection/components/af-fieldset/af-fieldset.js.map +1 -0
  266. package/dist/collection/components/af-footer/af-footer.js +1 -1
  267. package/dist/collection/components/af-footer-column/af-footer-column.js +1 -1
  268. package/dist/collection/components/af-footer-link/af-footer-link.js +1 -1
  269. package/dist/collection/components/af-grid-callout/af-grid-callout.css +191 -0
  270. package/dist/collection/components/af-grid-callout/af-grid-callout.js +191 -0
  271. package/dist/collection/components/af-grid-callout/af-grid-callout.js.map +1 -0
  272. package/dist/collection/components/af-heading/af-heading.css +25 -33
  273. package/dist/collection/components/af-heading/af-heading.js +8 -26
  274. package/dist/collection/components/af-heading/af-heading.js.map +1 -1
  275. package/dist/collection/components/af-hero-section/af-hero-section.css +118 -12
  276. package/dist/collection/components/af-hero-section/af-hero-section.js +102 -10
  277. package/dist/collection/components/af-hero-section/af-hero-section.js.map +1 -1
  278. package/dist/collection/components/af-icon/af-icon.css +28 -0
  279. package/dist/collection/components/af-icon/af-icon.js +116 -0
  280. package/dist/collection/components/af-icon/af-icon.js.map +1 -0
  281. package/dist/collection/components/af-icon-box/af-icon-box.css +36 -0
  282. package/dist/collection/components/af-icon-box/af-icon-box.js +97 -0
  283. package/dist/collection/components/af-icon-box/af-icon-box.js.map +1 -0
  284. package/dist/collection/components/af-icon-button/af-icon-button.css +42 -54
  285. package/dist/collection/components/af-icon-button/af-icon-button.js +8 -5
  286. package/dist/collection/components/af-icon-button/af-icon-button.js.map +1 -1
  287. package/dist/collection/components/af-icon-text/af-icon-text.css +43 -0
  288. package/dist/collection/components/af-icon-text/af-icon-text.js +150 -0
  289. package/dist/collection/components/af-icon-text/af-icon-text.js.map +1 -0
  290. package/dist/collection/components/af-illustrated-card/af-illustrated-card.css +99 -0
  291. package/dist/collection/components/af-illustrated-card/af-illustrated-card.js +115 -0
  292. package/dist/collection/components/af-illustrated-card/af-illustrated-card.js.map +1 -0
  293. package/dist/collection/components/af-image/af-image.css +27 -0
  294. package/dist/collection/components/af-image/af-image.js +65 -0
  295. package/dist/collection/components/af-image/af-image.js.map +1 -0
  296. package/dist/collection/components/af-in-page-banner/af-in-page-banner.css +379 -0
  297. package/dist/collection/components/{af-cta-section/af-cta-section.js → af-in-page-banner/af-in-page-banner.js} +78 -17
  298. package/dist/collection/components/af-in-page-banner/af-in-page-banner.js.map +1 -0
  299. package/dist/collection/components/af-input/af-input.css +246 -0
  300. package/dist/collection/components/af-input/af-input.js +527 -0
  301. package/dist/collection/components/af-input/af-input.js.map +1 -0
  302. package/dist/collection/components/af-logo/af-logo.css +0 -7
  303. package/dist/collection/components/af-logo/af-logo.js +2 -55
  304. package/dist/collection/components/af-logo/af-logo.js.map +1 -1
  305. package/dist/collection/components/af-logo-well/af-logo-well.css +15 -4
  306. package/dist/collection/components/af-logo-well/af-logo-well.js +1 -1
  307. package/dist/collection/components/af-nav-card/af-nav-card.css +70 -0
  308. package/dist/collection/components/af-nav-card/af-nav-card.js +138 -0
  309. package/dist/collection/components/af-nav-card/af-nav-card.js.map +1 -0
  310. package/dist/collection/components/af-nav-item/af-nav-item.css +161 -28
  311. package/dist/collection/components/af-nav-item/af-nav-item.js +27 -0
  312. package/dist/collection/components/af-nav-item/af-nav-item.js.map +1 -1
  313. package/dist/collection/components/af-nav-menu/af-nav-menu.css +91 -0
  314. package/dist/collection/components/af-nav-menu/af-nav-menu.js +131 -0
  315. package/dist/collection/components/af-nav-menu/af-nav-menu.js.map +1 -0
  316. package/dist/collection/components/af-nav-menu-nest/af-nav-menu-nest.css +79 -0
  317. package/dist/collection/components/af-nav-menu-nest/af-nav-menu-nest.js +129 -0
  318. package/dist/collection/components/af-nav-menu-nest/af-nav-menu-nest.js.map +1 -0
  319. package/dist/collection/components/af-navbar/af-navbar.css +91 -8
  320. package/dist/collection/components/af-navbar/af-navbar.js +84 -3
  321. package/dist/collection/components/af-navbar/af-navbar.js.map +1 -1
  322. package/dist/collection/components/af-number-badge/af-number-badge.css +30 -0
  323. package/dist/collection/components/af-number-badge/af-number-badge.js +131 -0
  324. package/dist/collection/components/af-number-badge/af-number-badge.js.map +1 -0
  325. package/dist/collection/components/af-progress-line/af-progress-line.css +44 -0
  326. package/dist/collection/components/af-progress-line/af-progress-line.js +86 -0
  327. package/dist/collection/components/af-progress-line/af-progress-line.js.map +1 -0
  328. package/dist/collection/components/af-radio/af-radio.css +97 -0
  329. package/dist/collection/components/af-radio/af-radio.js +150 -0
  330. package/dist/collection/components/af-radio/af-radio.js.map +1 -0
  331. package/dist/collection/components/af-section/af-section.css +230 -24
  332. package/dist/collection/components/af-section/af-section.js +11 -10
  333. package/dist/collection/components/af-section/af-section.js.map +1 -1
  334. package/dist/collection/components/af-social-link/af-social-link.js +1 -1
  335. package/dist/collection/components/af-split-section/af-split-section.css +46 -0
  336. package/dist/collection/components/af-split-section/af-split-section.js +145 -0
  337. package/dist/collection/components/af-split-section/af-split-section.js.map +1 -0
  338. package/dist/collection/components/af-switch/af-switch.css +104 -0
  339. package/dist/collection/components/af-switch/af-switch.js +155 -0
  340. package/dist/collection/components/af-switch/af-switch.js.map +1 -0
  341. package/dist/collection/components/af-tab/af-tab.css +182 -0
  342. package/dist/collection/components/af-tab/af-tab.js +251 -0
  343. package/dist/collection/components/af-tab/af-tab.js.map +1 -0
  344. package/dist/collection/components/af-tab-bar/af-tab-bar.css +87 -0
  345. package/dist/collection/components/af-tab-bar/af-tab-bar.js +171 -0
  346. package/dist/collection/components/af-tab-bar/af-tab-bar.js.map +1 -0
  347. package/dist/collection/components/af-tag/af-tag.css +92 -0
  348. package/dist/collection/components/af-tag/af-tag.js +126 -0
  349. package/dist/collection/components/af-tag/af-tag.js.map +1 -0
  350. package/dist/collection/components/af-testimonial/af-testimonial.css +30 -46
  351. package/dist/collection/components/af-testimonial/af-testimonial.js +118 -1
  352. package/dist/collection/components/af-testimonial/af-testimonial.js.map +1 -1
  353. package/dist/collection/components/af-testimonial-carousel/af-testimonial-carousel.css +6 -66
  354. package/dist/collection/components/af-testimonial-carousel/af-testimonial-carousel.js +48 -13
  355. package/dist/collection/components/af-testimonial-carousel/af-testimonial-carousel.js.map +1 -1
  356. package/dist/collection/components/af-testimonial-stat/af-testimonial-stat.css +9 -16
  357. package/dist/collection/components/af-testimonial-stat/af-testimonial-stat.js +1 -1
  358. package/dist/collection/components/af-testimonial-stat/af-testimonial-stat.js.map +1 -1
  359. package/dist/collection/components/af-text/af-text.css +13 -36
  360. package/dist/collection/components/af-text/af-text.js +10 -28
  361. package/dist/collection/components/af-text/af-text.js.map +1 -1
  362. package/dist/collection/components/af-text-image/af-text-image.css +228 -0
  363. package/dist/collection/components/af-text-image/af-text-image.js +173 -0
  364. package/dist/collection/components/af-text-image/af-text-image.js.map +1 -0
  365. package/dist/collection/components/af-text-image-nest/af-text-image-nest.css +110 -0
  366. package/dist/collection/components/af-text-image-nest/af-text-image-nest.js +71 -0
  367. package/dist/collection/components/af-text-image-nest/af-text-image-nest.js.map +1 -0
  368. package/dist/collection/components/af-textarea/af-textarea.css +175 -0
  369. package/dist/collection/components/af-textarea/af-textarea.js +443 -0
  370. package/dist/collection/components/af-textarea/af-textarea.js.map +1 -0
  371. package/dist/collection/components/af-typography-lockup/af-typography-lockup.css +126 -40
  372. package/dist/collection/components/af-typography-lockup/af-typography-lockup.js +5 -5
  373. package/dist/collection/components/af-typography-lockup/af-typography-lockup.js.map +1 -1
  374. package/dist/collection/components/af-video-container/af-video-container.css +102 -0
  375. package/dist/collection/components/af-video-container/af-video-container.js +142 -0
  376. package/dist/collection/components/af-video-container/af-video-container.js.map +1 -0
  377. package/dist/collection/components.js +11 -0
  378. package/dist/collection/components.js.map +1 -1
  379. package/dist/components/af-aspect-ratio.js +1 -1
  380. package/dist/components/af-button-group.js +1 -1
  381. package/dist/components/af-button.js +1 -1
  382. package/dist/components/af-card.js +1 -39
  383. package/dist/components/af-card.js.map +1 -1
  384. package/dist/components/{af-cta-section.d.ts → af-checkbox.d.ts} +4 -4
  385. package/dist/components/af-checkbox.js +9 -0
  386. package/dist/components/af-checkbox.js.map +1 -0
  387. package/dist/components/af-client-carousel.js +6 -9
  388. package/dist/components/af-client-carousel.js.map +1 -1
  389. package/dist/components/af-color-swatch.js +1 -1
  390. package/dist/components/af-contact-item.js +2 -2
  391. package/dist/components/af-container.js +1 -1
  392. package/dist/components/af-feature-accordion.js +4 -4
  393. package/dist/components/af-feature-accordion.js.map +1 -1
  394. package/dist/components/af-feature-card.d.ts +11 -0
  395. package/dist/components/af-feature-card.js +9 -0
  396. package/dist/components/af-feature-card.js.map +1 -0
  397. package/dist/components/af-feature-grid.d.ts +11 -0
  398. package/dist/components/af-feature-grid.js +124 -0
  399. package/dist/components/af-feature-grid.js.map +1 -0
  400. package/dist/components/af-fieldset.d.ts +11 -0
  401. package/dist/components/af-fieldset.js +9 -0
  402. package/dist/components/af-fieldset.js.map +1 -0
  403. package/dist/components/af-footer-column.js +2 -2
  404. package/dist/components/af-footer-link.js +2 -2
  405. package/dist/components/af-footer.js +2 -2
  406. package/dist/components/af-grid-callout.d.ts +11 -0
  407. package/dist/components/af-grid-callout.js +82 -0
  408. package/dist/components/af-grid-callout.js.map +1 -0
  409. package/dist/components/af-heading.js +1 -1
  410. package/dist/components/af-hero-section.js +25 -9
  411. package/dist/components/af-hero-section.js.map +1 -1
  412. package/dist/components/af-icon-box.d.ts +11 -0
  413. package/dist/components/af-icon-box.js +9 -0
  414. package/dist/components/af-icon-box.js.map +1 -0
  415. package/dist/components/af-icon-button.js +1 -1
  416. package/dist/components/af-icon-text.d.ts +11 -0
  417. package/dist/components/af-icon-text.js +78 -0
  418. package/dist/components/af-icon-text.js.map +1 -0
  419. package/dist/components/af-icon.d.ts +11 -0
  420. package/dist/components/af-icon.js +9 -0
  421. package/dist/components/af-icon.js.map +1 -0
  422. package/dist/components/af-illustrated-card.d.ts +11 -0
  423. package/dist/components/af-illustrated-card.js +9 -0
  424. package/dist/components/af-illustrated-card.js.map +1 -0
  425. package/dist/components/af-image.d.ts +11 -0
  426. package/dist/components/af-image.js +9 -0
  427. package/dist/components/af-image.js.map +1 -0
  428. package/dist/components/af-in-page-banner.d.ts +11 -0
  429. package/dist/components/af-in-page-banner.js +82 -0
  430. package/dist/components/af-in-page-banner.js.map +1 -0
  431. package/dist/components/af-input.d.ts +11 -0
  432. package/dist/components/af-input.js +9 -0
  433. package/dist/components/af-input.js.map +1 -0
  434. package/dist/components/af-logo-well.js +3 -3
  435. package/dist/components/af-logo-well.js.map +1 -1
  436. package/dist/components/af-logo.js +1 -1
  437. package/dist/components/af-nav-card.d.ts +11 -0
  438. package/dist/components/af-nav-card.js +63 -0
  439. package/dist/components/af-nav-card.js.map +1 -0
  440. package/dist/components/af-nav-item.js +1 -1
  441. package/dist/components/af-nav-menu-nest.d.ts +11 -0
  442. package/dist/components/af-nav-menu-nest.js +67 -0
  443. package/dist/components/af-nav-menu-nest.js.map +1 -0
  444. package/dist/components/af-nav-menu.d.ts +11 -0
  445. package/dist/components/af-nav-menu.js +66 -0
  446. package/dist/components/af-nav-menu.js.map +1 -0
  447. package/dist/components/af-navbar.js +1 -1
  448. package/dist/components/af-number-badge.d.ts +11 -0
  449. package/dist/components/af-number-badge.js +66 -0
  450. package/dist/components/af-number-badge.js.map +1 -0
  451. package/dist/components/af-progress-line.d.ts +11 -0
  452. package/dist/components/af-progress-line.js +9 -0
  453. package/dist/components/af-progress-line.js.map +1 -0
  454. package/dist/components/af-radio.d.ts +11 -0
  455. package/dist/components/af-radio.js +9 -0
  456. package/dist/components/af-radio.js.map +1 -0
  457. package/dist/components/af-section.js +8 -8
  458. package/dist/components/af-section.js.map +1 -1
  459. package/dist/components/af-social-link.js +2 -2
  460. package/dist/components/af-split-section.d.ts +11 -0
  461. package/dist/components/af-split-section.js +71 -0
  462. package/dist/components/af-split-section.js.map +1 -0
  463. package/dist/components/af-switch.d.ts +11 -0
  464. package/dist/components/af-switch.js +9 -0
  465. package/dist/components/af-switch.js.map +1 -0
  466. package/dist/components/af-tab-bar.d.ts +11 -0
  467. package/dist/components/af-tab-bar.js +9 -0
  468. package/dist/components/af-tab-bar.js.map +1 -0
  469. package/dist/components/af-tab.d.ts +11 -0
  470. package/dist/components/af-tab.js +9 -0
  471. package/dist/components/af-tab.js.map +1 -0
  472. package/dist/components/af-tag.d.ts +11 -0
  473. package/dist/components/af-tag.js +9 -0
  474. package/dist/components/af-tag.js.map +1 -0
  475. package/dist/components/af-testimonial-carousel.js +35 -17
  476. package/dist/components/af-testimonial-carousel.js.map +1 -1
  477. package/dist/components/af-testimonial-stat.js +16 -4
  478. package/dist/components/af-testimonial-stat.js.map +1 -1
  479. package/dist/components/af-testimonial.js +56 -5
  480. package/dist/components/af-testimonial.js.map +1 -1
  481. package/dist/components/af-text-image-nest.d.ts +11 -0
  482. package/dist/components/af-text-image-nest.js +51 -0
  483. package/dist/components/af-text-image-nest.js.map +1 -0
  484. package/dist/components/af-text-image.d.ts +11 -0
  485. package/dist/components/af-text-image.js +94 -0
  486. package/dist/components/af-text-image.js.map +1 -0
  487. package/dist/components/af-text.js +1 -1
  488. package/dist/components/af-textarea.d.ts +11 -0
  489. package/dist/components/af-textarea.js +9 -0
  490. package/dist/components/af-textarea.js.map +1 -0
  491. package/dist/components/af-typography-lockup.js +1 -1
  492. package/dist/components/af-video-container.d.ts +11 -0
  493. package/dist/components/af-video-container.js +70 -0
  494. package/dist/components/af-video-container.js.map +1 -0
  495. package/dist/components/index.js +24 -13
  496. package/dist/components/index.js.map +1 -1
  497. package/dist/components/{p-BBivIwbE.js → p-6uEhsUaO.js} +3 -3
  498. package/dist/components/{p-BBivIwbE.js.map → p-6uEhsUaO.js.map} +1 -1
  499. package/dist/components/{p-PLXzXWgX.js → p-BHKA-yEm.js} +4 -4
  500. package/dist/components/p-BHKA-yEm.js.map +1 -0
  501. package/dist/components/p-BMp8QbY-.js +68 -0
  502. package/dist/components/p-BMp8QbY-.js.map +1 -0
  503. package/dist/components/p-BRN73McC.js +59 -0
  504. package/dist/components/p-BRN73McC.js.map +1 -0
  505. package/dist/components/p-BRsO61_R.js +58 -0
  506. package/dist/components/p-BRsO61_R.js.map +1 -0
  507. package/dist/components/p-BXZ7aJQf.js +372 -0
  508. package/dist/components/p-BXZ7aJQf.js.map +1 -0
  509. package/dist/components/p-Bh4YP9vE.js +74 -0
  510. package/dist/components/p-Bh4YP9vE.js.map +1 -0
  511. package/dist/components/p-Br0VERLB.js +81 -0
  512. package/dist/components/p-Br0VERLB.js.map +1 -0
  513. package/dist/components/{p-DBFWSHR9.js → p-ByHIHg3l.js} +4 -4
  514. package/dist/components/{p-DBFWSHR9.js.map → p-ByHIHg3l.js.map} +1 -1
  515. package/dist/components/p-C0f6y_zg.js +94 -0
  516. package/dist/components/p-C0f6y_zg.js.map +1 -0
  517. package/dist/components/p-CCAq3Zj6.js +68 -0
  518. package/dist/components/p-CCAq3Zj6.js.map +1 -0
  519. package/dist/components/p-CZyCImor.js +127 -0
  520. package/dist/components/p-CZyCImor.js.map +1 -0
  521. package/dist/components/p-C_M8AOaj.js +65 -0
  522. package/dist/components/p-C_M8AOaj.js.map +1 -0
  523. package/dist/components/p-Cqp0DdgH.js +58 -0
  524. package/dist/components/p-Cqp0DdgH.js.map +1 -0
  525. package/dist/components/{p-Dt4Fpr3O.js → p-CxngDK-N.js} +122 -8
  526. package/dist/components/p-CxngDK-N.js.map +1 -0
  527. package/dist/components/{p-BkEmrXbw.js → p-D3UZ60qM.js} +3 -3
  528. package/dist/components/{p-BkEmrXbw.js.map → p-D3UZ60qM.js.map} +1 -1
  529. package/dist/components/p-D99aXp3U.js +35 -0
  530. package/dist/components/p-D99aXp3U.js.map +1 -0
  531. package/dist/components/p-DBnL9UHx.js +91 -0
  532. package/dist/components/p-DBnL9UHx.js.map +1 -0
  533. package/dist/components/p-DOkvrcIE.js +50 -0
  534. package/dist/components/p-DOkvrcIE.js.map +1 -0
  535. package/dist/components/p-DW5DrJlQ.js +70 -0
  536. package/dist/components/p-DW5DrJlQ.js.map +1 -0
  537. package/dist/components/p-DZ-qivXD.js +55 -0
  538. package/dist/components/p-DZ-qivXD.js.map +1 -0
  539. package/dist/components/p-DhdRcSve.js +89 -0
  540. package/dist/components/p-DhdRcSve.js.map +1 -0
  541. package/dist/components/p-Dvi1lz3x.js +53 -0
  542. package/dist/components/p-Dvi1lz3x.js.map +1 -0
  543. package/dist/components/p-DzkSL2bi.js +141 -0
  544. package/dist/components/p-DzkSL2bi.js.map +1 -0
  545. package/dist/components/p-JepBVz99.js +71 -0
  546. package/dist/components/p-JepBVz99.js.map +1 -0
  547. package/dist/components/p-_bQXTXUb.js +98 -0
  548. package/dist/components/p-_bQXTXUb.js.map +1 -0
  549. package/dist/components/p-l95vl6T1.js +108 -0
  550. package/dist/components/p-l95vl6T1.js.map +1 -0
  551. package/dist/components/p-wwnR-hlX.js +52 -0
  552. package/dist/components/p-wwnR-hlX.js.map +1 -0
  553. package/dist/components/p-xDRMXxWJ.js +37 -0
  554. package/dist/components/p-xDRMXxWJ.js.map +1 -0
  555. package/dist/esm/af-aspect-ratio.entry.js +2 -2
  556. package/dist/esm/af-aspect-ratio.entry.js.map +1 -1
  557. package/dist/esm/af-button-group.entry.js +2 -2
  558. package/dist/esm/af-button.entry.js +25 -12
  559. package/dist/esm/af-button.entry.js.map +1 -1
  560. package/dist/esm/af-card.entry.js +17 -7
  561. package/dist/esm/af-card.entry.js.map +1 -1
  562. package/dist/esm/af-checkbox.entry.js +56 -0
  563. package/dist/esm/af-checkbox.entry.js.map +1 -0
  564. package/dist/esm/af-client-carousel.entry.js +5 -7
  565. package/dist/esm/af-client-carousel.entry.js.map +1 -1
  566. package/dist/esm/af-color-swatch.entry.js +1 -1
  567. package/dist/esm/af-contact-item.entry.js +2 -2
  568. package/dist/esm/af-container.entry.js +1 -1
  569. package/dist/esm/af-feature-accordion.entry.js +4 -4
  570. package/dist/esm/af-feature-accordion.entry.js.map +1 -1
  571. package/dist/esm/af-feature-card.entry.js +57 -0
  572. package/dist/esm/af-feature-card.entry.js.map +1 -0
  573. package/dist/esm/af-feature-grid.entry.js +91 -0
  574. package/dist/esm/af-feature-grid.entry.js.map +1 -0
  575. package/dist/esm/af-fieldset.entry.js +35 -0
  576. package/dist/esm/af-fieldset.entry.js.map +1 -0
  577. package/dist/esm/af-footer-column.entry.js +2 -2
  578. package/dist/esm/af-footer-link.entry.js +2 -2
  579. package/dist/esm/af-footer.entry.js +2 -2
  580. package/dist/esm/af-grid-callout.entry.js +49 -0
  581. package/dist/esm/af-grid-callout.entry.js.map +1 -0
  582. package/dist/esm/af-heading.af-logo.af-nav-item.af-navbar.af-text.entry.js.map +1 -1
  583. package/dist/esm/af-heading_5.entry.js +67 -27
  584. package/dist/esm/af-hero-section.entry.js +11 -5
  585. package/dist/esm/af-hero-section.entry.js.map +1 -1
  586. package/dist/esm/af-icon-box.entry.js +28 -0
  587. package/dist/esm/af-icon-box.entry.js.map +1 -0
  588. package/dist/esm/af-icon-button.entry.js +6 -3
  589. package/dist/esm/af-icon-button.entry.js.map +1 -1
  590. package/dist/esm/af-icon-text.entry.js +34 -0
  591. package/dist/esm/af-icon-text.entry.js.map +1 -0
  592. package/dist/esm/af-icon.entry.js +349 -0
  593. package/dist/esm/af-icon.entry.js.map +1 -0
  594. package/dist/esm/af-illustrated-card.entry.js +34 -0
  595. package/dist/esm/af-illustrated-card.entry.js.map +1 -0
  596. package/dist/esm/af-image.entry.js +16 -0
  597. package/dist/esm/af-image.entry.js.map +1 -0
  598. package/dist/esm/af-in-page-banner.entry.js +45 -0
  599. package/dist/esm/af-in-page-banner.entry.js.map +1 -0
  600. package/dist/esm/af-input.entry.js +102 -0
  601. package/dist/esm/af-input.entry.js.map +1 -0
  602. package/dist/esm/af-logo-well.entry.js +3 -3
  603. package/dist/esm/af-logo-well.entry.js.map +1 -1
  604. package/dist/esm/af-nav-card.entry.js +35 -0
  605. package/dist/esm/af-nav-card.entry.js.map +1 -0
  606. package/dist/esm/af-nav-menu-nest.entry.js +41 -0
  607. package/dist/esm/af-nav-menu-nest.entry.js.map +1 -0
  608. package/dist/esm/af-nav-menu.entry.js +39 -0
  609. package/dist/esm/af-nav-menu.entry.js.map +1 -0
  610. package/dist/esm/af-number-badge.entry.js +40 -0
  611. package/dist/esm/af-number-badge.entry.js.map +1 -0
  612. package/dist/esm/af-progress-line.entry.js +31 -0
  613. package/dist/esm/af-progress-line.entry.js.map +1 -0
  614. package/dist/esm/af-radio.entry.js +41 -0
  615. package/dist/esm/af-radio.entry.js.map +1 -0
  616. package/dist/esm/af-section.entry.js +6 -6
  617. package/dist/esm/af-section.entry.js.map +1 -1
  618. package/dist/esm/af-social-link.entry.js +2 -2
  619. package/dist/esm/af-split-section.entry.js +39 -0
  620. package/dist/esm/af-split-section.entry.js.map +1 -0
  621. package/dist/esm/af-switch.entry.js +46 -0
  622. package/dist/esm/af-switch.entry.js.map +1 -0
  623. package/dist/esm/af-tab-bar.entry.js +86 -0
  624. package/dist/esm/af-tab-bar.entry.js.map +1 -0
  625. package/dist/esm/af-tab.entry.js +62 -0
  626. package/dist/esm/af-tab.entry.js.map +1 -0
  627. package/dist/esm/af-tag.entry.js +35 -0
  628. package/dist/esm/af-tag.entry.js.map +1 -0
  629. package/dist/esm/af-testimonial-carousel.entry.js +27 -15
  630. package/dist/esm/af-testimonial-carousel.entry.js.map +1 -1
  631. package/dist/esm/af-testimonial-stat.entry.js +3 -3
  632. package/dist/esm/af-testimonial-stat.entry.js.map +1 -1
  633. package/dist/esm/af-testimonial.entry.js +27 -3
  634. package/dist/esm/af-testimonial.entry.js.map +1 -1
  635. package/dist/esm/af-text-image-nest.entry.js +28 -0
  636. package/dist/esm/af-text-image-nest.entry.js.map +1 -0
  637. package/dist/esm/af-text-image.entry.js +61 -0
  638. package/dist/esm/af-text-image.entry.js.map +1 -0
  639. package/dist/esm/af-textarea.entry.js +91 -0
  640. package/dist/esm/af-textarea.entry.js.map +1 -0
  641. package/dist/esm/af-typography-lockup.entry.js +7 -7
  642. package/dist/esm/af-typography-lockup.entry.js.map +1 -1
  643. package/dist/esm/af-video-container.entry.js +33 -0
  644. package/dist/esm/af-video-container.entry.js.map +1 -0
  645. package/dist/esm/affinda.js +3 -3
  646. package/dist/esm/{index-DI7b0bCy.js → index-BmU_CFQ4.js} +130 -7
  647. package/dist/esm/index-BmU_CFQ4.js.map +1 -0
  648. package/dist/esm/index.js +12 -1
  649. package/dist/esm/index.js.map +1 -1
  650. package/dist/esm/loader.js +3 -3
  651. package/dist/types/components/af-button/af-button.d.ts +22 -9
  652. package/dist/types/components/af-card/af-card.d.ts +15 -8
  653. package/dist/types/components/af-checkbox/af-checkbox.d.ts +40 -0
  654. package/dist/types/components/af-client-carousel/af-client-carousel.d.ts +10 -5
  655. package/dist/types/components/af-feature-accordion/af-feature-accordion.d.ts +13 -3
  656. package/dist/types/components/af-feature-card/af-feature-card.d.ts +49 -0
  657. package/dist/types/components/af-feature-grid/af-feature-grid.d.ts +32 -0
  658. package/dist/types/components/af-fieldset/af-fieldset.d.ts +23 -0
  659. package/dist/types/components/af-grid-callout/af-grid-callout.d.ts +57 -0
  660. package/dist/types/components/af-heading/af-heading.d.ts +5 -2
  661. package/dist/types/components/af-hero-section/af-hero-section.d.ts +18 -3
  662. package/dist/types/components/af-icon/af-icon.d.ts +28 -0
  663. package/dist/types/components/af-icon-box/af-icon-box.d.ts +27 -0
  664. package/dist/types/components/af-icon-button/af-icon-button.d.ts +5 -2
  665. package/dist/types/components/af-icon-text/af-icon-text.d.ts +44 -0
  666. package/dist/types/components/af-illustrated-card/af-illustrated-card.d.ts +28 -0
  667. package/dist/types/components/af-image/af-image.d.ts +15 -0
  668. package/dist/types/components/af-in-page-banner/af-in-page-banner.d.ts +56 -0
  669. package/dist/types/components/af-input/af-input.d.ts +110 -0
  670. package/dist/types/components/af-logo/af-logo.d.ts +1 -6
  671. package/dist/types/components/af-nav-card/af-nav-card.d.ts +34 -0
  672. package/dist/types/components/af-nav-item/af-nav-item.d.ts +6 -0
  673. package/dist/types/components/af-nav-menu/af-nav-menu.d.ts +28 -0
  674. package/dist/types/components/af-nav-menu-nest/af-nav-menu-nest.d.ts +42 -0
  675. package/dist/types/components/af-navbar/af-navbar.d.ts +26 -1
  676. package/dist/types/components/af-number-badge/af-number-badge.d.ts +29 -0
  677. package/dist/types/components/af-progress-line/af-progress-line.d.ts +18 -0
  678. package/dist/types/components/af-radio/af-radio.d.ts +33 -0
  679. package/dist/types/components/af-section/af-section.d.ts +4 -3
  680. package/dist/types/components/af-split-section/af-split-section.d.ts +20 -0
  681. package/dist/types/components/af-switch/af-switch.d.ts +32 -0
  682. package/dist/types/components/af-tab/af-tab.d.ts +61 -0
  683. package/dist/types/components/af-tab-bar/af-tab-bar.d.ts +43 -0
  684. package/dist/types/components/af-tag/af-tag.d.ts +33 -0
  685. package/dist/types/components/af-testimonial/af-testimonial.d.ts +23 -0
  686. package/dist/types/components/af-testimonial-carousel/af-testimonial-carousel.d.ts +17 -0
  687. package/dist/types/components/af-text/af-text.d.ts +6 -3
  688. package/dist/types/components/af-text-image/af-text-image.d.ts +30 -0
  689. package/dist/types/components/af-text-image-nest/af-text-image-nest.d.ts +21 -0
  690. package/dist/types/components/af-textarea/af-textarea.d.ts +92 -0
  691. package/dist/types/components/af-video-container/af-video-container.d.ts +45 -0
  692. package/dist/types/components.d.ts +3395 -669
  693. package/package.json +8 -7
  694. package/dist/affinda/af-cta-section.entry.esm.js.map +0 -1
  695. package/dist/affinda/p-050f98cd.entry.js +0 -2
  696. package/dist/affinda/p-0eb8173d.entry.js +0 -2
  697. package/dist/affinda/p-1955dbad.entry.js +0 -2
  698. package/dist/affinda/p-1b18ab28.entry.js +0 -2
  699. package/dist/affinda/p-1b18ab28.entry.js.map +0 -1
  700. package/dist/affinda/p-1e3d40a0.entry.js +0 -2
  701. package/dist/affinda/p-1e3d40a0.entry.js.map +0 -1
  702. package/dist/affinda/p-350ac7a5.entry.js +0 -2
  703. package/dist/affinda/p-71e663b3.entry.js +0 -2
  704. package/dist/affinda/p-71e663b3.entry.js.map +0 -1
  705. package/dist/affinda/p-7b8c36e0.entry.js +0 -2
  706. package/dist/affinda/p-7b8c36e0.entry.js.map +0 -1
  707. package/dist/affinda/p-83b5d5ea.entry.js +0 -2
  708. package/dist/affinda/p-83b5d5ea.entry.js.map +0 -1
  709. package/dist/affinda/p-9071c2a7.entry.js +0 -2
  710. package/dist/affinda/p-954963fa.entry.js +0 -2
  711. package/dist/affinda/p-954963fa.entry.js.map +0 -1
  712. package/dist/affinda/p-DI7b0bCy.js +0 -3
  713. package/dist/affinda/p-DI7b0bCy.js.map +0 -1
  714. package/dist/affinda/p-b2fb60c9.entry.js +0 -2
  715. package/dist/affinda/p-b2fb60c9.entry.js.map +0 -1
  716. package/dist/affinda/p-d3b2ab0e.entry.js +0 -2
  717. package/dist/affinda/p-e1198ca3.entry.js +0 -2
  718. package/dist/affinda/p-e1198ca3.entry.js.map +0 -1
  719. package/dist/affinda/p-e3efc291.entry.js +0 -2
  720. package/dist/affinda/p-e3efc291.entry.js.map +0 -1
  721. package/dist/affinda/p-f692a7bd.entry.js +0 -2
  722. package/dist/affinda/p-f692a7bd.entry.js.map +0 -1
  723. package/dist/affinda/p-fc2cb8d1.entry.js +0 -2
  724. package/dist/cjs/af-cta-section.cjs.entry.js +0 -34
  725. package/dist/cjs/af-cta-section.entry.cjs.js.map +0 -1
  726. package/dist/cjs/index-DfEVhbS6.js.map +0 -1
  727. package/dist/collection/components/af-cta-section/af-cta-section.css +0 -175
  728. package/dist/collection/components/af-cta-section/af-cta-section.js.map +0 -1
  729. package/dist/components/af-cta-section.js +0 -62
  730. package/dist/components/af-cta-section.js.map +0 -1
  731. package/dist/components/p-BKGrl8ua.js +0 -77
  732. package/dist/components/p-BKGrl8ua.js.map +0 -1
  733. package/dist/components/p-BTEblSAo.js +0 -63
  734. package/dist/components/p-BTEblSAo.js.map +0 -1
  735. package/dist/components/p-BekWfVfB.js +0 -66
  736. package/dist/components/p-BekWfVfB.js.map +0 -1
  737. package/dist/components/p-Bg7dSc4D.js +0 -54
  738. package/dist/components/p-Bg7dSc4D.js.map +0 -1
  739. package/dist/components/p-CN_K2ni-.js +0 -45
  740. package/dist/components/p-CN_K2ni-.js.map +0 -1
  741. package/dist/components/p-CgnBqOVh.js +0 -50
  742. package/dist/components/p-CgnBqOVh.js.map +0 -1
  743. package/dist/components/p-DqOwXTsH.js +0 -68
  744. package/dist/components/p-DqOwXTsH.js.map +0 -1
  745. package/dist/components/p-Dt4Fpr3O.js.map +0 -1
  746. package/dist/components/p-LUt2VDjp.js +0 -68
  747. package/dist/components/p-LUt2VDjp.js.map +0 -1
  748. package/dist/components/p-PLXzXWgX.js.map +0 -1
  749. package/dist/esm/af-cta-section.entry.js +0 -32
  750. package/dist/esm/af-cta-section.entry.js.map +0 -1
  751. package/dist/esm/index-DI7b0bCy.js.map +0 -1
  752. package/dist/types/components/af-cta-section/af-cta-section.d.ts +0 -23
  753. /package/dist/affinda/{p-0eb8173d.entry.js.map → p-1d9e532f.entry.js.map} +0 -0
  754. /package/dist/affinda/{p-fb4e3a8d.entry.js.map → p-31d4c1a4.entry.js.map} +0 -0
  755. /package/dist/affinda/{p-1955dbad.entry.js.map → p-53ae16fe.entry.js.map} +0 -0
  756. /package/dist/affinda/{p-ec7721cc.entry.js.map → p-72f02343.entry.js.map} +0 -0
  757. /package/dist/affinda/{p-bd30e86a.entry.js.map → p-96eac3af.entry.js.map} +0 -0
  758. /package/dist/affinda/{p-806d129e.entry.js.map → p-acbbe39a.entry.js.map} +0 -0
  759. /package/dist/affinda/{p-3a9646e6.entry.js.map → p-c11088fa.entry.js.map} +0 -0
  760. /package/dist/affinda/{p-f8ac0120.entry.js.map → p-e5af21c2.entry.js.map} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-input.entry.js","sources":["src/components/af-input/af-input.css?tag=af-input&encapsulation=shadow","src/components/af-input/af-input.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n/* Wrapper */\n.input-wrapper {\n display: flex;\n flex-direction: column;\n gap: var(--sds-size-space-200, 8px);\n width: 100%;\n}\n\n/* Label row */\n.label-row {\n display: flex;\n align-items: center;\n gap: 12px;\n}\n\n.label {\n flex: 1;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: var(--font-weight-book, 500);\n font-size: 16px;\n line-height: 24px;\n color: var(--forms-fields-label, var(--colour-brand-inkwell, #14343b));\n cursor: default;\n}\n\n.required {\n color: var(--forms-fields-error, #be292a);\n margin-left: 2px;\n}\n\n/* Info icon button */\n.info-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n padding: 0;\n border: none;\n background: none;\n cursor: pointer;\n color: var(--forms-fields-label, var(--colour-brand-inkwell, #14343b));\n flex-shrink: 0;\n}\n\n.info-icon svg {\n width: 20px;\n height: 20px;\n}\n\n.info-icon:hover {\n opacity: 0.7;\n}\n\n.info-icon:focus-visible {\n outline: 2px solid var(--buttons-secondary-stroke, #14343b);\n outline-offset: 2px;\n border-radius: 4px;\n}\n\n/* Description */\n.description {\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: var(--font-weight-regular, 400);\n font-size: 16px;\n line-height: 24px;\n color: var(--forms-fields-description, var(--colour-inkwell-400, #2b484f));\n margin: 0;\n}\n\n/* Input container */\n.input-container {\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 12px 16px;\n background: var(--forms-fields-bg-default, #ffffff);\n border: 1px solid var(--forms-fields-stroke-default, #d0d6d8);\n border-radius: var(--radii-input, 8px);\n transition: all 0.15s ease;\n min-height: 48px;\n box-sizing: border-box;\n}\n\n/* Hover state */\n.input-container.hovered {\n background: var(--forms-fields-bg-hover, #f3f5f5);\n}\n\n/* Focus state */\n.input-container.focused {\n background: var(--forms-fields-bg-default, #ffffff);\n border-color: var(--forms-fields-stroke-active, var(--colour-brand-inkwell, #14343b));\n box-shadow: \n 0 0 0 4px var(--background-base, #ffffff), \n 0 0 0 5px var(--buttons-secondary-stroke, #14343b);\n}\n\n/* Error state */\n.input-container.error {\n border-color: var(--forms-fields-stroke-error, #be292a);\n}\n\n/* Disabled state */\n.input-container.disabled {\n background: var(--forms-fields-bg-disabled, #e8ebeb);\n border-color: var(--forms-fields-stroke-default, #d0d6d8);\n cursor: not-allowed;\n}\n\n/* Search icon */\n.search-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n color: var(--forms-fields-label, var(--colour-brand-inkwell, #14343b));\n}\n\n.search-icon svg {\n width: 20px;\n height: 20px;\n}\n\n.disabled .search-icon {\n opacity: 0.5;\n}\n\n/* Native input */\n.input {\n flex: 1;\n min-width: 0;\n padding: 0;\n border: none;\n background: transparent;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: var(--font-weight-regular, 400);\n font-size: 16px;\n line-height: 24px;\n color: var(--forms-fields-input, var(--colour-brand-inkwell, #14343b));\n outline: none;\n}\n\n.input::placeholder {\n color: var(--forms-fields-placeholder, #60767b);\n opacity: 1;\n}\n\n.input:disabled {\n cursor: not-allowed;\n color: var(--forms-fields-placeholder, #60767b);\n}\n\n.input:disabled::placeholder {\n color: var(--forms-fields-placeholder, #60767b);\n}\n\n/* Hide native browser styling for search inputs */\n.input[type=\"search\"]::-webkit-search-decoration,\n.input[type=\"search\"]::-webkit-search-cancel-button,\n.input[type=\"search\"]::-webkit-search-results-button,\n.input[type=\"search\"]::-webkit-search-results-decoration {\n display: none;\n}\n\n/* Hide number input spinners */\n.input[type=\"number\"]::-webkit-inner-spin-button,\n.input[type=\"number\"]::-webkit-outer-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n\n.input[type=\"number\"] {\n -moz-appearance: textfield;\n}\n\n/* Clear button */\n.clear-button {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n padding: 0;\n border: none;\n background: none;\n cursor: pointer;\n color: var(--forms-fields-label, var(--colour-brand-inkwell, #14343b));\n flex-shrink: 0;\n opacity: 0.6;\n transition: opacity 0.15s ease;\n}\n\n.clear-button svg {\n width: 16px;\n height: 16px;\n}\n\n.clear-button:hover {\n opacity: 1;\n}\n\n.clear-button:focus-visible {\n outline: 2px solid var(--buttons-secondary-stroke, #14343b);\n outline-offset: 2px;\n border-radius: 4px;\n}\n\n/* Error row */\n.error-row {\n display: flex;\n align-items: center;\n gap: 12px;\n}\n\n.error-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n color: var(--forms-fields-error, #be292a);\n}\n\n.error-icon svg {\n width: 20px;\n height: 20px;\n}\n\n.error-text {\n flex: 1;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: var(--font-weight-regular, 400);\n font-size: 16px;\n line-height: 24px;\n color: var(--forms-fields-error, #be292a);\n}\n\n","import { Component, h, Prop, Host, Event, EventEmitter, State } from '@stencil/core';\n\n/**\n * Input field component with label, description, and error states.\n * Supports various input types and validation states.\n * \n * @slot label-end - Content to display at the end of the label (e.g., info icon)\n */\n@Component({\n tag: 'af-input',\n styleUrl: 'af-input.css',\n shadow: true\n})\nexport class AfInput {\n /**\n * The label text for the input field\n */\n @Prop() label?: string;\n\n /**\n * Description text displayed below the label\n */\n @Prop() description?: string;\n\n /**\n * Placeholder text for the input\n */\n @Prop() placeholder?: string;\n\n /**\n * The current value of the input\n */\n @Prop({ mutable: true }) value: string = '';\n\n /**\n * The input type (text, email, password, number, tel, url, search)\n */\n @Prop() type: 'text' | 'email' | 'password' | 'number' | 'tel' | 'url' | 'search' = 'text';\n\n /**\n * The name of the input for form submission\n */\n @Prop() name?: string;\n\n /**\n * Whether the input is disabled\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * Whether the input is required\n */\n @Prop() required: boolean = false;\n\n /**\n * Whether the input is read-only\n */\n @Prop() readonly: boolean = false;\n\n /**\n * Error message to display (also sets error state)\n */\n @Prop() error?: string;\n\n /**\n * Whether to show the info icon next to the label\n */\n @Prop() showInfoIcon: boolean = false;\n\n /**\n * Whether to show a search icon in the input\n */\n @Prop() showSearchIcon: boolean = false;\n\n /**\n * Whether to show a clear button when input has value\n */\n @Prop() clearable: boolean = false;\n\n /**\n * Autocomplete attribute for the input\n */\n @Prop() autocomplete?: string;\n\n /**\n * Maximum length of input value\n */\n @Prop() maxlength?: number;\n\n /**\n * Minimum length of input value\n */\n @Prop() minlength?: number;\n\n /**\n * Pattern for input validation (regex)\n */\n @Prop() pattern?: string;\n\n /**\n * Emitted when the input value changes\n */\n @Event() afInput!: EventEmitter<{ value: string }>;\n\n /**\n * Emitted when the input loses focus\n */\n @Event() afBlur!: EventEmitter<void>;\n\n /**\n * Emitted when the input gains focus\n */\n @Event() afFocus!: EventEmitter<void>;\n\n /**\n * Emitted when the clear button is clicked\n */\n @Event() afClear!: EventEmitter<void>;\n\n /**\n * Emitted when the info icon is clicked\n */\n @Event() afInfoClick!: EventEmitter<void>;\n\n @State() private isFocused: boolean = false;\n @State() private isHovered: boolean = false;\n\n private inputEl?: HTMLInputElement;\n\n private handleInput = (event: Event) => {\n const target = event.target as HTMLInputElement;\n this.value = target.value;\n this.afInput.emit({ value: this.value });\n };\n\n private handleFocus = () => {\n this.isFocused = true;\n this.afFocus.emit();\n };\n\n private handleBlur = () => {\n this.isFocused = false;\n this.afBlur.emit();\n };\n\n private handleMouseEnter = () => {\n this.isHovered = true;\n };\n\n private handleMouseLeave = () => {\n this.isHovered = false;\n };\n\n private handleClear = () => {\n this.value = '';\n this.afClear.emit();\n this.afInput.emit({ value: '' });\n this.inputEl?.focus();\n };\n\n private handleInfoClick = (event: MouseEvent) => {\n event.preventDefault();\n event.stopPropagation();\n this.afInfoClick.emit();\n };\n\n render() {\n const hasError = !!this.error;\n const hasValue = !!(this.value && this.value.length > 0);\n\n const wrapperClasses = {\n 'input-wrapper': true,\n 'disabled': this.disabled,\n 'error': hasError,\n 'focused': this.isFocused,\n 'hovered': this.isHovered && !this.disabled && !this.isFocused,\n 'populated': hasValue\n };\n\n const inputContainerClasses = {\n 'input-container': true,\n 'disabled': this.disabled,\n 'error': hasError,\n 'focused': this.isFocused,\n 'hovered': this.isHovered && !this.disabled && !this.isFocused\n };\n\n return (\n <Host>\n <div class={wrapperClasses}>\n {/* Label */}\n {this.label && (\n <div class=\"label-row\">\n <label class=\"label\" htmlFor=\"input\">\n {this.label}\n {this.required && <span class=\"required\">*</span>}\n </label>\n {this.showInfoIcon && (\n <button \n type=\"button\" \n class=\"info-icon\" \n onClick={this.handleInfoClick}\n aria-label=\"More information\"\n >\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 16V12\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 8H12.01\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </button>\n )}\n <slot name=\"label-end\"></slot>\n </div>\n )}\n\n {/* Description */}\n {this.description && (\n <p class=\"description\">{this.description}</p>\n )}\n\n {/* Input container */}\n <div \n class={inputContainerClasses}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n >\n {/* Search icon */}\n {this.showSearchIcon && (\n <span class=\"search-icon\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M11 19C15.4183 19 19 15.4183 19 11C19 6.58172 15.4183 3 11 3C6.58172 3 3 6.58172 3 11C3 15.4183 6.58172 19 11 19Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M21 21L16.65 16.65\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </span>\n )}\n\n {/* Native input */}\n <input\n ref={(el) => this.inputEl = el ?? undefined}\n id=\"input\"\n class=\"input\"\n type={this.type}\n name={this.name}\n value={this.value}\n placeholder={this.placeholder}\n disabled={this.disabled}\n required={this.required}\n readonly={this.readonly}\n autocomplete={this.autocomplete}\n maxlength={this.maxlength}\n minlength={this.minlength}\n pattern={this.pattern}\n aria-invalid={hasError ? 'true' : undefined}\n aria-describedby={hasError ? 'error-message' : this.description ? 'description' : undefined}\n onInput={this.handleInput}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n />\n\n {/* Clear button */}\n {this.clearable && hasValue && !this.disabled && !this.readonly && (\n <button \n type=\"button\" \n class=\"clear-button\" \n onClick={this.handleClear}\n aria-label=\"Clear input\"\n >\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M18 6L6 18\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M6 6L18 18\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </button>\n )}\n </div>\n\n {/* Error message */}\n {hasError && (\n <div class=\"error-row\" id=\"error-message\">\n <span class=\"error-icon\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 16V12\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 8H12.01\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </span>\n <span class=\"error-text\">{this.error}</span>\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":"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"}
@@ -1,13 +1,13 @@
1
- import { r as registerInstance, h, H as Host } from './index-DI7b0bCy.js';
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
2
 
3
- const afLogoWellCss = ":host{display:inline-block}.logo-well{background:rgb(32, 62, 69);border-radius:16px;height:72px;width:184px;display:flex;align-items:center;justify-content:center;padding:20px 32px;box-sizing:border-box}::slotted(img){max-height:32px;max-width:120px;width:auto;height:auto;display:block;object-fit:contain;filter:brightness(0) invert(1);}::slotted(svg){max-height:32px;max-width:120px;width:auto;height:auto;display:block}::slotted(div){white-space:nowrap;color:white;font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-weight:600;font-size:16px}";
3
+ const afLogoWellCss = ":host{display:inline-block}.logo-well{background:var(--af-carousel-logo-well-bg, var(--colour-background-level1-dark, #203e45));border-radius:var(--radius-logo-well-desktop, 16px);height:72px;width:184px;display:flex;align-items:center;justify-content:center;padding:20px 32px;box-sizing:border-box}::slotted(img){max-height:32px;max-width:120px;width:auto;height:auto;display:block;object-fit:contain;filter:var(--af-carousel-logo-filter, brightness(0) invert(1))}::slotted(svg){max-height:32px;max-width:120px;width:auto;height:auto;display:block;color:var(--af-carousel-logo-color, white)}::slotted(div){white-space:nowrap;color:var(--af-carousel-logo-color, white);font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-weight:600;font-size:16px}@media (max-width: 767px){.logo-well{border-radius:var(--radius-logo-well-mobile, 12px);padding:20px 24px}}";
4
4
 
5
5
  const AfLogoWell = class {
6
6
  constructor(hostRef) {
7
7
  registerInstance(this, hostRef);
8
8
  }
9
9
  render() {
10
- return (h(Host, { key: '679e2499f882286319d238428fea12307fd7913e' }, h("div", { key: '7b6b0e3571f5e584939622077b2c9d861f6343e4', class: "logo-well" }, h("slot", { key: '07c6a572e394bc9e7f11e0b1c94c725a83ed312a' }))));
10
+ return (h(Host, { key: 'f64c4eb4974d71972365ba55c49b54bd1667d157' }, h("div", { key: '1192eb30a0dcb0426d15b23148f9f48b2ded06d4', class: "logo-well" }, h("slot", { key: 'f62638c5fab67512858baf0756c38ce45546dd0e' }))));
11
11
  }
12
12
  };
13
13
  AfLogoWell.style = afLogoWellCss;
@@ -1 +1 @@
1
- {"version":3,"file":"af-logo-well.entry.js","sources":["src/components/af-logo-well/af-logo-well.css?tag=af-logo-well&encapsulation=shadow","src/components/af-logo-well/af-logo-well.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.logo-well {\n background: rgb(32, 62, 69); /* Slightly lighter than inkwell for contrast */\n border-radius: 16px;\n height: 72px;\n width: 184px;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 20px 32px;\n box-sizing: border-box;\n}\n\n::slotted(img) {\n max-height: 32px;\n max-width: 120px;\n width: auto;\n height: auto;\n display: block;\n object-fit: contain;\n filter: brightness(0) invert(1); /* Make logos white */\n}\n\n::slotted(svg) {\n max-height: 32px;\n max-width: 120px;\n width: auto;\n height: auto;\n display: block;\n}\n\n::slotted(div) {\n white-space: nowrap;\n color: white;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: 600;\n font-size: 16px;\n}\n\n","import { Component, h, Host } from '@stencil/core';\n\n/**\n * A rounded container for displaying client logos\n */\n@Component({\n tag: 'af-logo-well',\n styleUrl: 'af-logo-well.css',\n shadow: true,\n})\nexport class AfLogoWell {\n render() {\n return (\n <Host>\n <div class=\"logo-well\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,aAAa,GAAG,sjBAAsjB;;MCU/jB,UAAU,GAAA,MAAA;;;;IACrB,MAAM,GAAA;AACJ,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,WAAW,EAAA,EACpB,CAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT,CACD;;;;;;;"}
1
+ {"version":3,"file":"af-logo-well.entry.js","sources":["src/components/af-logo-well/af-logo-well.css?tag=af-logo-well&encapsulation=shadow","src/components/af-logo-well/af-logo-well.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.logo-well {\n /* Use theme variable from parent carousel, or fall back to dark theme default */\n background: var(--af-carousel-logo-well-bg, var(--colour-background-level1-dark, #203e45));\n border-radius: var(--radius-logo-well-desktop, 16px);\n height: 72px;\n width: 184px;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 20px 32px;\n box-sizing: border-box;\n}\n\n::slotted(img) {\n max-height: 32px;\n max-width: 120px;\n width: auto;\n height: auto;\n display: block;\n object-fit: contain;\n /* Use logo filter from parent theme, default to white logos for dark backgrounds */\n filter: var(--af-carousel-logo-filter, brightness(0) invert(1));\n}\n\n::slotted(svg) {\n max-height: 32px;\n max-width: 120px;\n width: auto;\n height: auto;\n display: block;\n /* SVG color inherits from parent */\n color: var(--af-carousel-logo-color, white);\n}\n\n::slotted(div) {\n white-space: nowrap;\n color: var(--af-carousel-logo-color, white);\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: 600;\n font-size: 16px;\n}\n\n/* Mobile adjustments */\n@media (max-width: 767px) {\n .logo-well {\n border-radius: var(--radius-logo-well-mobile, 12px);\n padding: 20px 24px;\n }\n}\n","import { Component, h, Host } from '@stencil/core';\n\n/**\n * A rounded container for displaying client logos\n */\n@Component({\n tag: 'af-logo-well',\n styleUrl: 'af-logo-well.css',\n shadow: true,\n})\nexport class AfLogoWell {\n render() {\n return (\n <Host>\n <div class=\"logo-well\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,aAAa,GAAG,02BAA02B;;MCUn3B,UAAU,GAAA,MAAA;;;;IACrB,MAAM,GAAA;AACJ,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,WAAW,EAAA,EACpB,CAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT,CACD;;;;;;;"}
@@ -0,0 +1,35 @@
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afNavCardCss = ":host{display:block}.card-link{text-decoration:none;color:inherit;display:block}.nav-card{display:flex;flex-direction:column;position:relative;width:290px;height:360px;min-height:360px;border-radius:var(--radii-image, 16px);overflow:hidden;justify-content:flex-end;transition:transform 0.2s ease}.nav-card.is-hovered{transform:scale(1.02)}.image-container{position:absolute;inset:0;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;object-position:center}.overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to bottom, rgba(0, 0, 0, 0), #000000);padding:80px 24px 24px 24px;display:flex;flex-direction:column;align-items:flex-start}.heading{margin:0;font-family:var(--typography-headingfont, 'NeuSans', 'Inter', system-ui, sans-serif);font-weight:var(--font-weight-book, 500);font-size:24px;line-height:1.2;letter-spacing:-0.48px;color:#ffffff;width:100%}.nav-card.is-hovered .heading{text-decoration:underline}";
4
+
5
+ const AfNavCard = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * Alternative text for the image
10
+ */
11
+ this.imageAlt = '';
12
+ this.isHovered = false;
13
+ this.handleMouseEnter = () => {
14
+ this.isHovered = true;
15
+ };
16
+ this.handleMouseLeave = () => {
17
+ this.isHovered = false;
18
+ };
19
+ }
20
+ render() {
21
+ const classes = {
22
+ 'nav-card': true,
23
+ 'is-hovered': this.isHovered
24
+ };
25
+ const content = (h("div", { class: classes, onMouseEnter: this.handleMouseEnter, onMouseLeave: this.handleMouseLeave }, h("div", { class: "image-container" }, this.imageSrc && (h("img", { src: this.imageSrc, alt: this.imageAlt, class: "card-image" }))), h("div", { class: "overlay" }, this.heading && (h("h3", { class: "heading" }, this.heading)))));
26
+ if (this.href) {
27
+ return (h(Host, null, h("a", { href: this.href, class: "card-link" }, content)));
28
+ }
29
+ return h(Host, null, content);
30
+ }
31
+ };
32
+ AfNavCard.style = afNavCardCss;
33
+
34
+ export { AfNavCard as af_nav_card };
35
+ //# sourceMappingURL=af-nav-card.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-nav-card.entry.js","sources":["src/components/af-nav-card/af-nav-card.css?tag=af-nav-card&encapsulation=shadow","src/components/af-nav-card/af-nav-card.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.card-link {\n text-decoration: none;\n color: inherit;\n display: block;\n}\n\n/* Card container */\n.nav-card {\n display: flex;\n flex-direction: column;\n position: relative;\n width: 290px;\n height: 360px;\n min-height: 360px;\n border-radius: var(--radii-image, 16px);\n overflow: hidden;\n justify-content: flex-end;\n transition: transform 0.2s ease;\n}\n\n.nav-card.is-hovered {\n transform: scale(1.02);\n}\n\n/* Image container */\n.image-container {\n position: absolute;\n inset: 0;\n overflow: hidden;\n}\n\n.card-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n object-position: center;\n}\n\n/* Gradient overlay */\n.overlay {\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n background: linear-gradient(to bottom, rgba(0, 0, 0, 0), #000000);\n padding: 80px 24px 24px 24px;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n}\n\n/* Heading */\n.heading {\n margin: 0;\n font-family: var(--typography-headingfont, 'NeuSans', 'Inter', system-ui, sans-serif);\n font-weight: var(--font-weight-book, 500);\n font-size: 24px;\n line-height: 1.2;\n letter-spacing: -0.48px;\n color: #ffffff;\n width: 100%;\n}\n\n.nav-card.is-hovered .heading {\n text-decoration: underline;\n}\n","import { Component, h, Prop, Host, State } from '@stencil/core';\n\n/**\n * A navigation card component for featured article content in mega-menu dropdowns.\n * Displays an image with a gradient overlay and headline text.\n * \n * **Usage:**\n * - Place in the `sidebar` slot of NavMenuNest\n * - Provide imageSrc, heading, and href props\n * \n * **Hover behavior:**\n * - Slight scale effect (1.02)\n * - Headline underline\n */\n@Component({\n tag: 'af-nav-card',\n styleUrl: 'af-nav-card.css',\n shadow: true\n})\nexport class AfNavCard {\n /**\n * The headline text displayed over the image\n */\n @Prop() heading?: string;\n\n /**\n * URL to navigate to when clicked\n */\n @Prop() href?: string;\n\n /**\n * Image source URL for the background\n */\n @Prop() imageSrc?: string;\n\n /**\n * Alternative text for the image\n */\n @Prop() imageAlt: string = '';\n\n @State() isHovered: boolean = false;\n\n private handleMouseEnter = () => {\n this.isHovered = true;\n };\n\n private handleMouseLeave = () => {\n this.isHovered = false;\n };\n\n render() {\n const classes = {\n 'nav-card': true,\n 'is-hovered': this.isHovered\n };\n\n const content = (\n <div\n class={classes}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n >\n <div class=\"image-container\">\n {this.imageSrc && (\n <img src={this.imageSrc} alt={this.imageAlt} class=\"card-image\" />\n )}\n </div>\n <div class=\"overlay\">\n {this.heading && (\n <h3 class=\"heading\">{this.heading}</h3>\n )}\n </div>\n </div>\n );\n\n if (this.href) {\n return (\n <Host>\n <a href={this.href} class=\"card-link\">\n {content}\n </a>\n </Host>\n );\n }\n\n return <Host>{content}</Host>;\n }\n}\n"],"names":[],"mappings":";;AAAA,MAAM,YAAY,GAAG,47BAA47B;;MCmBp8B,SAAS,GAAA,MAAA;AALtB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAqBE;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAW,EAAE;AAEpB,QAAA,IAAS,CAAA,SAAA,GAAY,KAAK;AAE3B,QAAA,IAAgB,CAAA,gBAAA,GAAG,MAAK;AAC9B,YAAA,IAAI,CAAC,SAAS,GAAG,IAAI;AACvB,SAAC;AAEO,QAAA,IAAgB,CAAA,gBAAA,GAAG,MAAK;AAC9B,YAAA,IAAI,CAAC,SAAS,GAAG,KAAK;AACxB,SAAC;AAuCF;IArCC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG;AACd,YAAA,UAAU,EAAE,IAAI;YAChB,YAAY,EAAE,IAAI,CAAC;SACpB;QAED,MAAM,OAAO,IACX,WACE,KAAK,EAAE,OAAO,EACd,YAAY,EAAE,IAAI,CAAC,gBAAgB,EACnC,YAAY,EAAE,IAAI,CAAC,gBAAgB,EAAA,EAEnC,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,iBAAiB,EACzB,EAAA,IAAI,CAAC,QAAQ,KACZ,CAAK,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAC,YAAY,EAAG,CAAA,CACnE,CACG,EACN,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,SAAS,EAAA,EACjB,IAAI,CAAC,OAAO,KACX,CAAI,CAAA,IAAA,EAAA,EAAA,KAAK,EAAC,SAAS,EAAA,EAAE,IAAI,CAAC,OAAO,CAAM,CACxC,CACG,CACF,CACP;AAED,QAAA,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,QACE,EAAC,IAAI,EAAA,IAAA,EACH,CAAA,CAAA,GAAA,EAAA,EAAG,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAC,WAAW,EAClC,EAAA,OAAO,CACN,CACC;;QAIX,OAAO,CAAC,CAAA,IAAI,EAAE,IAAA,EAAA,OAAO,CAAQ;;;;;;;"}
@@ -0,0 +1,41 @@
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afNavMenuNestCss = ":host{display:inline-block}.nav-menu-nest{display:inline-flex;background:var(--colour-background-base, #ffffff);border-radius:32px}.nav-menu-nest.breakpoint-desktop{flex-direction:row;align-items:stretch}.nav-menu-nest.breakpoint-desktop .menu-columns{display:flex;flex-direction:row;gap:32px;padding:24px 0 32px 40px}.nav-menu-nest.breakpoint-desktop .menu-sidebar{display:flex;flex-direction:column;padding:24px 40px 32px 32px}.nav-menu-nest.breakpoint-desktop .menu-sidebar ::slotted(af-nav-menu){padding-top:16px}.nav-menu-nest.breakpoint-desktop .menu-sidebar ::slotted(af-nav-card){margin-top:16px}.nav-menu-nest.breakpoint-desktop .menu-columns ::slotted(af-nav-menu){border-right:1px solid var(--colour-background-border-subtle, #e8eeed);padding-right:32px;padding-top:16px}.nav-menu-nest.breakpoint-desktop .menu-columns ::slotted(af-nav-menu:last-of-type){border-right:none;padding-right:0}:host([show-sidebar-border]) .nav-menu-nest.breakpoint-desktop .menu-columns ::slotted(af-nav-menu:last-of-type){border-right:1px solid var(--colour-background-border-heavy, #c6d5d1);padding-right:32px}.nav-menu-nest.breakpoint-mobile{flex-direction:column;border-radius:0}.nav-menu-nest.breakpoint-mobile .menu-columns{display:flex;flex-direction:column}.nav-menu-nest.breakpoint-mobile .menu-sidebar{display:flex;flex-direction:column;padding:32px 12px;border-top:1px solid var(--colour-background-border-subtle, #e8eeed)}.nav-menu-nest.breakpoint-mobile .menu-columns ::slotted(af-nav-menu){border-right:none;border-bottom:1px solid var(--colour-background-border-subtle, #e8eeed)}";
4
+
5
+ const AfNavMenuNest = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * The type/variant of the mega-menu
10
+ * - 'solutions': Multi-column layout (3 columns + sidebar)
11
+ * - 'solutions-alt': Alternative solutions layout
12
+ * - 'resources': Multi-column layout with optional featured card
13
+ * - 'pricing': Simpler layout without sidebar
14
+ */
15
+ this.type = 'solutions';
16
+ /**
17
+ * Breakpoint variant for responsive styling
18
+ * - 'desktop': Horizontal multi-column layout
19
+ * - 'mobile': Vertical stacked layout
20
+ */
21
+ this.breakpoint = 'desktop';
22
+ /**
23
+ * Whether to show the heavier border on the last column (before sidebar).
24
+ * Set to `true` when sidebar has content, `false` when no sidebar.
25
+ * When `false`, the last column has no border.
26
+ */
27
+ this.showSidebarBorder = true;
28
+ }
29
+ render() {
30
+ const classes = {
31
+ 'nav-menu-nest': true,
32
+ [`type-${this.type}`]: true,
33
+ [`breakpoint-${this.breakpoint}`]: true
34
+ };
35
+ return (h(Host, { key: '238b95cdf9c910302351b6dc07fb8c4dff386168' }, h("div", { key: '7cc941c220c635d6d22520d792122eaad98864ca', class: classes }, h("div", { key: 'b5437b4a10a1bc01ff23117e56928a96ed8e1f9e', class: "menu-columns" }, h("slot", { key: 'ab9d8520730622ee52c8d8d095d6bd5ef0b10419' })), h("div", { key: '1a859f0c957850a52fc4c24873bc4960ad8a96f3', class: "menu-sidebar" }, h("slot", { key: 'ca7ed122f10996d06bce10c6d80281283ef12a62', name: "sidebar" })))));
36
+ }
37
+ };
38
+ AfNavMenuNest.style = afNavMenuNestCss;
39
+
40
+ export { AfNavMenuNest as af_nav_menu_nest };
41
+ //# sourceMappingURL=af-nav-menu-nest.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-nav-menu-nest.entry.js","sources":["src/components/af-nav-menu-nest/af-nav-menu-nest.css?tag=af-nav-menu-nest&encapsulation=shadow","src/components/af-nav-menu-nest/af-nav-menu-nest.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.nav-menu-nest {\n display: inline-flex;\n background: var(--colour-background-base, #ffffff);\n border-radius: 32px;\n}\n\n/* Desktop layout */\n.nav-menu-nest.breakpoint-desktop {\n flex-direction: row;\n align-items: stretch;\n}\n\n.nav-menu-nest.breakpoint-desktop .menu-columns {\n display: flex;\n flex-direction: row;\n gap: 32px;\n padding: 24px 0 32px 40px;\n}\n\n.nav-menu-nest.breakpoint-desktop .menu-sidebar {\n display: flex;\n flex-direction: column;\n padding: 24px 40px 32px 32px;\n}\n\n/* Slotted content in sidebar - match column spacing */\n.nav-menu-nest.breakpoint-desktop .menu-sidebar ::slotted(af-nav-menu) {\n padding-top: 16px;\n}\n\n.nav-menu-nest.breakpoint-desktop .menu-sidebar ::slotted(af-nav-card) {\n margin-top: 16px;\n}\n\n/* Slotted NavMenu in columns - add border and spacing */\n.nav-menu-nest.breakpoint-desktop .menu-columns ::slotted(af-nav-menu) {\n border-right: 1px solid var(--colour-background-border-subtle, #e8eeed);\n padding-right: 32px;\n padding-top: 16px;\n}\n\n/* Last NavMenu in columns - no border by default */\n.nav-menu-nest.breakpoint-desktop .menu-columns ::slotted(af-nav-menu:last-of-type) {\n border-right: none;\n padding-right: 0;\n}\n\n/* When showSidebarBorder is true, last column gets heavier border */\n:host([show-sidebar-border]) .nav-menu-nest.breakpoint-desktop .menu-columns ::slotted(af-nav-menu:last-of-type) {\n border-right: 1px solid var(--colour-background-border-heavy, #c6d5d1);\n padding-right: 32px;\n}\n\n/* Mobile layout */\n.nav-menu-nest.breakpoint-mobile {\n flex-direction: column;\n border-radius: 0;\n}\n\n.nav-menu-nest.breakpoint-mobile .menu-columns {\n display: flex;\n flex-direction: column;\n}\n\n.nav-menu-nest.breakpoint-mobile .menu-sidebar {\n display: flex;\n flex-direction: column;\n padding: 32px 12px;\n border-top: 1px solid var(--colour-background-border-subtle, #e8eeed);\n}\n\n.nav-menu-nest.breakpoint-mobile .menu-columns ::slotted(af-nav-menu) {\n border-right: none;\n border-bottom: 1px solid var(--colour-background-border-subtle, #e8eeed);\n}\n","import { Component, h, Prop, Host } from '@stencil/core';\n\n/**\n * A mega-menu dropdown panel component.\n * Acts as a container for NavMenu columns and optionally a sidebar.\n * Used as the dropdown content for navbar items.\n * \n * **Slots:**\n * - default: Place NavMenu components here - they will be displayed as columns\n * - sidebar: Optional sidebar content (NavMenu, NavCard, or any content)\n * \n * **Example:**\n * ```html\n * <af-nav-menu-nest type=\"solutions\" breakpoint=\"desktop\">\n * <af-nav-menu heading=\"Industries\">...</af-nav-menu>\n * <af-nav-menu heading=\"Use Cases\">...</af-nav-menu>\n * <af-nav-menu heading=\"Documents\">...</af-nav-menu>\n * <af-nav-menu slot=\"sidebar\" heading=\"Resume Parser\">...</af-nav-menu>\n * </af-nav-menu-nest>\n * ```\n */\n@Component({\n tag: 'af-nav-menu-nest',\n styleUrl: 'af-nav-menu-nest.css',\n shadow: true\n})\nexport class AfNavMenuNest {\n /**\n * The type/variant of the mega-menu\n * - 'solutions': Multi-column layout (3 columns + sidebar)\n * - 'solutions-alt': Alternative solutions layout\n * - 'resources': Multi-column layout with optional featured card\n * - 'pricing': Simpler layout without sidebar\n */\n @Prop() type: 'solutions' | 'solutions-alt' | 'resources' | 'pricing' = 'solutions';\n\n /**\n * Breakpoint variant for responsive styling\n * - 'desktop': Horizontal multi-column layout\n * - 'mobile': Vertical stacked layout\n */\n @Prop() breakpoint: 'desktop' | 'mobile' = 'desktop';\n\n /**\n * Whether to show the heavier border on the last column (before sidebar).\n * Set to `true` when sidebar has content, `false` when no sidebar.\n * When `false`, the last column has no border.\n */\n @Prop({ reflect: true }) showSidebarBorder: boolean = true;\n\n render() {\n const classes = {\n 'nav-menu-nest': true,\n [`type-${this.type}`]: true,\n [`breakpoint-${this.breakpoint}`]: true\n };\n\n return (\n <Host>\n <div class={classes}>\n <div class=\"menu-columns\">\n <slot></slot>\n </div>\n <div class=\"menu-sidebar\">\n <slot name=\"sidebar\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":[],"mappings":";;AAAA,MAAM,gBAAgB,GAAG,kjDAAkjD;;MC0B9jD,aAAa,GAAA,MAAA;AAL1B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;;;;;AAMG;AACK,QAAA,IAAI,CAAA,IAAA,GAA4D,WAAW;AAEnF;;;;AAIG;AACK,QAAA,IAAU,CAAA,UAAA,GAAyB,SAAS;AAEpD;;;;AAIG;AACsB,QAAA,IAAiB,CAAA,iBAAA,GAAY,IAAI;AAsB3D;IApBC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG;AACd,YAAA,eAAe,EAAE,IAAI;AACrB,YAAA,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAE,CAAA,GAAG,IAAI;AAC3B,YAAA,CAAC,cAAc,IAAI,CAAC,UAAU,CAAE,CAAA,GAAG;SACpC;AAED,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,OAAO,EAAA,EACjB,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,cAAc,EAAA,EACvB,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa,CACT,EACN,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,cAAc,EAAA,EACvB,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,SAAS,EAAA,CAAQ,CACxB,CACF,CACD;;;;;;;"}
@@ -0,0 +1,39 @@
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afNavMenuCss = ":host{display:block}.nav-menu{display:flex;flex-direction:column;gap:16px;align-items:flex-start;min-height:1px;min-width:1px}.nav-menu.breakpoint-desktop{padding:0;flex:1 0 0;align-self:stretch}.nav-menu.breakpoint-desktop.has-border{border-right:1px solid var(--colour-background-border-subtle, #e8eeed);padding-right:32px;padding-top:16px}.nav-menu.breakpoint-mobile{padding:32px 12px;width:100%;border-bottom:1px solid var(--colour-background-border-subtle, #e8eeed)}.menu-header{display:flex;gap:16px;align-items:center;width:100%}.menu-heading{margin:0;font-family:var(--typography-headingfont, 'NeuSans', 'Inter', system-ui, sans-serif);font-weight:var(--font-weight-book, 500);font-size:20px;line-height:1.2;letter-spacing:-0.4px;color:var(--colour-typography-heading-secondary, #8a7049);flex:1 0 0;min-height:1px;min-width:1px}.nav-menu.breakpoint-mobile .menu-heading{line-height:1.1}.menu-items{display:flex;flex-direction:column;align-items:flex-start;width:100%}.nav-menu.breakpoint-mobile .menu-items{padding-left:24px}::slotted(af-nav-item){width:100%}.nav-menu.card-style{background:var(--colour-background-level-1, #e8eeed);border-radius:var(--radii-card-level-1, 32px);padding:40px}.nav-menu.card-style.breakpoint-desktop{flex:1 0 0;align-self:stretch}";
4
+
5
+ const AfNavMenu = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * Breakpoint variant for responsive styling
10
+ * - 'desktop': Desktop-specific styles (right border, horizontal padding)
11
+ * - 'mobile': Mobile-specific styles (bottom border, vertical layout)
12
+ */
13
+ this.breakpoint = 'desktop';
14
+ /**
15
+ * Whether to show the right border separator.
16
+ * When used inside NavMenuNest, borders are controlled by the parent.
17
+ * Set to true only when using NavMenu standalone.
18
+ */
19
+ this.showBorder = false;
20
+ /**
21
+ * Whether to display as a card with background color and rounded corners.
22
+ * Used for highlighted sidebar menus (e.g., solutions-alt variant).
23
+ */
24
+ this.cardStyle = false;
25
+ }
26
+ render() {
27
+ const classes = {
28
+ 'nav-menu': true,
29
+ [`breakpoint-${this.breakpoint}`]: true,
30
+ 'has-border': this.showBorder,
31
+ 'card-style': this.cardStyle
32
+ };
33
+ return (h(Host, { key: '25d24de982df9e0bb085023f15a0ccc99dd68987' }, h("div", { key: 'c473e5e58df5a6300bc9f7087b4ed98126d2c178', class: classes }, this.heading && (h("div", { key: '6f080b0dd068463bde77f72a0b07dace7af4a248', class: "menu-header" }, h("h3", { key: '77f1ac6ecb8c877dc6d3b6bb0e1a37617f322175', class: "menu-heading" }, this.heading))), h("div", { key: 'f8cf91ec5aa5b31e8171d98a7c7e5c4e1e977f5e', class: "menu-items" }, h("slot", { key: 'd7bd3a85725fc817c2d9110cc315d5b57837c636' })))));
34
+ }
35
+ };
36
+ AfNavMenu.style = afNavMenuCss;
37
+
38
+ export { AfNavMenu as af_nav_menu };
39
+ //# sourceMappingURL=af-nav-menu.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-nav-menu.entry.js","sources":["src/components/af-nav-menu/af-nav-menu.css?tag=af-nav-menu&encapsulation=shadow","src/components/af-nav-menu/af-nav-menu.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.nav-menu {\n display: flex;\n flex-direction: column;\n gap: 16px;\n align-items: flex-start;\n min-height: 1px;\n min-width: 1px;\n}\n\n/* Desktop styles */\n.nav-menu.breakpoint-desktop {\n padding: 0;\n flex: 1 0 0;\n align-self: stretch;\n}\n\n/* Border is now controlled by parent NavMenuNest via ::slotted()\n Use showBorder prop only when NavMenu is used standalone */\n.nav-menu.breakpoint-desktop.has-border {\n border-right: 1px solid var(--colour-background-border-subtle, #e8eeed);\n padding-right: 32px;\n padding-top: 16px;\n}\n\n/* Mobile styles */\n.nav-menu.breakpoint-mobile {\n padding: 32px 12px;\n width: 100%;\n border-bottom: 1px solid var(--colour-background-border-subtle, #e8eeed);\n}\n\n/* Menu header */\n.menu-header {\n display: flex;\n gap: 16px;\n align-items: center;\n width: 100%;\n}\n\n.menu-heading {\n margin: 0;\n font-family: var(--typography-headingfont, 'NeuSans', 'Inter', system-ui, sans-serif);\n font-weight: var(--font-weight-book, 500);\n font-size: 20px;\n line-height: 1.2;\n letter-spacing: -0.4px;\n color: var(--colour-typography-heading-secondary, #8a7049);\n flex: 1 0 0;\n min-height: 1px;\n min-width: 1px;\n}\n\n/* Mobile heading adjustments */\n.nav-menu.breakpoint-mobile .menu-heading {\n line-height: 1.1;\n}\n\n/* Menu items container */\n.menu-items {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n width: 100%;\n}\n\n/* Mobile items with left padding */\n.nav-menu.breakpoint-mobile .menu-items {\n padding-left: 24px;\n}\n\n/* Slot styling for nav-items */\n::slotted(af-nav-item) {\n width: 100%;\n}\n\n/* Card style variant - adds background and rounded corners */\n.nav-menu.card-style {\n background: var(--colour-background-level-1, #e8eeed);\n border-radius: var(--radii-card-level-1, 32px);\n padding: 40px;\n}\n\n.nav-menu.card-style.breakpoint-desktop {\n flex: 1 0 0;\n align-self: stretch;\n}\n\n","import { Component, h, Prop, Host } from '@stencil/core';\n\n/**\n * A grouped navigation menu component with a heading.\n * Used in mega-menu dropdowns to group related navigation items.\n */\n@Component({\n tag: 'af-nav-menu',\n styleUrl: 'af-nav-menu.css',\n shadow: true\n})\nexport class AfNavMenu {\n /**\n * The heading text displayed above the navigation items\n */\n @Prop() heading?: string;\n\n /**\n * Breakpoint variant for responsive styling\n * - 'desktop': Desktop-specific styles (right border, horizontal padding)\n * - 'mobile': Mobile-specific styles (bottom border, vertical layout)\n */\n @Prop() breakpoint: 'desktop' | 'mobile' = 'desktop';\n\n /**\n * Whether to show the right border separator.\n * When used inside NavMenuNest, borders are controlled by the parent.\n * Set to true only when using NavMenu standalone.\n */\n @Prop() showBorder: boolean = false;\n\n /**\n * Whether to display as a card with background color and rounded corners.\n * Used for highlighted sidebar menus (e.g., solutions-alt variant).\n */\n @Prop({ reflect: true }) cardStyle: boolean = false;\n\n render() {\n const classes = {\n 'nav-menu': true,\n [`breakpoint-${this.breakpoint}`]: true,\n 'has-border': this.showBorder,\n 'card-style': this.cardStyle\n };\n\n return (\n <Host>\n <div class={classes}>\n {this.heading && (\n <div class=\"menu-header\">\n <h3 class=\"menu-heading\">{this.heading}</h3>\n </div>\n )}\n <div class=\"menu-items\">\n <slot></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,YAAY,GAAG,wvCAAwvC;;MCWhwC,SAAS,GAAA,MAAA;AALtB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAWE;;;;AAIG;AACK,QAAA,IAAU,CAAA,UAAA,GAAyB,SAAS;AAEpD;;;;AAIG;AACK,QAAA,IAAU,CAAA,UAAA,GAAY,KAAK;AAEnC;;;AAGG;AACsB,QAAA,IAAS,CAAA,SAAA,GAAY,KAAK;AAyBpD;IAvBC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG;AACd,YAAA,UAAU,EAAE,IAAI;AAChB,YAAA,CAAC,cAAc,IAAI,CAAC,UAAU,CAAE,CAAA,GAAG,IAAI;YACvC,YAAY,EAAE,IAAI,CAAC,UAAU;YAC7B,YAAY,EAAE,IAAI,CAAC;SACpB;QAED,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,OAAO,EAAA,EAChB,IAAI,CAAC,OAAO,KACX,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,aAAa,EAAA,EACtB,CAAI,CAAA,IAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,cAAc,EAAA,EAAE,IAAI,CAAC,OAAO,CAAM,CACxC,CACP,EACD,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,YAAY,EAAA,EACrB,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa,CACT,CACF,CACD;;;;;;;"}
@@ -0,0 +1,40 @@
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afNumberBadgeCss = ":host{display:inline-flex;align-items:center;justify-content:center;line-height:1;user-select:none;flex-shrink:0}.badge{display:inline-flex;align-items:center;justify-content:center;font-family:var(--af-font-family-sans, 'NeuSans', Arial, sans-serif);font-weight:500}.badge.variant-inCircle{border-radius:50%;background-color:var(--af-color-brand-soft-clay, #B09670);color:var(--af-color-brand-inkwell, #14343B)}.badge.variant-outlined{background-color:transparent;color:var(--af-color-brand-mist-green, #C6D5D1)}";
4
+
5
+ const AfNumberBadge = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * The number to display (1-10)
10
+ */
11
+ this.number = 1;
12
+ /**
13
+ * Visual variant of the badge
14
+ * - `inCircle` - Number in filled soft-clay circle
15
+ * - `outlined` - Number text only in mist-green
16
+ */
17
+ this.variant = 'inCircle';
18
+ /**
19
+ * Size of the badge in pixels
20
+ */
21
+ this.size = 48;
22
+ }
23
+ render() {
24
+ const isInCircle = this.variant === 'inCircle';
25
+ const fontSize = isInCircle ? this.size * 0.4 : this.size * 0.8;
26
+ const badgeStyle = {
27
+ width: `${this.size}px`,
28
+ height: `${this.size}px`,
29
+ fontSize: `${fontSize}px`,
30
+ };
31
+ return (h(Host, { key: '8b3d22147d452da450899cb2853957d601d321cb', role: "img", "aria-label": `Number ${this.number}${isInCircle ? ' badge' : ''}` }, h("span", { key: 'de26b2d9ad6139ecb2ebe764020577f9887ececf', class: {
32
+ 'badge': true,
33
+ [`variant-${this.variant}`]: true,
34
+ }, style: badgeStyle }, this.number)));
35
+ }
36
+ };
37
+ AfNumberBadge.style = afNumberBadgeCss;
38
+
39
+ export { AfNumberBadge as af_number_badge };
40
+ //# sourceMappingURL=af-number-badge.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-number-badge.entry.js","sources":["src/components/af-number-badge/af-number-badge.css?tag=af-number-badge&encapsulation=shadow","src/components/af-number-badge/af-number-badge.tsx"],"sourcesContent":[":host {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n line-height: 1;\n user-select: none;\n flex-shrink: 0;\n}\n\n.badge {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n font-family: var(--af-font-family-sans, 'NeuSans', Arial, sans-serif);\n font-weight: 500;\n}\n\n/* In Circle variant - filled soft-clay circle */\n.badge.variant-inCircle {\n border-radius: 50%;\n background-color: var(--af-color-brand-soft-clay, #B09670);\n color: var(--af-color-brand-inkwell, #14343B);\n}\n\n/* Outlined variant - text only in mist-green */\n.badge.variant-outlined {\n background-color: transparent;\n color: var(--af-color-brand-mist-green, #C6D5D1);\n}\n\n","import { Component, h, Prop, Host } from '@stencil/core';\n\nexport type NumberBadgeNumber = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10;\nexport type NumberBadgeVariant = 'inCircle' | 'outlined';\n\n/**\n * NumberBadge displays numbers 1-10 in either a filled circle or text-only style.\n * Perfect for numbered lists, step indicators, or ordered content.\n * \n * @example\n * ```html\n * <af-number-badge number=\"1\" variant=\"inCircle\" size=\"48\"></af-number-badge>\n * <af-number-badge number=\"5\" variant=\"outlined\" size=\"32\"></af-number-badge>\n * ```\n */\n@Component({\n tag: 'af-number-badge',\n styleUrl: 'af-number-badge.css',\n shadow: true\n})\nexport class AfNumberBadge {\n /**\n * The number to display (1-10)\n */\n @Prop() number: NumberBadgeNumber = 1;\n\n /**\n * Visual variant of the badge\n * - `inCircle` - Number in filled soft-clay circle\n * - `outlined` - Number text only in mist-green\n */\n @Prop() variant: NumberBadgeVariant = 'inCircle';\n\n /**\n * Size of the badge in pixels\n */\n @Prop() size: number = 48;\n\n render() {\n const isInCircle = this.variant === 'inCircle';\n const fontSize = isInCircle ? this.size * 0.4 : this.size * 0.8;\n\n const badgeStyle = {\n width: `${this.size}px`,\n height: `${this.size}px`,\n fontSize: `${fontSize}px`,\n };\n\n return (\n <Host\n role=\"img\"\n aria-label={`Number ${this.number}${isInCircle ? ' badge' : ''}`}\n >\n <span\n class={{\n 'badge': true,\n [`variant-${this.variant}`]: true,\n }}\n style={badgeStyle}\n >\n {this.number}\n </span>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,gBAAgB,GAAG,mgBAAmgB;;MCoB/gB,aAAa,GAAA,MAAA;AAL1B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;AAEG;AACK,QAAA,IAAM,CAAA,MAAA,GAAsB,CAAC;AAErC;;;;AAIG;AACK,QAAA,IAAO,CAAA,OAAA,GAAuB,UAAU;AAEhD;;AAEG;AACK,QAAA,IAAI,CAAA,IAAA,GAAW,EAAE;AA6B1B;IA3BC,MAAM,GAAA;AACJ,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,KAAK,UAAU;AAC9C,QAAA,MAAM,QAAQ,GAAG,UAAU,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG;AAE/D,QAAA,MAAM,UAAU,GAAG;AACjB,YAAA,KAAK,EAAE,CAAA,EAAG,IAAI,CAAC,IAAI,CAAI,EAAA,CAAA;AACvB,YAAA,MAAM,EAAE,CAAA,EAAG,IAAI,CAAC,IAAI,CAAI,EAAA,CAAA;YACxB,QAAQ,EAAE,CAAG,EAAA,QAAQ,CAAI,EAAA,CAAA;SAC1B;AAED,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EACH,IAAI,EAAC,KAAK,EACE,YAAA,EAAA,CAAU,OAAA,EAAA,IAAI,CAAC,MAAM,CAAA,EAAG,UAAU,GAAG,QAAQ,GAAG,EAAE,EAAE,EAAA,EAEhE,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,OAAO,EAAE,IAAI;AACb,gBAAA,CAAC,WAAW,IAAI,CAAC,OAAO,CAAE,CAAA,GAAG,IAAI;aAClC,EACD,KAAK,EAAE,UAAU,EAEhB,EAAA,IAAI,CAAC,MAAM,CACP,CACF;;;;;;;"}
@@ -0,0 +1,31 @@
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afProgressLineCss = ".sc-af-progress-line-h{display:block;width:100%}.progress-line.sc-af-progress-line{position:relative;overflow:hidden}.progress-line--horizontal.sc-af-progress-line{height:3px;width:100%}.progress-line__background.sc-af-progress-line{position:absolute;inset:0;background:var(--af-background-border-default, var(--colour-background-border-default, #d1ddda));height:1px;top:50%;transform:translateY(-50%)}.progress-line__active.sc-af-progress-line{position:relative;height:100%;min-width:1px;background:var(--af-background-border-active, var(--colour-background-border-active, #8a7049));transition:width 0.15s ease-out}";
4
+
5
+ const AfProgressLine = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * Progress value from 0 to 1 (0 = 0%, 1 = 100%).
10
+ */
11
+ this.progress = 0;
12
+ /**
13
+ * Orientation of the progress line.
14
+ * Currently only horizontal is supported.
15
+ */
16
+ this.orientation = 'horizontal';
17
+ }
18
+ render() {
19
+ // Clamp progress between 0 and 1
20
+ const clampedProgress = Math.max(0, Math.min(1, this.progress));
21
+ const progressPercent = clampedProgress * 100;
22
+ return (h(Host, { key: '0b5f1dccd9d5d3d80a68dbecd7c78e9c7ba1e9eb' }, h("div", { key: '70083ced351eeed528c93787c47299af86edf693', class: {
23
+ 'progress-line': true,
24
+ [`progress-line--${this.orientation}`]: true,
25
+ }, role: "progressbar", "aria-valuenow": Math.round(progressPercent), "aria-valuemin": 0, "aria-valuemax": 100 }, h("div", { key: '6a37704b7183543b589a872c44413fafc6a643dc', class: "progress-line__background" }), h("div", { key: 'ff7cee0f9e117e3ea346d195126c635d86efc5da', class: "progress-line__active", style: { width: `${progressPercent}%` } }))));
26
+ }
27
+ };
28
+ AfProgressLine.style = afProgressLineCss;
29
+
30
+ export { AfProgressLine as af_progress_line };
31
+ //# sourceMappingURL=af-progress-line.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-progress-line.entry.js","sources":["src/components/af-progress-line/af-progress-line.css?tag=af-progress-line&encapsulation=scoped","src/components/af-progress-line/af-progress-line.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n/* ==========================================================================\n Progress Line Base Styles\n ========================================================================== */\n\n.progress-line {\n position: relative;\n overflow: hidden;\n}\n\n.progress-line--horizontal {\n height: 3px;\n width: 100%;\n}\n\n/* ==========================================================================\n Background Track\n ========================================================================== */\n\n.progress-line__background {\n position: absolute;\n inset: 0;\n background: var(--af-background-border-default, var(--colour-background-border-default, #d1ddda));\n height: 1px;\n top: 50%;\n transform: translateY(-50%);\n}\n\n/* ==========================================================================\n Active Progress\n ========================================================================== */\n\n.progress-line__active {\n position: relative;\n height: 100%;\n min-width: 1px;\n background: var(--af-background-border-active, var(--colour-background-border-active, #8a7049));\n transition: width 0.15s ease-out;\n}\n\n","import { Component, Prop, h, Host } from '@stencil/core';\n\n/**\n * Progress Line atom component for displaying scroll or completion progress.\n * \n * Shows a horizontal bar with a filled portion indicating progress.\n * Used primarily for carousel scroll indicators.\n */\n@Component({\n tag: 'af-progress-line',\n styleUrl: 'af-progress-line.css',\n shadow: false,\n scoped: true,\n})\nexport class AfProgressLine {\n /**\n * Progress value from 0 to 1 (0 = 0%, 1 = 100%).\n */\n @Prop() progress: number = 0;\n\n /**\n * Orientation of the progress line.\n * Currently only horizontal is supported.\n */\n @Prop() orientation: 'horizontal' = 'horizontal';\n\n render() {\n // Clamp progress between 0 and 1\n const clampedProgress = Math.max(0, Math.min(1, this.progress));\n const progressPercent = clampedProgress * 100;\n\n return (\n <Host>\n <div\n class={{\n 'progress-line': true,\n [`progress-line--${this.orientation}`]: true,\n }}\n role=\"progressbar\"\n aria-valuenow={Math.round(progressPercent)}\n aria-valuemin={0}\n aria-valuemax={100}\n >\n <div class=\"progress-line__background\" />\n <div\n class=\"progress-line__active\"\n style={{ width: `${progressPercent}%` }}\n />\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,iBAAiB,GAAG,0mBAA0mB;;MCcvnB,cAAc,GAAA,MAAA;AAN3B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAOE;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAW,CAAC;AAE5B;;;AAGG;AACK,QAAA,IAAW,CAAA,WAAA,GAAiB,YAAY;AA4BjD;IA1BC,MAAM,GAAA;;AAEJ,QAAA,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;AAC/D,QAAA,MAAM,eAAe,GAAG,eAAe,GAAG,GAAG;QAE7C,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,eAAe,EAAE,IAAI;AACrB,gBAAA,CAAC,kBAAkB,IAAI,CAAC,WAAW,CAAE,CAAA,GAAG,IAAI;AAC7C,aAAA,EACD,IAAI,EAAC,aAAa,EAAA,eAAA,EACH,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,EAC3B,eAAA,EAAA,CAAC,mBACD,GAAG,EAAA,EAElB,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,2BAA2B,EAAG,CAAA,EACzC,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAC,uBAAuB,EAC7B,KAAK,EAAE,EAAE,KAAK,EAAE,CAAG,EAAA,eAAe,CAAG,CAAA,CAAA,EAAE,GACvC,CACE,CACD;;;;;;;"}
@@ -0,0 +1,41 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afRadioCss = ":host{display:inline-block}.radio{display:inline-flex;align-items:center;gap:12px;cursor:pointer;font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;line-height:20px;color:var(--buttons-ghost-text, var(--colour-brand-inkwell, #14343b));user-select:none}.radio.disabled{cursor:not-allowed;opacity:0.5}.input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.control{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px;border-radius:var(--radii-radio, 9999px);border:1px solid var(--forms-control-stroke, #d0d6d8);background:var(--forms-control-bg-default, #ffffff);transition:all 0.15s ease;box-sizing:border-box}.control.checked{background:var(--forms-control-bg-active, var(--colour-brand-inkwell, #14343b));border-color:var(--forms-control-bg-active, var(--colour-brand-inkwell, #14343b))}.control.disabled{background:var(--forms-control-bg-default-disabled, #e8ebeb);border-color:var(--forms-control-stroke-disabled, #d0d6d8)}.control.checked.disabled{background:var(--forms-control-bg-active-disabled, #708380);border-color:var(--forms-control-bg-active-disabled, #708380)}.radio:not(.disabled):hover .control{border-color:var(--forms-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.input:focus-visible+.control{box-shadow:0 0 0 4px var(--background-base, #ffffff), 0 0 0 5px var(--buttons-secondary-stroke, #14343b);outline:none}.dot{width:8px;height:8px;border-radius:50%;background:#ffffff}.label{display:flex;align-items:center;min-height:24px}.label:empty{display:none}";
4
+
5
+ const AfRadio = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ this.afChange = createEvent(this, "afChange");
9
+ /**
10
+ * Whether the radio is checked
11
+ */
12
+ this.checked = false;
13
+ /**
14
+ * Whether the radio is disabled
15
+ */
16
+ this.disabled = false;
17
+ this.handleChange = () => {
18
+ if (this.disabled || this.checked)
19
+ return;
20
+ this.checked = true;
21
+ this.afChange.emit({ checked: this.checked, value: this.value });
22
+ };
23
+ }
24
+ render() {
25
+ const radioClasses = {
26
+ 'radio': true,
27
+ 'checked': this.checked,
28
+ 'disabled': this.disabled
29
+ };
30
+ const controlClasses = {
31
+ 'control': true,
32
+ 'checked': this.checked,
33
+ 'disabled': this.disabled
34
+ };
35
+ return (h(Host, { key: '6adcdfda7127638527a30f9289f9cd240ec1e11d' }, h("label", { key: '9366569dd10eeeca7f3c3a616b0f523efd3208ec', class: radioClasses }, h("input", { key: '4b63b4285d65e42fc04c9f1f2e02e82abcf71018', type: "radio", class: "input", checked: this.checked, disabled: this.disabled, name: this.name, value: this.value, onChange: this.handleChange }), h("span", { key: '2e9fa65ff49c95948e6ac3e791f31a8f51f4b0ba', class: controlClasses }, this.checked && (h("span", { key: 'efda09c196af4b1a33bba4da56d3036ee8545905', class: "dot" }))), h("span", { key: 'faf8a3d424418f987d9561d9d903068ce865a494', class: "label" }, h("slot", { key: '9b7d84b6eab1f908708bca461cd49eda3737435b' })))));
36
+ }
37
+ };
38
+ AfRadio.style = afRadioCss;
39
+
40
+ export { AfRadio as af_radio };
41
+ //# sourceMappingURL=af-radio.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-radio.entry.js","sources":["src/components/af-radio/af-radio.css?tag=af-radio&encapsulation=shadow","src/components/af-radio/af-radio.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.radio {\n display: inline-flex;\n align-items: center;\n gap: 12px;\n cursor: pointer;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-size: 14px;\n line-height: 20px;\n color: var(--buttons-ghost-text, var(--colour-brand-inkwell, #14343b));\n user-select: none;\n}\n\n.radio.disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n/* Hidden native input */\n.input {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n\n/* Custom radio control */\n.control {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n width: 20px;\n height: 20px;\n border-radius: var(--radii-radio, 9999px);\n border: 1px solid var(--forms-control-stroke, #d0d6d8);\n background: var(--forms-control-bg-default, #ffffff);\n transition: all 0.15s ease;\n box-sizing: border-box;\n}\n\n/* Checked state */\n.control.checked {\n background: var(--forms-control-bg-active, var(--colour-brand-inkwell, #14343b));\n border-color: var(--forms-control-bg-active, var(--colour-brand-inkwell, #14343b));\n}\n\n/* Disabled state */\n.control.disabled {\n background: var(--forms-control-bg-default-disabled, #e8ebeb);\n border-color: var(--forms-control-stroke-disabled, #d0d6d8);\n}\n\n.control.checked.disabled {\n background: var(--forms-control-bg-active-disabled, #708380);\n border-color: var(--forms-control-bg-active-disabled, #708380);\n}\n\n/* Hover state */\n.radio:not(.disabled):hover .control {\n border-color: var(--forms-control-stroke-hover, var(--colour-brand-inkwell, #14343b));\n}\n\n/* Focus state */\n.input:focus-visible + .control {\n box-shadow: 0 0 0 4px var(--background-base, #ffffff), 0 0 0 5px var(--buttons-secondary-stroke, #14343b);\n outline: none;\n}\n\n/* Inner dot */\n.dot {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: #ffffff;\n}\n\n/* Label styling */\n.label {\n display: flex;\n align-items: center;\n min-height: 24px;\n}\n\n/* Empty label - hide if no content */\n.label:empty {\n display: none;\n}\n\n","import { Component, h, Prop, Host, Event, EventEmitter } from '@stencil/core';\n\n/**\n * Radio component for selecting a single option from a group.\n * \n * @slot - Radio label text\n */\n@Component({\n tag: 'af-radio',\n styleUrl: 'af-radio.css',\n shadow: true\n})\nexport class AfRadio {\n /**\n * Whether the radio is checked\n */\n @Prop({ mutable: true, reflect: true }) checked: boolean = false;\n\n /**\n * Whether the radio is disabled\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * The name of the radio for form submission (radios with same name are grouped)\n */\n @Prop() name?: string;\n\n /**\n * The value of the radio for form submission\n */\n @Prop() value?: string;\n\n /**\n * Emitted when the radio checked state changes\n */\n @Event() afChange!: EventEmitter<{ checked: boolean; value?: string }>;\n\n private handleChange = () => {\n if (this.disabled || this.checked) return;\n this.checked = true;\n this.afChange.emit({ checked: this.checked, value: this.value });\n };\n\n render() {\n const radioClasses = {\n 'radio': true,\n 'checked': this.checked,\n 'disabled': this.disabled\n };\n\n const controlClasses = {\n 'control': true,\n 'checked': this.checked,\n 'disabled': this.disabled\n };\n\n return (\n <Host>\n <label class={radioClasses}>\n <input\n type=\"radio\"\n class=\"input\"\n checked={this.checked}\n disabled={this.disabled}\n name={this.name}\n value={this.value}\n onChange={this.handleChange}\n />\n <span class={controlClasses}>\n {this.checked && (\n <span class=\"dot\"></span>\n )}\n </span>\n <span class=\"label\">\n <slot></slot>\n </span>\n </label>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,UAAU,GAAG,umDAAumD;;MCY7mD,OAAO,GAAA,MAAA;AALpB,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAME;;AAEG;AACqC,QAAA,IAAO,CAAA,OAAA,GAAY,KAAK;AAEhE;;AAEG;AACsB,QAAA,IAAQ,CAAA,QAAA,GAAY,KAAK;AAiB1C,QAAA,IAAY,CAAA,YAAA,GAAG,MAAK;AAC1B,YAAA,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO;gBAAE;AACnC,YAAA,IAAI,CAAC,OAAO,GAAG,IAAI;AACnB,YAAA,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;AAClE,SAAC;AAuCF;IArCC,MAAM,GAAA;AACJ,QAAA,MAAM,YAAY,GAAG;AACnB,YAAA,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,IAAI,CAAC,OAAO;YACvB,UAAU,EAAE,IAAI,CAAC;SAClB;AAED,QAAA,MAAM,cAAc,GAAG;AACrB,YAAA,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,IAAI,CAAC,OAAO;YACvB,UAAU,EAAE,IAAI,CAAC;SAClB;AAED,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAO,CAAA,OAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,YAAY,EAAA,EACxB,CAAA,CAAA,OAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,IAAI,EAAC,OAAO,EACZ,KAAK,EAAC,OAAO,EACb,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,YAAY,EAC3B,CAAA,EACF,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAM,KAAK,EAAE,cAAc,EAAA,EACxB,IAAI,CAAC,OAAO,KACX,6DAAM,KAAK,EAAC,KAAK,EAAA,CAAQ,CAC1B,CACI,EACP,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,OAAO,EAAA,EACjB,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa,CACR,CACD,CACH;;;;;;;"}
@@ -1,20 +1,20 @@
1
- import { r as registerInstance, h, H as Host } from './index-DI7b0bCy.js';
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
2
 
3
- const afSectionCss = ".sc-af-section-h{display:block;width:100%}.section.sc-af-section{width:100%;position:relative}.padding-tight.sc-af-section{padding:48px 0}.padding-default.sc-af-section{padding:96px 0}.padding-loose.sc-af-section{padding:120px 0 96px}.bg-white.sc-af-section{background-color:var(--colour-background-white, #FFFFFF)}.bg-level1.sc-af-section{background-color:var(--colour-background-level-1, #E8EEED)}.bg-dark.sc-af-section,.bg-inkwell.sc-af-section{background-color:var(--colour-brand-inkwell, #14343B);--colour-typography-heading-primary:var(--colour-brand-mist-green, #C6D5D1);--colour-typography-body-default:var(--colour-brand-mist-green, #C6D5D1)}.bg-dark.sc-af-section af-heading.sc-af-section::part(base),.bg-dark.sc-af-section af-heading.sc-af-section [part~=\"base\"],.bg-inkwell.sc-af-section af-heading.sc-af-section::part(base),.bg-inkwell.sc-af-section af-heading.sc-af-section [part~=\"base\"]{color:var(--colour-brand-mist-green, #C6D5D1)}.bg-dark.sc-af-section af-text.sc-af-section::part(base),.bg-dark.sc-af-section af-text.sc-af-section [part~=\"base\"],.bg-inkwell.sc-af-section af-text.sc-af-section::part(base),.bg-inkwell.sc-af-section af-text.sc-af-section [part~=\"base\"]{color:var(--colour-brand-mist-green, #C6D5D1);opacity:0.92}.bg-dark.sc-af-section af-typography-lockup.sc-af-section::part(heading),.bg-dark.sc-af-section af-typography-lockup.sc-af-section [part~=\"heading\"],.bg-inkwell.sc-af-section af-typography-lockup.sc-af-section::part(heading),.bg-inkwell.sc-af-section af-typography-lockup.sc-af-section [part~=\"heading\"],.bg-dark.sc-af-section af-typography-lockup.sc-af-section::part(body),.bg-dark.sc-af-section af-typography-lockup.sc-af-section [part~=\"body\"],.bg-inkwell.sc-af-section af-typography-lockup.sc-af-section::part(body),.bg-inkwell.sc-af-section af-typography-lockup.sc-af-section [part~=\"body\"]{color:var(--colour-brand-mist-green, #C6D5D1)}@media (max-width: 768px){.padding-tight.sc-af-section{padding:32px 0}.padding-default.sc-af-section{padding:64px 0}.padding-loose.sc-af-section{padding:80px 0 64px}}";
3
+ const afSectionCss = ".sc-af-section-h{display:block;width:100%}.section.sc-af-section{width:100%;position:relative}.padding-tight.sc-af-section{padding:48px 0}.padding-default.sc-af-section{padding:96px 0}.padding-loose.sc-af-section{padding:120px 0 96px}.theme-white.sc-af-section{background-color:var(--colour-brand-white, #FFFFFF);--af-background-base:var(--colour-brand-white, #FFFFFF);--af-background-base-hover:var(--colour-mistgreen-100, #f4f7f6);--af-background-contrast:var(--colour-brand-mist-green, #c6d5d1);--af-background-level-1:var(--colour-mistgreen-200, #e8eeed);--af-background-level-1-hover:var(--colour-mistgreen-300, #dde6e3);--af-background-border-subtle:var(--colour-mistgreen-200, #e8eeed);--af-background-border-default:var(--colour-mistgreen-400, #d1ddda);--af-background-border-heavy:var(--colour-mistgreen-500, #c6d5d1);--af-background-border-active:var(--colour-softclay-800, #8a7049);--af-background-icon-default:var(--colour-brand-inkwell, #14343b);--af-background-icon-accent:var(--colour-brand-soft-clay, #b09670);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-heading-secondary:var(--colour-brand-soft-clay, #b09670);--af-typography-body-dark:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-typography-body-subtle:var(--colour-inkwell-350, #60767b);--af-button-primary-text:var(--colour-brand-inkwell, #14343b);--af-button-primary-icon:var(--colour-brand-inkwell, #14343b);--af-button-primary-bg:var(--colour-brand-ice, #a6fffb);--af-button-primary-bg-hover:var(--colour-ice-600, #95e6e2);--af-button-primary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-secondary-text:var(--colour-brand-inkwell, #14343b);--af-button-secondary-icon:var(--colour-brand-inkwell, #14343b);--af-button-secondary-bg:transparent;--af-button-secondary-bg-hover:rgba(0, 0, 0, 0.08);--af-button-secondary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-text:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-icon:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-stroke:var(--colour-brand-soft-clay, #B09670)}.theme-inkwell.sc-af-section{background-color:var(--colour-brand-inkwell, #14343B);--af-background-base:var(--colour-brand-inkwell, #14343b);--af-background-base-hover:var(--colour-inkwell-600, #102a2f);--af-background-contrast:var(--colour-inkwell-700, #102a2f);--af-background-level-1:var(--colour-inkwell-450, #203e45);--af-background-level-1-hover:var(--colour-inkwell-400, #2b484f);--af-background-border-subtle:var(--colour-inkwell-450, #203e45);--af-background-border-default:var(--colour-inkwell-400, #2b484f);--af-background-border-heavy:var(--colour-inkwell-700, #102a2f);--af-background-border-active:var(--colour-brand-ice, #a6fffb);--af-background-icon-default:var(--colour-brand-white, #ffffff);--af-background-icon-accent:var(--colour-brand-ice, #a6fffb);--af-typography-heading-primary:var(--colour-brand-mist-green, #c6d5d1);--af-typography-heading-secondary:var(--colour-brand-white, #ffffff);--af-typography-body-dark:var(--colour-brand-white, #ffffff);--af-typography-body-default:var(--colour-inkwell-100, #d0d6d8);--af-typography-body-subtle:var(--colour-inkwell-200, #a1aeb1);--af-button-primary-text:var(--colour-brand-inkwell, #14343b);--af-button-primary-icon:var(--colour-brand-inkwell, #14343b);--af-button-primary-bg:var(--colour-brand-ice, #a6fffb);--af-button-primary-bg-hover:var(--colour-ice-600, #95e6e2);--af-button-primary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-secondary-text:var(--colour-brand-white, #ffffff);--af-button-secondary-icon:var(--colour-brand-white, #ffffff);--af-button-secondary-bg:transparent;--af-button-secondary-bg-hover:rgba(255, 255, 255, 0.08);--af-button-secondary-stroke:var(--colour-brand-white, #ffffff);--af-button-tertiary-text:var(--colour-brand-white, #ffffff);--af-button-tertiary-icon:var(--colour-brand-white, #ffffff);--af-button-tertiary-stroke:var(--colour-brand-ice, #A6FFFB)}.theme-mist-green.sc-af-section{background-color:var(--colour-brand-mist-green, #C6D5D1);--af-background-base:var(--colour-brand-mist-green, #c6d5d1);--af-background-base-hover:var(--colour-mistgreen-600, #b2c0bc);--af-background-contrast:var(--colour-brand-soft-clay, #b09670);--af-background-level-1:var(--colour-mistgreen-300, #dde6e3);--af-background-level-1-hover:var(--colour-mistgreen-400, #d1ddda);--af-background-border-subtle:var(--colour-mistgreen-600, #b2c0bc);--af-background-border-default:var(--colour-mistgreen-700, #9eaaa7);--af-background-border-heavy:var(--colour-mistgreen-700, #9eaaa7);--af-background-border-active:var(--colour-softclay-800, #8a7049);--af-background-icon-default:var(--colour-brand-inkwell, #14343b);--af-background-icon-accent:var(--colour-brand-soft-clay, #b09670);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-heading-secondary:var(--colour-brand-soft-clay, #b09670);--af-typography-body-dark:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-typography-body-subtle:var(--colour-inkwell-350, #60767b);--af-button-primary-text:var(--colour-brand-inkwell, #14343b);--af-button-primary-icon:var(--colour-brand-inkwell, #14343b);--af-button-primary-bg:var(--colour-brand-ice, #a6fffb);--af-button-primary-bg-hover:var(--colour-ice-600, #95e6e2);--af-button-primary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-secondary-text:var(--colour-brand-inkwell, #14343b);--af-button-secondary-icon:var(--colour-brand-inkwell, #14343b);--af-button-secondary-bg:transparent;--af-button-secondary-bg-hover:rgba(0, 0, 0, 0.08);--af-button-secondary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-text:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-icon:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-stroke:var(--colour-brand-soft-clay, #B09670)}.theme-soft-clay.sc-af-section{background-color:var(--colour-softclay-400, #c0ab8d);--af-background-base:var(--colour-softclay-400, #c0ab8d);--af-background-base-hover:var(--colour-softclay-500, #b09670);--af-background-contrast:var(--colour-brand-mist-green, #c6d5d1);--af-background-level-1:var(--colour-softclay-500, #b09670);--af-background-level-1-hover:var(--colour-softclay-600, #9e8765);--af-background-border-subtle:var(--colour-softclay-600, #9e8765);--af-background-border-default:var(--colour-softclay-700, #8d785a);--af-background-border-heavy:var(--colour-brand-inkwell, #14343b);--af-background-border-active:var(--colour-brand-ice, #a6fffb);--af-background-icon-default:var(--colour-brand-inkwell, #14343b);--af-background-icon-accent:var(--colour-brand-ivory-paper, #fff9ee);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-heading-secondary:var(--colour-brand-ivory-paper, #fff9ee);--af-typography-body-dark:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-typography-body-subtle:var(--colour-inkwell-350, #60767b);--af-button-primary-text:var(--colour-brand-inkwell, #14343b);--af-button-primary-icon:var(--colour-brand-inkwell, #14343b);--af-button-primary-bg:var(--colour-brand-ice, #a6fffb);--af-button-primary-bg-hover:var(--colour-ice-600, #95e6e2);--af-button-primary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-secondary-text:var(--colour-brand-inkwell, #14343b);--af-button-secondary-icon:var(--colour-brand-inkwell, #14343b);--af-button-secondary-bg:transparent;--af-button-secondary-bg-hover:rgba(0, 0, 0, 0.08);--af-button-secondary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-text:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-icon:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-stroke:var(--colour-brand-inkwell, #14343b)}.theme-white-ivory.sc-af-section{background-color:var(--colour-brand-ivory-paper, #fff9ee);--af-background-base:var(--colour-brand-ivory-paper, #fff9ee);--af-background-base-hover:var(--colour-ivory-100, #fff5e0);--af-background-contrast:var(--colour-brand-mist-green, #c6d5d1);--af-background-level-1:var(--colour-ivory-200, #ffefcc);--af-background-level-1-hover:var(--colour-ivory-300, #ffe9b8);--af-background-border-subtle:var(--colour-ivory-200, #ffefcc);--af-background-border-default:var(--colour-ivory-400, #ffe3a3);--af-background-border-heavy:var(--colour-brand-soft-clay, #b09670);--af-background-border-active:var(--colour-brand-soft-clay, #b09670);--af-background-icon-default:var(--colour-brand-inkwell, #14343b);--af-background-icon-accent:var(--colour-brand-soft-clay, #b09670);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-heading-secondary:var(--colour-brand-soft-clay, #b09670);--af-typography-body-dark:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-typography-body-subtle:var(--colour-inkwell-350, #60767b);--af-button-primary-text:var(--colour-brand-inkwell, #14343b);--af-button-primary-icon:var(--colour-brand-inkwell, #14343b);--af-button-primary-bg:var(--colour-brand-ice, #a6fffb);--af-button-primary-bg-hover:var(--colour-ice-600, #95e6e2);--af-button-primary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-secondary-text:var(--colour-brand-inkwell, #14343b);--af-button-secondary-icon:var(--colour-brand-inkwell, #14343b);--af-button-secondary-bg:transparent;--af-button-secondary-bg-hover:rgba(0, 0, 0, 0.08);--af-button-secondary-stroke:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-text:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-icon:var(--colour-brand-inkwell, #14343b);--af-button-tertiary-stroke:var(--colour-brand-soft-clay, #b09670)}@media (max-width: 768px){.padding-tight.sc-af-section{padding:32px 0}.padding-default.sc-af-section{padding:64px 0}.padding-loose.sc-af-section{padding:80px 0 64px}}";
4
4
 
5
5
  const AfSection = class {
6
6
  constructor(hostRef) {
7
7
  registerInstance(this, hostRef);
8
8
  /** Padding variant */
9
9
  this.padding = 'default';
10
- /** Background color */
11
- this.background = 'white';
10
+ /** Theme - sets background color and provides theme context to children */
11
+ this.theme = 'white';
12
12
  /** Whether to include a Container wrapper */
13
13
  this.container = true;
14
14
  }
15
15
  render() {
16
- const content = h("slot", { key: 'cf70bb3d8d31bc3f68c49c40f1d3c415de57d8b1' });
17
- return (h(Host, { key: '5b93e97c455ca8a50b598b0f3299e9884afc61ea' }, h("div", { key: '75f9cfbc62fd40dfd669c841f0b8490dcabb0c6f', class: `section padding-${this.padding} bg-${this.background}` }, this.container ? (h("af-container", null, content)) : content)));
16
+ const content = h("slot", { key: 'bd82dbdc2f1a42d75ad23aace4155b46d813dace' });
17
+ return (h(Host, { key: '6a81a4ed99312b5ecaee80d6ceac79cd5bf58b8c' }, h("div", { key: '44002052c7a2cbbe7e60bd3bcafb9794a79ba11a', class: `section padding-${this.padding} theme-${this.theme}` }, this.container ? (h("af-container", null, content)) : content)));
18
18
  }
19
19
  };
20
20
  AfSection.style = afSectionCss;
@@ -1 +1 @@
1
- {"version":3,"file":"af-section.entry.js","sources":["src/components/af-section/af-section.css?tag=af-section&encapsulation=scoped","src/components/af-section/af-section.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.section {\n width: 100%;\n position: relative;\n}\n\n/* Padding variants */\n.padding-tight {\n padding: 48px 0;\n}\n\n.padding-default {\n padding: 96px 0;\n}\n\n.padding-loose {\n padding: 120px 0 96px;\n}\n\n/* Background variants */\n.bg-white {\n background-color: var(--colour-background-white, #FFFFFF);\n}\n\n.bg-level1 {\n background-color: var(--colour-background-level-1, #E8EEED);\n}\n\n.bg-dark,\n.bg-inkwell {\n background-color: var(--colour-brand-inkwell, #14343B);\n --colour-typography-heading-primary: var(--colour-brand-mist-green, #C6D5D1);\n --colour-typography-body-default: var(--colour-brand-mist-green, #C6D5D1);\n}\n\n/* Automatic contrast overrides for dark sections */\n.bg-dark af-heading::part(base),\n.bg-inkwell af-heading::part(base) {\n color: var(--colour-brand-mist-green, #C6D5D1);\n}\n\n.bg-dark af-text::part(base),\n.bg-inkwell af-text::part(base) {\n color: var(--colour-brand-mist-green, #C6D5D1);\n opacity: 0.92;\n}\n\n.bg-dark af-typography-lockup::part(heading),\n.bg-inkwell af-typography-lockup::part(heading),\n.bg-dark af-typography-lockup::part(body),\n.bg-inkwell af-typography-lockup::part(body) {\n color: var(--colour-brand-mist-green, #C6D5D1);\n}\n\n/* Mobile adjustments */\n@media (max-width: 768px) {\n .padding-tight {\n padding: 32px 0;\n }\n \n .padding-default {\n padding: 64px 0;\n }\n \n .padding-loose {\n padding: 80px 0 64px;\n }\n}\n\n","import { Component, h, Host, Prop } from '@stencil/core';\n\n/**\n * Section layout component for consistent spacing and backgrounds\n */\n@Component({\n tag: 'af-section',\n styleUrl: 'af-section.css',\n shadow: false,\n scoped: true,\n})\nexport class AfSection {\n /** Padding variant */\n @Prop() padding: 'tight' | 'default' | 'loose' = 'default';\n \n /** Background color */\n @Prop() background: 'white' | 'level1' | 'dark' | 'inkwell' = 'white';\n \n /** Whether to include a Container wrapper */\n @Prop() container: boolean = true;\n\n render() {\n const content = <slot></slot>;\n \n return (\n <Host>\n <div class={`section padding-${this.padding} bg-${this.background}`}>\n {this.container ? (\n <af-container>{content}</af-container>\n ) : content}\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,YAAY,GAAG,0hEAA0hE;;MCWliE,SAAS,GAAA,MAAA;AANtB,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAQU,QAAA,IAAO,CAAA,OAAA,GAAkC,SAAS;;AAGlD,QAAA,IAAU,CAAA,UAAA,GAA4C,OAAO;;AAG7D,QAAA,IAAS,CAAA,SAAA,GAAY,IAAI;AAelC;IAbC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa;QAE7B,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAE,CAAmB,gBAAA,EAAA,IAAI,CAAC,OAAO,CAAO,IAAA,EAAA,IAAI,CAAC,UAAU,CAAA,CAAE,EAAA,EAChE,IAAI,CAAC,SAAS,IACb,CAAe,CAAA,cAAA,EAAA,IAAA,EAAA,OAAO,CAAgB,IACpC,OAAO,CACP,CACD;;;;;;;"}
1
+ {"version":3,"file":"af-section.entry.js","sources":["src/components/af-section/af-section.css?tag=af-section&encapsulation=scoped","src/components/af-section/af-section.tsx"],"sourcesContent":["/**\n * Section Component Styles\n * \n * Provides themed containers with proper spacing.\n * Theme classes set CSS custom properties that child components consume.\n */\n\n:host {\n display: block;\n width: 100%;\n}\n\n.section {\n width: 100%;\n position: relative;\n}\n\n/* Padding variants */\n.padding-tight {\n padding: 48px 0;\n}\n\n.padding-default {\n padding: 96px 0;\n}\n\n.padding-loose {\n padding: 120px 0 96px;\n}\n\n/* ==========================================================================\n WHITE THEME\n ========================================================================== */\n\n.theme-white {\n background-color: var(--colour-brand-white, #FFFFFF);\n \n /* Background tokens */\n --af-background-base: var(--colour-brand-white, #FFFFFF);\n --af-background-base-hover: var(--colour-mistgreen-100, #f4f7f6);\n --af-background-contrast: var(--colour-brand-mist-green, #c6d5d1);\n --af-background-level-1: var(--colour-mistgreen-200, #e8eeed);\n --af-background-level-1-hover: var(--colour-mistgreen-300, #dde6e3);\n --af-background-border-subtle: var(--colour-mistgreen-200, #e8eeed);\n --af-background-border-default: var(--colour-mistgreen-400, #d1ddda);\n --af-background-border-heavy: var(--colour-mistgreen-500, #c6d5d1);\n --af-background-border-active: var(--colour-softclay-800, #8a7049);\n --af-background-icon-default: var(--colour-brand-inkwell, #14343b);\n --af-background-icon-accent: var(--colour-brand-soft-clay, #b09670);\n \n /* Typography tokens */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-heading-secondary: var(--colour-brand-soft-clay, #b09670);\n --af-typography-body-dark: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-typography-body-subtle: var(--colour-inkwell-350, #60767b);\n \n /* Button - Primary */\n --af-button-primary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-bg: var(--colour-brand-ice, #a6fffb);\n --af-button-primary-bg-hover: var(--colour-ice-600, #95e6e2);\n --af-button-primary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Secondary */\n --af-button-secondary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-bg: transparent;\n --af-button-secondary-bg-hover: rgba(0, 0, 0, 0.08);\n --af-button-secondary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Tertiary */\n --af-button-tertiary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-stroke: var(--colour-brand-soft-clay, #B09670);\n}\n\n/* ==========================================================================\n INKWELL THEME (Dark)\n ========================================================================== */\n\n.theme-inkwell {\n background-color: var(--colour-brand-inkwell, #14343B);\n \n /* Background tokens */\n --af-background-base: var(--colour-brand-inkwell, #14343b);\n --af-background-base-hover: var(--colour-inkwell-600, #102a2f);\n --af-background-contrast: var(--colour-inkwell-700, #102a2f);\n --af-background-level-1: var(--colour-inkwell-450, #203e45);\n --af-background-level-1-hover: var(--colour-inkwell-400, #2b484f);\n --af-background-border-subtle: var(--colour-inkwell-450, #203e45);\n --af-background-border-default: var(--colour-inkwell-400, #2b484f);\n --af-background-border-heavy: var(--colour-inkwell-700, #102a2f);\n --af-background-border-active: var(--colour-brand-ice, #a6fffb);\n --af-background-icon-default: var(--colour-brand-white, #ffffff);\n --af-background-icon-accent: var(--colour-brand-ice, #a6fffb);\n \n /* Typography tokens */\n --af-typography-heading-primary: var(--colour-brand-mist-green, #c6d5d1);\n --af-typography-heading-secondary: var(--colour-brand-white, #ffffff);\n --af-typography-body-dark: var(--colour-brand-white, #ffffff);\n --af-typography-body-default: var(--colour-inkwell-100, #d0d6d8);\n --af-typography-body-subtle: var(--colour-inkwell-200, #a1aeb1);\n \n /* Button - Primary */\n --af-button-primary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-bg: var(--colour-brand-ice, #a6fffb);\n --af-button-primary-bg-hover: var(--colour-ice-600, #95e6e2);\n --af-button-primary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Secondary */\n --af-button-secondary-text: var(--colour-brand-white, #ffffff);\n --af-button-secondary-icon: var(--colour-brand-white, #ffffff);\n --af-button-secondary-bg: transparent;\n --af-button-secondary-bg-hover: rgba(255, 255, 255, 0.08);\n --af-button-secondary-stroke: var(--colour-brand-white, #ffffff);\n \n /* Button - Tertiary */\n --af-button-tertiary-text: var(--colour-brand-white, #ffffff);\n --af-button-tertiary-icon: var(--colour-brand-white, #ffffff);\n --af-button-tertiary-stroke: var(--colour-brand-ice, #A6FFFB);\n}\n\n/* ==========================================================================\n MIST-GREEN THEME\n ========================================================================== */\n\n.theme-mist-green {\n background-color: var(--colour-brand-mist-green, #C6D5D1);\n \n /* Background tokens */\n --af-background-base: var(--colour-brand-mist-green, #c6d5d1);\n --af-background-base-hover: var(--colour-mistgreen-600, #b2c0bc);\n --af-background-contrast: var(--colour-brand-soft-clay, #b09670);\n --af-background-level-1: var(--colour-mistgreen-300, #dde6e3);\n --af-background-level-1-hover: var(--colour-mistgreen-400, #d1ddda);\n --af-background-border-subtle: var(--colour-mistgreen-600, #b2c0bc);\n --af-background-border-default: var(--colour-mistgreen-700, #9eaaa7);\n --af-background-border-heavy: var(--colour-mistgreen-700, #9eaaa7);\n --af-background-border-active: var(--colour-softclay-800, #8a7049);\n --af-background-icon-default: var(--colour-brand-inkwell, #14343b);\n --af-background-icon-accent: var(--colour-brand-soft-clay, #b09670);\n \n /* Typography tokens */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-heading-secondary: var(--colour-brand-soft-clay, #b09670);\n --af-typography-body-dark: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-typography-body-subtle: var(--colour-inkwell-350, #60767b);\n \n /* Button - Primary */\n --af-button-primary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-bg: var(--colour-brand-ice, #a6fffb);\n --af-button-primary-bg-hover: var(--colour-ice-600, #95e6e2);\n --af-button-primary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Secondary */\n --af-button-secondary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-bg: transparent;\n --af-button-secondary-bg-hover: rgba(0, 0, 0, 0.08);\n --af-button-secondary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Tertiary */\n --af-button-tertiary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-stroke: var(--colour-brand-soft-clay, #B09670);\n}\n\n/* ==========================================================================\n SOFT-CLAY THEME\n ========================================================================== */\n\n.theme-soft-clay {\n background-color: var(--colour-softclay-400, #c0ab8d);\n \n /* Background tokens */\n --af-background-base: var(--colour-softclay-400, #c0ab8d);\n --af-background-base-hover: var(--colour-softclay-500, #b09670);\n --af-background-contrast: var(--colour-brand-mist-green, #c6d5d1);\n --af-background-level-1: var(--colour-softclay-500, #b09670);\n --af-background-level-1-hover: var(--colour-softclay-600, #9e8765);\n --af-background-border-subtle: var(--colour-softclay-600, #9e8765);\n --af-background-border-default: var(--colour-softclay-700, #8d785a);\n --af-background-border-heavy: var(--colour-brand-inkwell, #14343b);\n --af-background-border-active: var(--colour-brand-ice, #a6fffb);\n --af-background-icon-default: var(--colour-brand-inkwell, #14343b);\n --af-background-icon-accent: var(--colour-brand-ivory-paper, #fff9ee);\n \n /* Typography tokens */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-heading-secondary: var(--colour-brand-ivory-paper, #fff9ee);\n --af-typography-body-dark: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-typography-body-subtle: var(--colour-inkwell-350, #60767b);\n \n /* Button - Primary */\n --af-button-primary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-bg: var(--colour-brand-ice, #a6fffb);\n --af-button-primary-bg-hover: var(--colour-ice-600, #95e6e2);\n --af-button-primary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Secondary */\n --af-button-secondary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-bg: transparent;\n --af-button-secondary-bg-hover: rgba(0, 0, 0, 0.08);\n --af-button-secondary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Tertiary */\n --af-button-tertiary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-stroke: var(--colour-brand-inkwell, #14343b);\n}\n\n/* ==========================================================================\n WHITE-IVORY THEME\n ========================================================================== */\n\n.theme-white-ivory {\n background-color: var(--colour-brand-ivory-paper, #fff9ee);\n \n /* Background tokens */\n --af-background-base: var(--colour-brand-ivory-paper, #fff9ee);\n --af-background-base-hover: var(--colour-ivory-100, #fff5e0);\n --af-background-contrast: var(--colour-brand-mist-green, #c6d5d1);\n --af-background-level-1: var(--colour-ivory-200, #ffefcc);\n --af-background-level-1-hover: var(--colour-ivory-300, #ffe9b8);\n --af-background-border-subtle: var(--colour-ivory-200, #ffefcc);\n --af-background-border-default: var(--colour-ivory-400, #ffe3a3);\n --af-background-border-heavy: var(--colour-brand-soft-clay, #b09670);\n --af-background-border-active: var(--colour-brand-soft-clay, #b09670);\n --af-background-icon-default: var(--colour-brand-inkwell, #14343b);\n --af-background-icon-accent: var(--colour-brand-soft-clay, #b09670);\n \n /* Typography tokens */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-heading-secondary: var(--colour-brand-soft-clay, #b09670);\n --af-typography-body-dark: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-typography-body-subtle: var(--colour-inkwell-350, #60767b);\n \n /* Button - Primary */\n --af-button-primary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-primary-bg: var(--colour-brand-ice, #a6fffb);\n --af-button-primary-bg-hover: var(--colour-ice-600, #95e6e2);\n --af-button-primary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Secondary */\n --af-button-secondary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-secondary-bg: transparent;\n --af-button-secondary-bg-hover: rgba(0, 0, 0, 0.08);\n --af-button-secondary-stroke: var(--colour-brand-inkwell, #14343b);\n \n /* Button - Tertiary */\n --af-button-tertiary-text: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-icon: var(--colour-brand-inkwell, #14343b);\n --af-button-tertiary-stroke: var(--colour-brand-soft-clay, #b09670);\n}\n\n/* Mobile adjustments */\n@media (max-width: 768px) {\n .padding-tight {\n padding: 32px 0;\n }\n \n .padding-default {\n padding: 64px 0;\n }\n \n .padding-loose {\n padding: 80px 0 64px;\n }\n}\n","import { Component, h, Host, Prop } from '@stencil/core';\n\n/**\n * Section layout component for consistent spacing and backgrounds.\n * Sets theme context for all child components via CSS custom properties.\n */\n@Component({\n tag: 'af-section',\n styleUrl: 'af-section.css',\n shadow: false,\n scoped: true,\n})\nexport class AfSection {\n /** Padding variant */\n @Prop() padding: 'tight' | 'default' | 'loose' = 'default';\n \n /** Theme - sets background color and provides theme context to children */\n @Prop() theme: 'white' | 'inkwell' | 'mist-green' | 'soft-clay' | 'white-ivory' = 'white';\n \n /** Whether to include a Container wrapper */\n @Prop() container: boolean = true;\n\n render() {\n const content = <slot></slot>;\n \n return (\n <Host>\n <div class={`section padding-${this.padding} theme-${this.theme}`}>\n {this.container ? (\n <af-container>{content}</af-container>\n ) : content}\n </div>\n </Host>\n );\n }\n}\n"],"names":[],"mappings":";;AAAA,MAAM,YAAY,GAAG,2qTAA2qT;;MCYnrT,SAAS,GAAA,MAAA;AANtB,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAQU,QAAA,IAAO,CAAA,OAAA,GAAkC,SAAS;;AAGlD,QAAA,IAAK,CAAA,KAAA,GAAqE,OAAO;;AAGjF,QAAA,IAAS,CAAA,SAAA,GAAY,IAAI;AAelC;IAbC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa;QAE7B,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAE,CAAmB,gBAAA,EAAA,IAAI,CAAC,OAAO,CAAU,OAAA,EAAA,IAAI,CAAC,KAAK,CAAA,CAAE,EAAA,EAC9D,IAAI,CAAC,SAAS,IACb,CAAe,CAAA,cAAA,EAAA,IAAA,EAAA,OAAO,CAAgB,IACpC,OAAO,CACP,CACD;;;;;;;"}
@@ -1,4 +1,4 @@
1
- import { r as registerInstance, h, H as Host } from './index-DI7b0bCy.js';
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
2
 
3
3
  const afSocialLinkCss = ".sc-af-social-link-h{display:inline-block}.social-link.sc-af-social-link{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid rgba(198, 213, 209, 0.3);border-radius:50%;color:var(--colour-tints-mistGreen-200, #C6D5D1);transition:all 0.2s ease}.social-link.sc-af-social-link:hover{background-color:rgba(198, 213, 209, 0.1);border-color:rgba(198, 213, 209, 0.5)}";
4
4
 
@@ -29,7 +29,7 @@ const AfSocialLink = class {
29
29
  }
30
30
  }
31
31
  render() {
32
- return (h(Host, { key: 'a3ee0c643448f2c83f37559334be40a00a041465' }, h("a", { key: '162b7812f93c5226272220edd9ba3153651c01df', href: this.href, target: "_blank", rel: "noopener noreferrer", class: "social-link", "aria-label": this.label }, this.renderIcon())));
32
+ return (h(Host, { key: '57af022b19d623dfb9c39b7a75e5ceefe2ef866b' }, h("a", { key: '7fd283969d02fbce9b4a7a585a1b88dae1fd5fbe', href: this.href, target: "_blank", rel: "noopener noreferrer", class: "social-link", "aria-label": this.label }, this.renderIcon())));
33
33
  }
34
34
  };
35
35
  AfSocialLink.style = afSocialLinkCss;
@@ -0,0 +1,39 @@
1
+ import { r as registerInstance, h, H as Host } from './index-BmU_CFQ4.js';
2
+
3
+ const afSplitSectionCss = ".sc-af-split-section-h{display:block;width:100%}.split-section.sc-af-split-section{position:relative;width:100%}.padding-tight.sc-af-split-section{padding:48px 0}.padding-default.sc-af-split-section{padding:96px 0}.padding-loose.sc-af-split-section{padding:120px 0 96px}@media (max-width: 768px){.padding-tight.sc-af-split-section{padding:32px 0}.padding-default.sc-af-split-section{padding:64px 0}.padding-loose.sc-af-split-section{padding:80px 0 64px}}";
4
+
5
+ // Map theme names to CSS color values
6
+ const themeColors = {
7
+ 'white': 'var(--colour-brand-white, #FFFFFF)',
8
+ 'inkwell': 'var(--colour-brand-inkwell, #14343B)',
9
+ 'mist-green': 'var(--colour-brand-mist-green, #C6D5D1)',
10
+ 'soft-clay': 'var(--colour-softclay-400, #c0ab8d)',
11
+ 'white-ivory': 'var(--colour-brand-ivory-paper, #fff9ee)',
12
+ };
13
+ const AfSplitSection = class {
14
+ constructor(hostRef) {
15
+ registerInstance(this, hostRef);
16
+ /** Theme for the top half of the section */
17
+ this.topTheme = 'mist-green';
18
+ /** Theme for the bottom half of the section */
19
+ this.bottomTheme = 'white';
20
+ /** Padding variant */
21
+ this.padding = 'default';
22
+ /** Whether to include a Container wrapper */
23
+ this.container = true;
24
+ }
25
+ render() {
26
+ const content = h("slot", { key: '6883d2b8d85fc848e03978e163655d8672f8bac6' });
27
+ // Create the split background using CSS gradient
28
+ const topColor = themeColors[this.topTheme];
29
+ const bottomColor = themeColors[this.bottomTheme];
30
+ const backgroundStyle = {
31
+ background: `linear-gradient(to bottom, ${topColor} 0%, ${topColor} 50%, ${bottomColor} 50%, ${bottomColor} 100%)`
32
+ };
33
+ return (h(Host, { key: '583008c903c5883fb1b2254eb235cc3db440be38' }, h("div", { key: 'c8b2f2d0527c60cb2df6a321fe55a640a8f46a8c', class: `split-section padding-${this.padding} top-theme-${this.topTheme}`, style: backgroundStyle }, this.container ? (h("af-container", null, content)) : content)));
34
+ }
35
+ };
36
+ AfSplitSection.style = afSplitSectionCss;
37
+
38
+ export { AfSplitSection as af_split_section };
39
+ //# sourceMappingURL=af-split-section.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-split-section.entry.js","sources":["src/components/af-split-section/af-split-section.css?tag=af-split-section&encapsulation=scoped","src/components/af-split-section/af-split-section.tsx"],"sourcesContent":["/* Theme CSS custom properties are loaded globally from @affinda/css */\n\n:host {\n display: block;\n width: 100%;\n}\n\n.split-section {\n position: relative;\n width: 100%;\n /* Background is set via inline style with linear-gradient */\n}\n\n/* ==========================================================================\n Padding Variants\n ========================================================================== */\n\n.padding-tight {\n padding: 48px 0;\n}\n\n.padding-default {\n padding: 96px 0;\n}\n\n.padding-loose {\n padding: 120px 0 96px;\n}\n\n/* ==========================================================================\n Mobile Adjustments\n ========================================================================== */\n\n@media (max-width: 768px) {\n .padding-tight {\n padding: 32px 0;\n }\n \n .padding-default {\n padding: 64px 0;\n }\n \n .padding-loose {\n padding: 80px 0 64px;\n }\n}\n","import { Component, h, Host, Prop } from '@stencil/core';\n\ntype Theme = 'white' | 'inkwell' | 'mist-green' | 'soft-clay' | 'white-ivory';\n\n// Map theme names to CSS color values\nconst themeColors: Record<Theme, string> = {\n 'white': 'var(--colour-brand-white, #FFFFFF)',\n 'inkwell': 'var(--colour-brand-inkwell, #14343B)',\n 'mist-green': 'var(--colour-brand-mist-green, #C6D5D1)',\n 'soft-clay': 'var(--colour-softclay-400, #c0ab8d)',\n 'white-ivory': 'var(--colour-brand-ivory-paper, #fff9ee)',\n};\n\n/**\n * Split Section component for layouts with two-tone backgrounds.\n * Creates a vertical split with different themes for top and bottom halves.\n * Useful for content that visually spans across two themed areas.\n * \n * Uses a CSS linear-gradient for the split background effect.\n */\n@Component({\n tag: 'af-split-section',\n styleUrl: 'af-split-section.css',\n shadow: false,\n scoped: true,\n})\nexport class AfSplitSection {\n /** Theme for the top half of the section */\n @Prop() topTheme: Theme = 'mist-green';\n\n /** Theme for the bottom half of the section */\n @Prop() bottomTheme: Theme = 'white';\n\n /** Padding variant */\n @Prop() padding: 'tight' | 'default' | 'loose' = 'default';\n\n /** Whether to include a Container wrapper */\n @Prop() container: boolean = true;\n\n render() {\n const content = <slot></slot>;\n \n // Create the split background using CSS gradient\n const topColor = themeColors[this.topTheme];\n const bottomColor = themeColors[this.bottomTheme];\n const backgroundStyle = {\n background: `linear-gradient(to bottom, ${topColor} 0%, ${topColor} 50%, ${bottomColor} 50%, ${bottomColor} 100%)`\n };\n\n return (\n <Host>\n <div\n class={`split-section padding-${this.padding} top-theme-${this.topTheme}`}\n style={backgroundStyle}\n >\n {this.container ? (\n <af-container>{content}</af-container>\n ) : content}\n </div>\n </Host>\n );\n }\n}\n\n"],"names":[],"mappings":";;AAAA,MAAM,iBAAiB,GAAG,wcAAwc;;ACIle;AACA,MAAM,WAAW,GAA0B;AACzC,IAAA,OAAO,EAAE,oCAAoC;AAC7C,IAAA,SAAS,EAAE,sCAAsC;AACjD,IAAA,YAAY,EAAE,yCAAyC;AACvD,IAAA,WAAW,EAAE,qCAAqC;AAClD,IAAA,aAAa,EAAE,0CAA0C;CAC1D;MAeY,cAAc,GAAA,MAAA;AAN3B,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAQU,QAAA,IAAQ,CAAA,QAAA,GAAU,YAAY;;AAG9B,QAAA,IAAW,CAAA,WAAA,GAAU,OAAO;;AAG5B,QAAA,IAAO,CAAA,OAAA,GAAkC,SAAS;;AAGlD,QAAA,IAAS,CAAA,SAAA,GAAY,IAAI;AAyBlC;IAvBC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa;;QAG7B,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC3C,MAAM,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC;AACjD,QAAA,MAAM,eAAe,GAAG;YACtB,UAAU,EAAE,8BAA8B,QAAQ,CAAA,KAAA,EAAQ,QAAQ,CAAS,MAAA,EAAA,WAAW,CAAS,MAAA,EAAA,WAAW,CAAQ,MAAA;SACnH;AAED,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE,CAAyB,sBAAA,EAAA,IAAI,CAAC,OAAO,CAAc,WAAA,EAAA,IAAI,CAAC,QAAQ,CAAE,CAAA,EACzE,KAAK,EAAE,eAAe,EAErB,EAAA,IAAI,CAAC,SAAS,IACb,wBAAe,OAAO,CAAgB,IACpC,OAAO,CACP,CACD;;;;;;;"}