@nationalarchives/frontend 0.35.0 → 0.36.0
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.
- package/nationalarchives/all.css +1 -1
- package/nationalarchives/all.css.map +1 -1
- package/nationalarchives/components/footer/fixtures.json +2 -2
- package/nationalarchives/components/footer/template.njk +3 -3
- package/nationalarchives/components/quick-filters/quick-filters.css.map +1 -1
- package/nationalarchives/components/quick-filters/quick-filters.scss +2 -2
- package/nationalarchives/components/sidebar/sidebar.css.map +1 -1
- package/nationalarchives/components/sidebar/sidebar.scss +1 -1
- package/nationalarchives/email.css +1 -1
- package/nationalarchives/email.css.map +1 -1
- package/nationalarchives/email.scss +2 -2
- package/nationalarchives/prototype-kit.css +1 -1
- package/nationalarchives/prototype-kit.css.map +1 -1
- package/nationalarchives/templates/fixtures.json +9 -6
- package/nationalarchives/templates/layouts/email.njk +1 -1
- package/nationalarchives/utilities/lists/_index.scss +5 -3
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sourceRoot":"","sources":["../../src/nationalarchives/all.scss","../../src/nationalarchives/tools/_colour.scss","../../src/nationalarchives/tools/_media.scss","../../src/nationalarchives/tools/_a11y.scss","../../src/nationalarchives/tools/_borders.scss","../../src/nationalarchives/variables/_borders.scss","../../src/nationalarchives/tools/_spacing.scss","../../src/nationalarchives/utilities/a11y/_index.scss","../../src/nationalarchives/utilities/animations/_index.scss","../../src/nationalarchives/utilities/areas/_index.scss","../../src/nationalarchives/utilities/colour/_index.scss","../../src/nationalarchives/utilities/columns/_index.scss","../../src/nationalarchives/utilities/forms/_index.scss","../../src/nationalarchives/tools/_typography.scss","../../src/nationalarchives/variables/_typography.scss","../../src/nationalarchives/utilities/global/_index.scss","../../src/nationalarchives/utilities/grid/_index.scss","../../src/nationalarchives/variables/_grid.scss","../../src/nationalarchives/tools/_grid.scss","../../src/nationalarchives/utilities/typography/_index.scss","../../src/nationalarchives/utilities/lists/_index.scss","../../src/nationalarchives/utilities/logo/_index.scss","../../src/nationalarchives/utilities/overrides/_index.scss","../../src/nationalarchives/utilities/reset/_index.scss","../../src/nationalarchives/utilities/tables/_index.scss","../../src/nationalarchives/components/accordion/accordion.scss","../../src/nationalarchives/components/back-link/back-link.scss","../../src/nationalarchives/components/breadcrumbs/breadcrumbs.scss","../../src/nationalarchives/components/button/_button-group.scss","../../src/nationalarchives/components/button/button.scss","../../src/nationalarchives/components/card/card.scss","../../src/nationalarchives/variables/_a11y.scss","../../src/nationalarchives/components/compound-filters/compound-filters.scss","../../src/nationalarchives/components/cookie-banner/cookie-banner.scss","../../src/nationalarchives/components/details/details.scss","../../src/nationalarchives/components/files-list/files-list.scss","../../src/nationalarchives/components/footer/footer.scss","../../src/nationalarchives/components/gallery/gallery.scss","../../src/nationalarchives/components/global-header/global-header.scss","../../src/nationalarchives/components/header/header.scss","../../src/nationalarchives/components/hero/hero.scss","../../src/nationalarchives/components/index-grid/index-grid.scss","../../src/nationalarchives/components/pagination/pagination.scss","../../src/nationalarchives/components/panel/panel.scss","../../src/nationalarchives/components/phase-banner/phase-banner.scss","../../src/nationalarchives/components/picture/picture.scss","../../src/nationalarchives/tools/_shadows.scss","../../src/nationalarchives/components/quick-filters/quick-filters.scss","../../src/nationalarchives/components/secondary-navigation/secondary-navigation.scss","../../src/nationalarchives/components/sidebar/sidebar.scss","../../src/nationalarchives/components/skip-link/skip-link.scss","../../src/nationalarchives/components/tabs/tabs.scss","../../src/nationalarchives/components/warning/warning.scss","../../src/nationalarchives/components/fieldset/fieldset.scss","../../src/nationalarchives/components/checkboxes/checkboxes.scss","../../src/nationalarchives/components/date-input/date-input.scss","../../src/nationalarchives/components/date-search/date-search.scss","../../src/nationalarchives/components/error-summary/error-summary.scss","../../src/nationalarchives/components/file-input/file-input.scss","../../src/nationalarchives/components/radios/radios.scss","../../src/nationalarchives/components/search-field/search-field.scss","../../src/nationalarchives/variables/_forms.scss","../../src/nationalarchives/components/select/select.scss","../../src/nationalarchives/components/text-input/text-input.scss","../../src/nationalarchives/components/textarea/textarea.scss"],"names":[],"mappings":"CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GCsJA,oLA9DE,4CAIA,6DA4BI,mDAsHN,2BAvMM,sBAEE,2BAFF,2DAEE,0BAFF,0BAEE,+BAFF,kCAEE,uCAFF,kCAEE,uCAFF,gBAEE,qBAFF,wBAEE,6BAFF,oEAEE,uCAFF,gCAEE,qCAFF,+/CA2MJ,+BAJF,2BAjLM,iCAEE,sCAFF,kDAEE,+BAFF,0BAEE,+BAFF,2BAEE,gCAFF,iCAEE,sCAFF,gBAEE,qBAFF,wBAEE,6BAFF,+DAEE,mCAFF,6BAEE,kCAFF,0+CAkMN,2UACE,yCACA,uCACA,uCACA,yCACA,yCACA,6BACA,6CACA,mCACA,6CACA,2CACA,uDACA,uDACA,mEAhLA,4CAJA,gCCNA,wBDqMF,0DAEI,yCACA,uCACA,uCACA,yCACA,yCACA,6BACA,6CACA,mCACA,6CACA,2CACA,uDACA,uDACA,mEAzMF,4CAJA,iCAyNF,qCAEI,4OAvNF,4CAJA,gCAuOF,2eACE,qCApOA,4CA6OF,wZACE,uCACA,qCACA,qCACA,uCACA,uCACA,2BACA,mCACA,iCACA,2CACA,yCACA,yCACA,qDACA,qDACA,iEA3PA,4CAJA,gCA0QF,qGACE,6CACA,qBACA,0BACA,kCACA,kCACA,kCACA,gCACA,kCACA,kCAIA,kCAIA,8CAIA,0CA3RA,4CAJA,gCAqSE,mCADF,qNAKI,uCACA,qCACA,qCACA,uCACA,uCACA,2BACA,mCACA,iCACA,2CACA,yCACA,yCACA,qDACA,qDACA,kEAIJ,6MAIE,uCACA,qCACA,qCACA,uCACA,uCACA,2BACA,mCACA,iCACA,2CACA,yCACA,yCACA,qDACA,qDACA,iEAQJ,kEACE,iDACA,yDACA,6CACA,4CACA,4CACA,mDACA,mDACA,uCACA,+CACA,gDACA,qDACA,sDACA,0DAOF,icACE,kDACA,kDACA,yDACA,yDACA,6CACA,qDACA,sDACA,2DACA,sDAGF,+DACE,6CACA,yDACA,yCACA,gDACA,4DAQF,4DACE,iDACA,yDACA,6CACA,0DAQF,kEACE,iDACA,yDACA,4CACA,0DAQF,qKACE,+CACA,yDACA,8CACA,wDAQF,+FACE,gDACA,yDACA,6CACA,yDA8BF,0HACE,wGAMA,0BACA,0BAEA,4DAEA,+BAZF,0HAaI,2BElhBJ,gWACE,kCACA,8BAEA,qCAGA,WACE,kCAGF,usBACE,8BAEA,qCAIA,mCADF,2tBAEI,8BAEA,sCAeN,iSACE,kCACA,8BAEA,qCAGA,gBAEA,utBACE,8BAEA,qCAIA,mCADF,+uBAEI,8BAEA,sCASN,0BACE,kBAIA,gHACE,WAEA,kBACA,QACA,UChGF,cCDsB,IFsGtB,0NAhDA,wBAEA,2BGhCF,ghBACE,gBAIF,cACE,gBAKA,88BACE,aCpCJ,8CJGE,qBACA,sBACA,oBACA,qBAEA,2BAEA,6BACA,uBACA,wBACA,sBAEA,0CAEA,oBAEA,wCACA,gCIfF,iCAGE,UAOF,uCACE,QACE,WAiBJ,4HJoBE,wBAEA,2BK1DF,mCACE,QAEE,0BAGF,IACE,8BCFJ,aACE,iBACA,oBAGF,WAEE,aLTA,cCDsB,IJ6gBtB,8BQrgBF,WR8GM,uDAiZJ,+BQ/fF,WR8GM,uDQpGJ,kBACE,aP6DF,wBOxDA,aACE,iBACA,oBAGF,WACE,cC9BJ,cT0FE,4CSpFE,mCADF,4BT2CI,sBAEE,2BAFF,kEAEE,4CAFF,gCAEE,qCAFF,wCAEE,6CAFF,wCAEE,6CAFF,yBAEE,8BAFF,qBAEE,0BAFF,sEAEE,0CAFF,0CAEE,+CAFF,sgDStCF,+DALF,4BTiEI,mSAEE,yCAFF,mCAEE,wCAFF,g/CSvDJ,0BTiCI,sBAEE,2BAFF,kEAEE,4CAFF,gCAEE,qCAFF,wCAEE,6CAFF,wCAEE,6CAFF,yBAEE,8BAFF,qBAEE,0BAFF,sEAEE,0CAFF,0CAEE,+CAFF,qgDS9BF,+BAHF,0BTuDI,mSAEE,yCAFF,mCAEE,wCAFF,g/CSEJ,oBT8CI,wDS1CJ,yBT0CI,sDUrHN,aACE,gBAEA,gBACE,eAGF,gBACE,eT+CF,wBSvDF,aAYI,iBTqCF,kDShCI,sBACE,aAFS,EACX,sBACE,aAFS,EACX,sBACE,aAFS,EACX,sBACE,aAFS,GTuCf,wBS9BI,qBACE,aAFS,EACX,qBACE,aAFS,EACX,qBACE,aAFS,EACX,qBACE,aAFS,GAOf,oBACE,mBAGF,mDACE,eC7BF,sBACE,cAGF,qBACE,oBCTF,eZkFA,6CWnEA,sBACE,mBXkEF,sCYjEA,YCiBsB,IFZtB,qBACE,kBAEA,iCACE,aAIJ,sBACE,kBXyEE,wDc9GN,cASE,gBACA,WACA,YAUA,iCAGF,oBACE,gBACA,SACA,UAEA,6FACE,aACA,sBAIJ,UACE,OC9BF,eACE,WACA,UCRwB,ODSxB,kBACA,iBACA,mBACA,kBAEA,aACA,eACA,oBACA,2BAEA,sBAEA,0CACE,8BAGA,gBACA,eAGF,oBACE,eAGF,qDAEE,uBAGF,4BACE,yBAGF,sCACE,WACA,mBACA,kBAGO,kCACP,gBAIJ,YACE,mBACA,kBAEA,sBAEA,oCACE,gBACA,eAGF,uBACE,sBAGF,0BACE,kBAGF,0BACE,oBEvCA,kBACE,WACA,UAUI,wBACE,oBACA,UAGF,+BACE,2BAGF,8BACE,0BAVF,uBACE,qBACA,UAGF,8BACE,4BAGF,6BACE,2BAVF,uBACE,UACA,UAGF,8BACE,iBAGF,6BACE,gBAVF,uBACE,qBACA,UAGF,8BACE,4BAGF,6BACE,2BAVF,wBACE,qBACA,UAGF,+BACE,4BAGF,8BACE,2BAVF,uBACE,UACA,UAGF,8BACE,iBAGF,6BACE,gBAVF,wBACE,qBACA,UAGF,+BACE,4BAGF,8BACE,2BAVF,uBACE,qBACA,UAGF,8BACE,4BAGF,6BACE,2BAVF,uBACE,UACA,UAGF,8BACE,iBAGF,6BACE,gBAVF,uBACE,qBACA,UAGF,8BACE,4BAGF,6BACE,2BAVF,yBACE,qBACA,UAGF,gCACE,4BAGF,+BACE,2BAkCN,oBACE,WAEA,SAHF,oBACE,WAEA,SAHF,oBACE,WAEA,SAKF,qBACE,MAFS,EACX,qBACE,MAFS,EACX,qBACE,MAFS,EACX,qBACE,MAFS,EhBnDf,kDgBZE,yBACE,WACA,UAUI,8BACE,qBACA,UAGF,qCACE,4BAGF,oCACE,2BAVF,8BACE,qBACA,UAGF,qCACE,4BAGF,oCACE,2BAVF,8BACE,UACA,UAGF,qCACE,iBAGF,oCACE,gBAVF,8BACE,qBACA,UAGF,qCACE,4BAGF,oCACE,2BAVF,8BACE,qBACA,UAGF,qCACE,4BAGF,oCACE,2BAwBN,oCACE,eAGF,mCACE,cAKF,2BACE,WAEA,SAHF,2BACE,WAEA,SAHF,2BACE,WAEA,SAKF,4BACE,MAFS,EACX,4BACE,MAFS,EACX,4BACE,MAFS,EACX,4BACE,MAFS,GhB7Cf,kDgBlBE,wBACE,WACA,UAUI,6BACE,UACA,UAGF,oCACE,iBAGF,mCACE,gBAVF,6BACE,UACA,UAGF,oCACE,iBAGF,mCACE,gBAVF,6BACE,UACA,UAGF,oCACE,iBAGF,mCACE,gBAwBN,mCACE,eAGF,kCACE,cAKF,0BACE,WAEA,SAHF,0BACE,WAEA,SAHF,0BACE,WAEA,SAKF,2BACE,MAFS,EACX,2BACE,MAFS,EACX,2BACE,MAFS,EACX,2BACE,MAFS,GhBvCf,wBc8BA,eACE,qBACA,oBAEA,sCACE,WACA,mBACA,kBAIJ,YACE,qBACA,oBEnEA,uBACE,WACA,UAUI,4BACE,UACA,UAGF,mCACE,iBAGF,kCACE,gBAwBN,kCACE,eAGF,iCACE,cAKF,yBACE,WAEA,SAHF,yBACE,WAEA,SAHF,yBACE,WAEA,SAKF,0BACE,MAFS,EACX,0BACE,MAFS,EACX,0BACE,MAFS,EACX,0BACE,MAFS,GCxFjB,clB+EE,gCY7DA,YCSA,qBDRA,kBACA,yBACA,mCAfA,YCuBiB,IK1BjB,cACA,kCACA,8BACA,sBACA,kCACA,mClBwfA,+BkBhgBF,cNUE,YCoBwB,KKf1B,oBACE,cNnBA,oBMqBA,YLCiB,KZkBjB,kDiBtBF,oBNlBE,oBX4EA,wBiB1DF,oBNlBE,qBMgCF,ONfE,YCiBsB,IKKtB,IACE,gBAIJ,ENYE,0BC/BuC,WDgCvC,sBCjCoC,OKuBpC,mBAEA,SlBiCA,2BkB5BA,UlB4BA,mCkBxBA,iBNGA,0BACA,0BCpCsC,QDqCtC,sBCvCoC,OKwClC,qClBkBF,2BkBZF,MNtEE,sBM0EF,sDACE,sBACA,yBAEA,aACA,mBACA,WlBEA,gCY5CA,YC4BA,sBD3BA,kBACA,yBAIE,YCwBiB,IDpEnB,mBAmDA,gBACA,yBMgCA,cACA,kBACA,wBfzFA,cCDsB,Ic8Fb,yDACP,0BAEA,2EACE,0BACA,kCACA,8BAEA,yGACE,cAKN,oFlBtBA,6CAibA,+BkB3ZA,oFlBtBA,qBkB+BF,uGACE,UAEA,gBAEA,+BAEA,YACA,mBAGE,mIN/DF,0BACA,0BCpCsC,QDqCtC,sBCvCoC,OKwGlC,mJACE,cAKN,wJlBpBM,mDkByBJ,iCACA,yBAEA,guBlB5DA,oDAIA,qDAiCI,iDkB+BF,gzBlBpEF,2DkB0EE,mCADF,wblBzEA,oDAIA,qDAiCI,iDkB4CA,gelBjFJ,4DkB4HF,eAGE,aACA,eACA,kBAEA,gBAEA,qBACE,aACA,mBAIJ,kNlB3IE,qCkB6IA,iBAEA,oOACE,qBAEA,mBAEA,mSACE,WAEA,cACA,eACA,mBACA,mBAEA,qBAEA,sBAEA,wBlB1IA,4FkBiJA,opBlBlIA,0CkBwIJ,iRACE,oBAIJ,kDNnOE,YCmBA,gDDlBA,YCqBoB,IDuBpB,YCDuB,ID7EvB,eXwCA,kDiB4NF,kDNpQE,gBX4EA,wBiBwLF,kDNpQE,mBMiRF,gDNhPE,YCmBA,gDDlBA,YCqBoB,IDuBpB,YCKsB,KDnFtB,kBXwCA,kDiByOF,gDNjRE,gBX4EA,wBiBqMF,gDNjRE,qBM8RE,kEACE,aACA,cACA,gBACA,kBAEA,sBACA,wBAKN,gDNzRE,YCiBsB,ID4CtB,YCWsB,IDzFtB,mBXwCA,kDiBkQF,gDN1SE,oBX4EA,wBiB8NF,gDN1SE,qBMuTF,gDNtSE,YCiBsB,ID4CtB,YCiBsB,ID/FtB,oBMoUF,gBN3TE,YCuBiB,IKySjB,cACA,YL3OsB,IK8OxB,sIAEE,gBACA,iBAEA,kPACE,cAGF,mwBAGE,gBAgCE,qCACE,aAcN,wBACE,mBAaF,mBACE,SAEA,cAoBJ,gBAEE,eACA,gBACA,cACA,4BlB1UI,+DkByVJ,uBNpbA,YCoBwB,IKkatB,YACA,eAEA,uCACE,YAGF,4CACE,mBAGF,0CACE,oBAIJ,0BACE,gBNpdF,eMwdE,kCACE,gBACA,mBjBtaJ,wBiByXF,gBAkDI,mCAKJ,qBNp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","file":"all.css","sourcesContent":["/*!\n * ==========================================\n * TNA Frontend\n * ------------------------------------------\n * www.nationalarchives.gov.uk\n * github.com/nationalarchives/tna-frontend\n * ==========================================\n */\n\n@use \"variables\";\n@use \"tools\";\n@use \"utilities\";\n@use \"components\";\n","@use \"sass:list\";\n@use \"sass:map\";\n@use \"sass:meta\";\n@use \"../variables/borders\";\n@use \"../variables/forms\";\n@use \"../variables/colour\";\n@use \"../variables/features\";\n@use \"../tools/media\";\n\n$base-colours: (\n \"background\",\n // \"background-tint\",\n \"font-base\",\n \"font-dark\",\n \"font-light\",\n \"icon-light\",\n \"link\",\n \"link-visited\",\n // \"focus-outline\",\n \"keyline\",\n \"keyline-dark\",\n // \"input-foreground\",\n // \"input-background\",\n // \"input-border\",\n // \"form-error-border\",\n // \"form-error-text\",\n // \"button-text\",\n // \"button-background\",\n // \"button-hover-text\",\n // \"button-hover-background\",\n);\n\n@function brand-colour($colour, $opacity: 1) {\n @return colour.brand-colour($colour, $opacity);\n}\n\n@mixin colour-css-vars($excludes...) {\n @each $name, $value in colour.$colour-palette-default {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index($base-colours, $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@mixin colour-css-vars-dark($excludes...) {\n @each $name, $value in colour.$colour-palette-dark {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index($base-colours, $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@mixin colour-css-vars-high-contrast($excludes...) {\n @each $name, $value in colour.$colour-palette-high-contrast {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index($base-colours, $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@mixin colour-css-vars-high-contrast-dark($excludes...) {\n @each $name, $value in colour.$colour-palette-high-contrast-dark {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index((\"keyline\", \"keyline-dark\"), $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@function colour-var($colour) {\n @return var(\n --#{$colour},\n #{map.get(colour.$colour-palette-default, $colour)}\n );\n}\n\n@mixin colour-font($colour, $important: false) {\n color: colour-var($colour) if(sass($important): !important; else: null);\n}\n\n@mixin colour-background($colour, $important: false) {\n background-color: colour-var($colour)\n if(sass($important): !important; else: null);\n}\n\n@mixin colour-background-brand($brandColour, $important: false) {\n background-color: #{brand-colour($brandColour)}\n if(sass($important): !important; else: null);\n}\n\n@mixin colour-border(\n $colour,\n $width: \"\",\n $style: solid,\n $direction: \"\",\n $important: false\n) {\n @if $direction != \"\" {\n @if $width != \"\" {\n border-#{$direction}: $width\n colour-var($colour)\n $style\n if(sass($important): !important; else: null);\n } @else {\n border-#{$direction}-color: colour-var($colour)\n if(sass($important): !important; else: null);\n }\n } @else {\n @if $width != \"\" {\n border: $width\n colour-var($colour)\n $style\n if(sass($important): !important; else: null);\n } @else {\n border-color: var(\n --#{$colour},\n #{map.get(colour.$colour-palette-default, $colour)}\n )\n if(sass($important): !important; else: null);\n }\n }\n}\n\n@mixin colour-outline($colour, $width: \"\", $style: solid, $important: false) {\n @if $width != \"\" {\n outline: $width\n colour-var($colour)\n $style\n if(sass($important): !important; else: null);\n } @else {\n outline-color: colour-var($colour)\n if(sass($important): !important; else: null);\n }\n}\n\n@mixin colour-fill($colour, $important: false) {\n fill: colour-var($colour) if(sass($important): !important; else: null);\n}\n\n%colour-input {\n @include colour-font(\"input-foreground\");\n @include colour-background(\"input-background\");\n @include colour-border(\"input-border\", forms.$form-field-border-width);\n}\n\n@mixin colour-input() {\n @extend %colour-input;\n}\n\n@mixin thick-keyline($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\"keyline\", $border-width, solid, $direction);\n } @else {\n @include colour-border(\"keyline\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-dark($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\"keyline-dark\", $border-width, solid, $direction);\n } @else {\n @include colour-border(\"keyline-dark\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-accent($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\"accent-border\", $border-width, solid, $direction);\n } @else {\n @include colour-border(\"accent-border\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-error($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\n \"form-error-border\",\n $border-width,\n solid,\n $direction\n );\n } @else {\n @include colour-border(\"form-error-border\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-brand($direction: \"\", $brandColour, $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n border-#{$direction}: $border-width #{brand-colour($brandColour)} solid;\n } @else {\n border: $border-width #{brand-colour($brandColour)} solid;\n }\n}\n\n@mixin thick-keyline-transparent($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n border-#{$direction}: $border-width transparent solid;\n } @else {\n border: $border-width transparent solid;\n }\n}\n\n// Use light theme colours (except for \"form-error-border\")\n%always-light {\n // @include colour-css-vars(\"form-error-border\", \"focus-outline\");\n @include colour-css-vars;\n\n @media (prefers-contrast: more) {\n // @include colour-css-vars-high-contrast(\n // \"form-error-border\",\n // \"focus-outline\"\n // );\n @include colour-css-vars-high-contrast;\n }\n}\n\n@mixin always-light {\n @extend %always-light;\n}\n\n%contrast {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n}\n\n@mixin contrast {\n @extend %contrast;\n}\n\n%contrast-on-mobile {\n @include media.on-mobile {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n }\n}\n\n@mixin contrast-on-mobile {\n @extend %contrast-on-mobile;\n}\n\n%base {\n @each $name, $value in $base-colours {\n --#{$name}: var(--base-#{$value});\n }\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n}\n\n@mixin base {\n @extend %base;\n}\n\n%tint {\n --background: var(--background-tint);\n\n @include colour-background(\"background\");\n}\n\n@mixin tint {\n @extend %tint;\n}\n\n%accent {\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n --accent-border: var(--accent-font-dark);\n --button-text: var(--accent-button-text);\n --button-background: var(--accent-button-background);\n --button-hover-text: var(--accent-button-hover-text);\n --button-hover-background: var(--accent-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n}\n\n@mixin accent {\n @extend %accent;\n}\n\n%accent-light {\n --background: var(--accent-background-light);\n --font-base: #{map.get(colour.$colour-palette-default, \"font-base\")};\n --font-dark: #{map.get(colour.$colour-palette-default, \"font-dark\")};\n --font-light: #{map.get(colour.$colour-palette-default, \"font-light\")};\n --icon-light: #{map.get(colour.$colour-palette-default, \"icon-light\")};\n --keyline: #{map.get(colour.$colour-palette-default, \"keyline\")};\n --keyline-dark: #{map.get(colour.$colour-palette-default, \"keyline-dark\")};\n --button-text: #{map.get(colour.$colour-palette-default, \"button-text\")};\n --button-background: #{map.get(\n colour.$colour-palette-default,\n \"button-background\"\n )};\n --button-hover-text: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-text\"\n )};\n --button-hover-background: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-background\"\n )};\n --accent-border: var(--accent-background);\n\n @include colour-background(\"background\");\n @include colour-font(\"font-base\");\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n // --link: #{map.get(colour.$colour-palette-default, \"link\")};\n // --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n --accent-border: var(--accent-font-dark);\n --button-text: var(--accent-button-text);\n --button-background: var(--accent-button-background);\n --button-hover-text: var(--accent-button-hover-text);\n --button-hover-background: var(--accent-button-hover-background);\n }\n }\n\n .tna-template--dark-theme & {\n // --link: #{map.get(colour.$colour-palette-default, \"link\")};\n // --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n --accent-border: var(--accent-font-dark);\n --button-text: var(--accent-button-text);\n --button-background: var(--accent-button-background);\n --button-hover-text: var(--accent-button-hover-text);\n --button-hover-background: var(--accent-button-hover-background);\n }\n}\n\n@mixin accent-light {\n @extend %accent-light;\n}\n\n%yellow-accent {\n --accent-background: #{colour.brand-colour(\"yellow\")} !important;\n --accent-background-light: #{colour.brand-colour(\"cream\")} !important;\n --accent-border: #{colour.brand-colour(\"yellow\")} !important;\n --accent-font-base: #{colour.brand-colour(\"black\")} !important;\n --accent-font-dark: #{colour.brand-colour(\"black\")} !important;\n --accent-font-light: #{colour.brand-colour(\"black\", 0.7)} !important;\n --accent-icon-light: #{colour.brand-colour(\"black\", 0.7)} !important;\n --accent-link: #{colour.brand-colour(\"black\")} !important;\n --accent-link-visited: #{colour.brand-colour(\"black\")} !important;\n --accent-keyline: #{colour.brand-colour(\"black\", 0.5)} !important;\n --accent-keyline-dark: #{colour.brand-colour(\"black\", 0.8)} !important;\n --button-accented-text: #{colour.brand-colour(\"white\")} !important;\n --button-accented-background: #{colour.brand-colour(\"brown\")} !important;\n}\n\n@mixin yellow-accent {\n @extend %yellow-accent;\n}\n\n%accent-lighter-text {\n --accent-font-base: #{colour.brand-colour(\"white\")} !important;\n --accent-font-dark: #{colour.brand-colour(\"white\")} !important;\n --accent-font-light: #{colour.brand-colour(\"white\", 0.7)} !important;\n --accent-icon-light: #{colour.brand-colour(\"white\", 0.7)} !important;\n --accent-link: #{colour.brand-colour(\"white\")} !important;\n --accent-link-visited: #{colour.brand-colour(\"white\")} !important;\n --accent-keyline: #{colour.brand-colour(\"white\", 0.5)} !important;\n --accent-keyline-dark: #{colour.brand-colour(\"white\", 0.8)} !important;\n --button-accented-text: #{colour.brand-colour(\"white\")} !important;\n}\n\n%black-accent {\n --accent-background: #{colour.brand-colour(\"black\")} !important;\n --accent-background-light: #{colour.brand-colour(\"light-grey\")} !important;\n --accent-border: #{colour.brand-colour(\"black\")} !important;\n --button-accented-text: #{colour.brand-colour(\"black\")} !important;\n --button-accented-background: #{colour.brand-colour(\"grey\")} !important;\n}\n\n@mixin black-accent {\n @extend %accent-lighter-text;\n @extend %black-accent;\n}\n\n%pink-accent {\n --accent-background: #{colour.brand-colour(\"maroon\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-pink\")} !important;\n --accent-border: #{colour.brand-colour(\"pink\")} !important;\n --button-accented-background: #{colour.brand-colour(\"maroon\")} !important;\n}\n\n@mixin pink-accent {\n @extend %accent-lighter-text;\n @extend %pink-accent;\n}\n\n%orange-accent {\n --accent-background: #{colour.brand-colour(\"chestnut\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-orange\")} !important;\n --accent-border: #{colour.brand-colour(\"orange\")} !important;\n --button-accented-background: #{colour.brand-colour(\"chestnut\")} !important;\n}\n\n@mixin orange-accent {\n @extend %accent-lighter-text;\n @extend %orange-accent;\n}\n\n%green-accent {\n --accent-background: #{colour.brand-colour(\"forest\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-green\")} !important;\n --accent-border: #{colour.brand-colour(\"green\")} !important;\n --button-accented-background: #{colour.brand-colour(\"forest\")} !important;\n}\n\n@mixin green-accent {\n @extend %accent-lighter-text;\n @extend %green-accent;\n}\n\n%blue-accent {\n --accent-background: #{colour.brand-colour(\"navy\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-blue\")} !important;\n --accent-border: #{colour.brand-colour(\"blue\")} !important;\n --button-accented-background: #{colour.brand-colour(\"navy\")} !important;\n}\n\n@mixin blue-accent {\n @extend %accent-lighter-text;\n @extend %blue-accent;\n}\n\n@mixin on-high-contrast {\n @media (prefers-contrast: more) {\n @content;\n }\n}\n\n@mixin on-forced-colours {\n @media (forced-colors: active) {\n @content;\n }\n}\n\n@mixin on-high-contrast-and-forced-colours {\n @include on-forced-colours {\n @content;\n }\n\n @include on-high-contrast {\n @content;\n }\n}\n\n%image-loader-background {\n background: linear-gradient(\n -45deg,\n rgb(0 0 0 / 25%),\n rgb(255 255 255 / 25%),\n rgb(0 0 0 / 25%)\n );\n background-size: 500% 500%;\n background-position: 0 50%;\n\n animation: image-loader-background ease-in-out 1.2s infinite;\n\n @media (prefers-reduced-motion) {\n animation: none !important;\n }\n}\n\n@mixin image-loader-background {\n @if features.$image-loader-animations {\n @extend %image-loader-background;\n }\n}\n","@use \"sass:math\";\n@use \"../variables/media\";\n@use \"../variables/typography\";\n\n$smallest-large-device-em: #{math.div(\n media.$largest-medium-device-px + 1,\n typography.$relative-1rem-px\n )}em;\n$largest-medium-device-em: #{math.div(\n media.$largest-medium-device-px,\n typography.$relative-1rem-px\n )}em;\n$smallest-medium-device-em: #{math.div(\n media.$largest-small-device-px + 1,\n typography.$relative-1rem-px\n )}em;\n$largest-small-device-em: #{math.div(\n media.$largest-small-device-px,\n typography.$relative-1rem-px\n )}em;\n$smallest-small-device-em: #{math.div(\n media.$largest-tiny-device-px + 1,\n typography.$relative-1rem-px\n )}em;\n$largest-tiny-device-em: #{math.div(\n media.$largest-tiny-device-px,\n typography.$relative-1rem-px\n )}em;\n\n$media-large: \"(min-width: #{$smallest-large-device-em})\";\n$media-lt-large: \"(max-width: #{$largest-medium-device-em})\";\n$media-medium: \"(min-width: #{$smallest-medium-device-em}) and (max-width: #{$largest-medium-device-em})\";\n$media-gt-mobile: \"(min-width: #{$smallest-medium-device-em})\";\n$media-mobile: \"(max-width: #{$largest-small-device-em})\";\n$media-small: \"(min-width: #{$smallest-small-device-em}) and (max-width: #{$largest-small-device-em})\";\n$media-gt-tiny: \"(min-width: #{$smallest-small-device-em})\";\n$media-tiny: \"(max-width: #{$largest-tiny-device-em})\";\n\n// https://nationalarchives.github.io/design-system/styles/media/#media-queries\n@mixin on-large() {\n @media #{$media-large} {\n @content;\n }\n}\n\n@mixin on-medium() {\n @media #{$media-medium} {\n @content;\n }\n}\n\n@mixin on-small() {\n @media #{$media-small} {\n @content;\n }\n}\n\n@mixin on-tiny() {\n @media #{$media-tiny} {\n @content;\n }\n}\n\n@mixin on-larger-than-mobile() {\n @media #{$media-gt-mobile} {\n @content;\n }\n}\n\n@mixin on-larger-than-tiny() {\n @media #{$media-gt-tiny} {\n @content;\n }\n}\n\n@mixin on-smaller-than-large() {\n @media #{$media-lt-large} {\n @content;\n }\n}\n\n@mixin on-mobile() {\n @media #{$media-mobile} {\n @content;\n }\n}\n\n@mixin on-print() {\n @media print {\n @content;\n }\n}\n","@use \"../variables/a11y\";\n@use \"colour\";\n@use \"borders\";\n\n@mixin visually-hidden {\n width: 1px !important;\n height: 1px !important;\n margin: 0 !important;\n padding: 0 !important;\n\n overflow: hidden !important;\n\n position: absolute !important;\n top: -9999px !important;\n left: -9999px !important;\n z-index: -1 !important;\n\n background-color: transparent !important;\n\n border: 0 !important;\n\n -webkit-clip-path: inset(50%) !important;\n clip-path: inset(50%) !important;\n}\n\n%focus-outline {\n outline: a11y.$focus-outline-outer-width #000 solid !important;\n outline-offset: a11y.$focus-outline-inner-width !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-inner-width\n colour.brand-colour(\"yellow\") !important;\n\n transition:\n outline-offset 0.1s,\n box-shadow 0.1s;\n\n .tna-template--dark-theme & {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-inner-width #000 !important;\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-inner-width #000 !important;\n }\n }\n}\n\n@mixin focus-outline {\n @extend %focus-outline;\n}\n\n@mixin no-focus-outline {\n outline: none !important;\n\n box-shadow: none !important;\n}\n\n%active-outline {\n outline: a11y.$focus-outline-active-outer-width #000 solid !important;\n outline-offset: a11y.$focus-outline-active-inner-width !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-active-inner-width\n colour.brand-colour(\"yellow\") !important;\n\n transition: none;\n\n .tna-template--dark-theme & {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-active-inner-width #000 !important;\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-active-inner-width #000 !important;\n }\n }\n}\n\n@mixin active-outline {\n @extend %active-outline;\n}\n\n%faux-full-outline {\n position: relative;\n}\n\n%faux-full-outline-anchor {\n &::before {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: 9;\n\n @include borders.rounded-border;\n }\n\n &:focus,\n &:active {\n @include no-focus-outline;\n }\n\n &:focus {\n &::before {\n @include focus-outline;\n }\n }\n\n &:active {\n &::before {\n @include active-outline;\n }\n }\n}\n\n@mixin faux-full-outline($anchor_selector) {\n @extend %faux-full-outline;\n\n #{$anchor_selector} {\n @extend %faux-full-outline-anchor;\n }\n}\n","@use \"../variables/borders\";\n\n@mixin rounded-border {\n border-radius: borders.$rounded-border-radius;\n}\n","$thick-border-width: 5px !default;\n$very-thick-border-width: 8px !default;\n$rounded-border-radius: 2px !default;\n","@use \"sass:map\";\n@use \"sass:math\";\n@use \"../variables/spacing\";\n@use \"../variables/typography\";\n@use \"../tools/media\";\n\n/*\n * ------------------------------------------\n * Spacing is created with rem rather than px\n * units as when users use a custom font size\n * some browsers handle the resize of rem and\n * em separately from px which causes spacing\n * and layout issues, so to ensure everything\n * remaians consistent we use rem for spacing\n * and typography. The original intention was\n * separation so that we could scale the type\n * without affecting spacing, but in practice\n * there are too many ways to change the font\n * size in various browsers and devices\n * ------------------------------------------\n */\n@function space($size) {\n // @return #{$size * spacing.$spacing-unit-px}px;\n @return #{$size}rem;\n}\n\n%space-above {\n margin-top: space(2);\n @extend %no-space-above-for-first-children;\n}\n\n%space-only-above {\n margin: #{space(2)} 0 0;\n @extend %no-space-above-for-first-children;\n}\n\n%no-space-above-for-first-children {\n &:first-child {\n margin-top: 0;\n }\n}\n\n@mixin space-above($zero-other-margins: false) {\n @if $zero-other-margins {\n @extend %space-only-above;\n } @else {\n @extend %space-above;\n }\n}\n\n@mixin no-spacing-generator($suffix: \"\") {\n @if $suffix != \"\" {\n $suffix: \"-\" + $suffix;\n }\n @each $property in margin, padding {\n @each $direction in top, bottom {\n $combined-direction: \"\";\n @if $direction == top or $direction == bottom {\n $combined-direction: vertical;\n } @else if $direction == right or $direction == left {\n $combined-direction: horizontal;\n }\n @if $combined-direction {\n .tna-\\!--no-#{$property}-#{$direction}#{$suffix},\n .tna-\\!--no-#{$property}-#{$combined-direction}#{$suffix} {\n #{$property}-#{$direction}: 0 !important;\n }\n } @else {\n .tna-\\!--no-#{$property}-#{$direction}#{$suffix} {\n #{$property}-#{$direction}: 0 !important;\n }\n }\n }\n }\n}\n\n@mixin spacing-generator($suffix: \"\") {\n @each $property in margin, padding {\n @each $direction in top, bottom {\n @each $size, $amount in spacing.$spacing {\n @if $direction == all {\n .tna-\\!--#{$property}-#{$size} {\n #{$property}: #{space($amount)} !important;\n }\n } @else {\n $combined-direction: \"\";\n @if $direction == top or $direction == bottom {\n $combined-direction: vertical;\n } @else if $direction == right or $direction == left {\n $combined-direction: horizontal;\n }\n @if $combined-direction {\n .tna-\\!--#{$property}-#{$direction}-#{$size},\n .tna-\\!--#{$property}-#{$combined-direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n } @else {\n .tna-\\!--#{$property}-#{$direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n }\n }\n }\n }\n }\n\n @include media.on-mobile {\n @each $property in margin, padding {\n @each $direction in top, bottom {\n @each $size, $amount in spacing.$spacing-mobile {\n @if $direction == all {\n .tna-\\!--#{$property}-#{$size} {\n #{$property}: #{space($amount)} !important;\n }\n } @else {\n $combined-direction: \"\";\n @if $direction == top or $direction == bottom {\n $combined-direction: vertical;\n } @else if $direction == right or $direction == left {\n $combined-direction: horizontal;\n }\n @if $combined-direction {\n .tna-\\!--#{$property}-#{$direction}-#{$size},\n .tna-\\!--#{$property}-#{$combined-direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n } @else {\n .tna-\\!--#{$property}-#{$direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n }\n }\n }\n }\n }\n }\n}\n","@use \"../../tools/a11y\";\n\n.tna-visually-hidden,\n.tna-\\!--visually-hidden {\n @include a11y.visually-hidden;\n}\n\n*:focus,\n*:focus-visible,\n*:active {\n z-index: 9;\n}\n\n*:focus-visible {\n @include a11y.focus-outline;\n}\n\n@supports not selector(:focus-visible) {\n *:focus {\n z-index: 9;\n\n @include a11y.focus-outline;\n }\n}\n\na,\nbutton,\ninput,\ntextarea,\nselect,\nsummary {\n &:active {\n @include a11y.active-outline;\n }\n}\n\n[tabindex=\"-1\"] *:focus-visible,\n[tabindex=\"-1\"] *:focus,\n.tna-\\!--no-focus-style:focus-visible,\n.tna-\\!--no-focus-style:focus {\n @include a11y.no-focus-outline;\n}\n","@keyframes image-loader-background {\n 0%,\n 100% {\n background-position: 0 50%;\n }\n\n 50% {\n background-position: 100% 50%;\n }\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n\n.tna-section {\n padding-top: spacing.space(3);\n padding-bottom: spacing.space(3);\n}\n\n.tna-aside {\n @include spacing.space-above;\n padding: spacing.space(2);\n\n @include borders.rounded-border;\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n\n &--tight {\n padding: spacing.space(1);\n }\n}\n\n@include media.on-mobile {\n .tna-section {\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n }\n\n .tna-aside {\n padding: spacing.space(1);\n }\n}\n","@use \"../../tools/colour\";\n\n.tna-template {\n @include colour.always-light;\n\n @include colour.colour-background(\"background\");\n\n &--system-theme {\n @media (prefers-color-scheme: dark) {\n @include colour.colour-css-vars-dark;\n }\n\n @media (prefers-contrast: more) and (prefers-color-scheme: dark) {\n @include colour.colour-css-vars-high-contrast-dark;\n }\n }\n\n &--dark-theme {\n @include colour.colour-css-vars-dark;\n\n @media (prefers-contrast: more) {\n @include colour.colour-css-vars-high-contrast-dark;\n }\n }\n\n &--black-accent {\n @include colour.black-accent;\n }\n\n &--pink-accent {\n @include colour.pink-accent;\n }\n\n &--orange-accent {\n @include colour.orange-accent;\n }\n\n &--yellow-accent {\n @include colour.yellow-accent;\n }\n\n &--green-accent {\n @include colour.green-accent;\n }\n\n &--blue-accent {\n @include colour.blue-accent;\n }\n}\n\n.tna-background,\n.tna-block {\n &-tint {\n @include colour.tint;\n }\n\n &-contrast {\n @include colour.contrast;\n }\n\n &-accent {\n @include colour.accent;\n }\n\n &-accent-light {\n @include colour.accent-light;\n }\n\n &-base {\n @include colour.base;\n }\n}\n\n.tna-border {\n &-keyline {\n @include colour.colour-border(\"keyline\", 1px);\n }\n\n &-keyline-dark {\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n}\n\n.tna-accent {\n &-black {\n @include colour.black-accent;\n }\n\n &-pink {\n @include colour.pink-accent;\n }\n\n &-orange {\n @include colour.orange-accent;\n }\n\n &-yellow {\n @include colour.yellow-accent;\n }\n\n &-green {\n @include colour.green-accent;\n }\n\n &-blue {\n @include colour.blue-accent;\n }\n}\n","@use \"../../tools/media\";\n@use \"../../tools/grid\";\n\n.tna-columns {\n column-gap: grid.gutter-width();\n\n &--2 {\n column-count: 2;\n }\n\n &--3 {\n column-count: 3;\n }\n\n @include media.on-tiny {\n column-gap: grid.gutter-width-tiny();\n }\n\n @include media.on-small {\n @for $i from 1 through 4 {\n &--#{$i}-small {\n column-count: $i;\n }\n }\n }\n\n @include media.on-tiny {\n @for $i from 1 through 4 {\n &--#{$i}-tiny {\n column-count: $i;\n }\n }\n }\n\n &__block {\n break-inside: avoid;\n }\n\n &:has(&__block:only-of-type) {\n column-count: 1;\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-form-item {\n @include spacing.space-above;\n\n &__header {\n }\n\n &__label {\n display: block;\n }\n\n &__hint {\n margin-top: spacing.space(0.125);\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n }\n\n &__error {\n margin-top: spacing.space(0.25);\n\n @include colour.colour-font(\"form-error-text\");\n @include typography.main-font-weight-bold;\n }\n\n &__body {\n margin-top: spacing.space(0.5);\n\n &:first-child {\n margin-top: 0;\n }\n }\n\n &--error {\n padding-left: spacing.space(1);\n\n @include colour.thick-keyline-error(left);\n }\n}\n","@use \"sass:math\";\n@use \"../variables/typography\";\n@use \"colour\";\n@use \"media\";\n\n@mixin font-size($font-size-px) {\n font-size: #{math.div($font-size-px, typography.$relative-1rem-px)}rem;\n}\n\n@mixin relative-font-size($font-size-px) {\n @warn \"relative-font-size() will soon be deprecated in favour of font-size().\";\n @include font-size($font-size-px);\n}\n\n@mixin main-font-weight {\n font-weight: typography.$main-font-weight;\n}\n\n@mixin main-font-weight-medium {\n font-weight: typography.$main-font-weight-medium;\n}\n\n@mixin main-font-weight-bold {\n font-weight: typography.$main-font-weight-bold;\n}\n\n@mixin main-font($bold: false) {\n font-family: typography.$main-font-family;\n font-style: normal;\n font-optical-sizing: auto;\n font-variation-settings: \"wdth\" 100;\n @if $bold {\n @include main-font-weight-bold;\n } @else {\n @include main-font-weight;\n }\n}\n\n@mixin heading-font {\n font-family: typography.$heading-font-family;\n font-weight: typography.$heading-font-weight;\n}\n\n@mixin detail-font($bold: false) {\n font-family: typography.$detail-font-family;\n font-style: normal;\n font-optical-sizing: auto;\n @if $bold {\n font-weight: typography.$detail-font-weight-bold;\n } @else {\n font-weight: typography.$detail-font-weight;\n }\n}\n\n@mixin detail-font-small {\n @include detail-font;\n @include font-size(14);\n line-height: 1.1;\n text-transform: uppercase;\n}\n\n@mixin interactable-text-decoration {\n text-decoration-thickness: typography.$interactable-text-decoration-thickness;\n text-underline-offset: typography.$interactable-text-decoration-offset;\n}\n\n@mixin interacted-text-decoration {\n text-decoration: underline;\n text-decoration-thickness: typography.$interactive-text-decoration-thickness;\n text-underline-offset: typography.$interactable-text-decoration-offset;\n}\n\n@mixin heading-generator(\n $font-size-default,\n $font-size-medium,\n $font-size-small,\n $font-size-tiny,\n $line-height\n) {\n $small-and-tiny-identical: $font-size-small == $font-size-tiny;\n $medium-small-and-tiny-identical: $font-size-medium == $font-size-small and\n $small-and-tiny-identical;\n $all-identical: $font-size-default == $font-size-medium and\n $medium-small-and-tiny-identical and $small-and-tiny-identical;\n line-height: $line-height;\n @include font-size($font-size-default);\n\n @if $all-identical != true {\n @if $medium-small-and-tiny-identical != true {\n @include media.on-medium {\n @include font-size($font-size-medium);\n }\n\n @if $small-and-tiny-identical != true {\n @include media.on-small {\n @include font-size($font-size-small);\n }\n\n @include media.on-tiny {\n @include font-size($font-size-tiny);\n }\n } @else {\n @include media.on-mobile {\n @include font-size($font-size-small);\n }\n }\n } @else {\n @include media.on-smaller-than-large {\n @include font-size($font-size-medium);\n }\n }\n }\n}\n","@use \"sass:math\";\n\n/*\n * ------------------------------------------\n * The typefaces, sizes and spacings that are\n * defined in this file have been selected to\n * ensure 100% match with the latest National\n * Archives brand guidelines - avoid changing\n * or overwriting any of these values without\n * signing off with the Digital Services team\n * first\n * ------------------------------------------\n */\n\n$relative-1rem-px: 16; // 16px = 1rem\n\n/*\n * ------------------------------------------\n * When true, use the included font files for\n * Open Sans and Roboto Mono, rather than the\n * versions hosted by Google Fonts\n * ------------------------------------------\n */\n$use-local-fonts: false !default;\n\n$body-font-size-px: 19 !default;\n$body-font-size-px-medium: 18 !default;\n$body-font-size-px-mobile: 17 !default;\n$body-line-height: 1.75 !default;\n\n$interactable-text-decoration-offset: 0.125em !default;\n$interactable-text-decoration-thickness: #{math.div(1.5, $relative-1rem-px)}rem !default;\n$interactive-text-decoration-thickness: #{math.div(4, $relative-1rem-px)}rem !default;\n\n$main-font-family-name: \"Open Sans\" !default;\n$main-font-family:\n #{$main-font-family-name},\n sans-serif;\n$main-font-weight: 400 !default;\n$main-font-weight-medium: 600 !default;\n$main-font-weight-bold: 700 !default;\n$main-font-file: \"OpenSans-Regular.ttf\" !default;\n$main-font-file-medium: \"OpenSans-SemiBold.ttf\" !default;\n$main-font-file-bold: \"OpenSans-Bold.ttf\" !default;\n\n/*\n * ------------------------------------------\n * To use Supria Sans Condensed (which is the\n * approved heading typeface for The National\n * Archives), you need to obtain a licence to\n * properly embed the CSS files with the font\n * definitions in your service - check with a\n * member of the Digital Services team on how\n * to get a licence\n * ------------------------------------------\n */\n$heading-font-family-name: \"supria-sans-condensed\" !default;\n$heading-font-family:\n #{$heading-font-family-name},\n \"Arial Narrow\",\n sans-serif;\n$heading-font-weight: 500 !default;\n\n/*\n * ------------------------------------------\n * The detail font should be a monospace font\n * and is used for chips, supertitles as well\n * as the date search component\n * ------------------------------------------\n */\n$detail-font-family-name: \"Roboto Mono\" !default;\n$detail-font-family:\n #{$detail-font-family-name},\n monospace;\n$detail-font-weight: 400 !default;\n$detail-font-weight-bold: 500 !default;\n$detail-font-file: \"RobotoMono-Regular.ttf\" !default;\n$detail-font-file-bold: \"RobotoMono-Medium.ttf\" !default;\n\n$heading-xl-font-size-default: 64 !default;\n$heading-xl-font-size-medium: 48 !default;\n$heading-xl-font-size-small: 36 !default;\n$heading-xl-font-size-tiny: $heading-xl-font-size-small !default;\n$heading-xl-line-height: 1.1 !default;\n\n$heading-l-font-size-default: 36 !default;\n$heading-l-font-size-medium: 32 !default;\n$heading-l-font-size-small: 29 !default;\n$heading-l-font-size-tiny: $heading-l-font-size-small !default;\n$heading-l-line-height: 1.15 !default;\n\n$heading-m-font-size-default: 22 !default;\n$heading-m-font-size-medium: $heading-m-font-size-default !default;\n$heading-m-font-size-small: 21 !default;\n$heading-m-font-size-tiny: $heading-m-font-size-small !default;\n$heading-m-line-height: 1.4 !default;\n\n$heading-s-font-size-default: 19 !default;\n$heading-s-font-size-medium: $heading-s-font-size-default !default;\n$heading-s-font-size-small: $heading-s-font-size-default !default;\n$heading-s-font-size-tiny: $heading-s-font-size-default !default;\n$heading-s-line-height: 1.5 !default;\n",".tna-template {\n /*\n * ------------------------------------------\n * A minimum page width of 320px is needed in\n * order to meet the WCAG AA success criteria\n * for 1.4.10 (Reflow)\n * https://www.w3.org/WAI/WCAG21/Understanding/reflow.html\n * ------------------------------------------\n */\n min-width: 320px;\n width: 100%;\n height: 100%;\n\n /*\n * ------------------------------------------\n * Support ended with iOS 13 released on 19th\n * September 2019. Deprecate in the future if\n * iOS <13 share drops low enough.\n * https://caniuse.com/mdn-css_properties_-webkit-overflow-scrolling\n * ------------------------------------------\n */\n -webkit-overflow-scrolling: touch;\n}\n\n.tna-template__body {\n min-height: 100%;\n margin: 0;\n padding: 0;\n\n &:has(:is(.tna-global-header, .tna-header)):has(.tna-main):has(.tna-footer) {\n display: flex;\n flex-direction: column;\n }\n}\n\n.tna-main {\n flex: 1;\n}\n","@use \"sass:math\";\n@use \"sass:selector\";\n@use \"../../variables/grid\" as gridVars;\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n\n.tna-container {\n width: 100%;\n max-width: gridVars.$largest-container-width;\n margin-right: auto;\n margin-left: auto;\n padding-right: grid.gutter-width-half();\n padding-left: grid.gutter-width-half();\n\n display: flex;\n flex-wrap: wrap;\n align-items: stretch;\n justify-content: flex-start;\n\n box-sizing: border-box;\n\n & &--no-padding {\n max-width: calc(\n #{gridVars.$largest-container-width} - #{grid.gutter-width-double()}\n );\n padding-right: 0;\n padding-left: 0;\n }\n\n &--max {\n max-width: none;\n }\n\n &--centred,\n &--align-centre {\n justify-content: center;\n }\n\n &--align-right {\n justify-content: flex-end;\n }\n\n & &--nested {\n width: auto;\n margin-right: -#{grid.gutter-width()};\n margin-left: -#{grid.gutter-width()};\n }\n\n @at-root #{selector.unify(\"ul, ol\", &)} {\n list-style: none;\n }\n}\n\n.tna-column {\n padding-right: grid.gutter-width-half();\n padding-left: grid.gutter-width-half();\n\n box-sizing: border-box;\n\n & &--no-padding {\n padding-right: 0;\n padding-left: 0;\n }\n\n &--align-top {\n align-self: flex-start;\n }\n\n &--align-centre {\n align-self: center;\n }\n\n &--align-bottom {\n align-self: flex-end;\n }\n}\n\n@include grid.columns-generator(gridVars.$column-count);\n\n@include media.on-medium {\n @include grid.columns-generator(gridVars.$column-count-medium, \"medium\");\n}\n\n@include media.on-small {\n @include grid.columns-generator(gridVars.$column-count-small, \"small\");\n}\n\n@include media.on-tiny {\n .tna-container {\n padding-right: grid.gutter-width-tiny-half();\n padding-left: grid.gutter-width-tiny-half();\n\n & &--nested {\n width: auto;\n margin-right: -#{grid.gutter-width-tiny()};\n margin-left: -#{grid.gutter-width-tiny()};\n }\n }\n\n .tna-column {\n padding-right: grid.gutter-width-tiny-half();\n padding-left: grid.gutter-width-tiny-half();\n }\n\n @include grid.columns-generator(gridVars.$column-count-tiny, \"tiny\");\n}\n","$largest-container-width: 1280px !default;\n\n$gutter-width: 2 !default;\n$gutter-width-tiny: 1 !default;\n\n$column-count: 12;\n$column-count-medium: 6;\n$column-count-small: 4;\n$column-count-tiny: 2;\n","@use \"sass:math\";\n@use \"../variables/grid\";\n@use \"spacing\";\n\n@function gutter-width() {\n @return spacing.space(grid.$gutter-width);\n}\n\n@function gutter-width-half() {\n @return spacing.space(math.div(grid.$gutter-width, 2));\n}\n\n@function gutter-width-double() {\n @return spacing.space(grid.$gutter-width * 2);\n}\n\n@function gutter-width-tiny() {\n @return spacing.space(grid.$gutter-width-tiny);\n}\n\n@function gutter-width-tiny-half() {\n @return spacing.space(math.div(grid.$gutter-width-tiny, 2));\n}\n\n@function gutter-width-tiny-double() {\n @return spacing.space(grid.$gutter-width-tiny * 2);\n}\n\n@mixin columns-generator($count, $suffix: \"\") {\n @if $suffix != \"\" {\n $suffix: \"-\" + $suffix;\n }\n\n .tna-column {\n &--full#{$suffix} {\n width: 100%;\n flex: none;\n }\n\n @for $i from 1 through $count - 1 {\n $simplest-fraction-found: false;\n\n @for $j from math.div($count, 2) through 1 {\n @if (\n $count % $j == 0 and $i % $j == 0 and $simplest-fraction-found != true\n ) {\n &--width-#{math.div($i, $j)}-#{math.div($count, $j)}#{$suffix} {\n width: math.div(100%, $count) * $i;\n flex: none;\n }\n\n &--margin-right-#{math.div($i, $j)}-#{math.div($count, $j)}#{$suffix} {\n margin-right: math.div(100%, $count) * $i;\n }\n\n &--margin-left-#{math.div($i, $j)}-#{math.div($count, $j)}#{$suffix} {\n margin-left: math.div(100%, $count) * $i;\n }\n\n $simplest-fraction-found: true;\n }\n }\n\n @if $simplest-fraction-found != true {\n &--width-#{$i}-#{$count}#{$suffix} {\n width: math.div(100%, $count) * $i;\n flex: none;\n }\n\n &--margin-right-#{$i}-#{$count}#{$suffix} {\n margin-right: math.div(100%, $count) * $i;\n }\n\n &--margin-left-#{$i}-#{$count}#{$suffix} {\n margin-left: math.div(100%, $count) * $i;\n }\n }\n }\n\n @if $suffix != \"\" {\n &--no-margin-right#{$suffix} {\n margin-right: 0;\n }\n\n &--no-margin-left#{$suffix} {\n margin-left: 0;\n }\n }\n\n @for $i from 1 through 3 {\n &--flex-#{$i}#{$suffix} {\n width: auto;\n\n flex: $i 0;\n }\n }\n\n @for $i from 1 through 4 {\n &--order-#{$i}#{$suffix} {\n order: $i;\n }\n }\n }\n}\n","@use \"sass:math\";\n@use \"sass:selector\";\n@use \"../../variables/typography\" as typographyVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-template {\n @include colour.colour-font(\"font-base\");\n @include typography.main-font;\n direction: ltr;\n text-rendering: optimizeLegibility;\n -webkit-text-size-adjust: none;\n text-size-adjust: none;\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n\n @include colour.on-high-contrast {\n @include typography.main-font-weight-medium;\n }\n}\n\n.tna-template__body {\n color: inherit;\n @include typography.font-size(typographyVars.$body-font-size-px);\n line-height: typographyVars.$body-line-height;\n\n @include media.on-medium {\n @include typography.font-size(typographyVars.$body-font-size-px-medium);\n }\n\n @include media.on-mobile {\n @include typography.font-size(typographyVars.$body-font-size-px-mobile);\n }\n}\n\nstrong {\n @include typography.main-font-weight-bold;\n}\n\np {\n @include spacing.space-above;\n\n + p {\n margin-top: spacing.space(1);\n }\n}\n\na {\n @include typography.interactable-text-decoration;\n\n border-radius: 0.1px;\n\n &,\n &:link {\n @include colour.colour-font(\"link\");\n }\n\n &:visited {\n @include colour.colour-font(\"link-visited\");\n }\n\n &:hover,\n &:active {\n @include typography.interacted-text-decoration;\n }\n\n &.tna-link--no-visited-state {\n &:visited {\n @include colour.colour-font(\"link\");\n }\n }\n}\n\nsmall {\n @include typography.font-size(typographyVars.$body-font-size-px * 0.85);\n}\n\n%chip {\n max-width: max-content;\n padding: spacing.space(0.125) spacing.space(0.25);\n\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n @include colour.colour-font(\"font-base\");\n @include typography.detail-font-small;\n line-height: 1;\n text-align: center;\n text-wrap-style: balance;\n\n @include borders.rounded-border;\n\n @at-root #{selector.unify(\"a\", &)} {\n text-decoration: underline;\n\n &:hover {\n text-decoration: underline;\n text-decoration-thickness: 0.1875em;\n text-underline-offset: 0.0625em;\n\n .fa-solid {\n color: inherit;\n }\n }\n }\n\n .fa-solid {\n @include colour.colour-font(\"icon-light\");\n\n @include colour.on-high-contrast {\n @include colour.colour-font(\"icon\");\n }\n }\n}\n\n%chip-plain {\n padding: 0;\n\n text-align: left;\n\n background-color: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n @at-root #{selector.unify(\"a\", &)} {\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n .fa-solid {\n color: inherit;\n }\n }\n}\n\n%chip-accent {\n @include colour.accent;\n\n @include colour.colour-border(\"accent-background\", 2px);\n\n -webkit-print-color-adjust: exact;\n print-color-adjust: exact;\n\n .tna-background-accent &,\n .tna-template--dark-theme .tna-background-accent-light & {\n @include colour.colour-font(\"contrast-font-base\");\n\n @include colour.colour-background(\"contrast-background\");\n\n @include colour.colour-border(\"contrast-background\");\n\n .fa-solid {\n @include colour.colour-font(\"contrast-icon-light\");\n }\n }\n\n .tna-template--system-theme .tna-background-accent-light & {\n @media (prefers-color-scheme: dark) {\n @include colour.colour-font(\"contrast-font-base\");\n\n @include colour.colour-background(\"contrast-background\");\n\n @include colour.colour-border(\"contrast-background\");\n\n .fa-solid {\n @include colour.colour-font(\"contrast-icon-light\");\n }\n }\n }\n}\n\n.tna-chip {\n @extend %chip;\n\n &--plain {\n @extend %chip-plain;\n }\n\n &--black {\n @include colour.black-accent;\n }\n\n &--pink {\n @include colour.pink-accent;\n }\n\n &--orange {\n @include colour.orange-accent;\n }\n\n &--yellow {\n @include colour.yellow-accent;\n }\n\n &--green {\n @include colour.green-accent;\n }\n\n &--blue {\n @include colour.blue-accent;\n }\n\n &:not(&--plain) {\n @extend %chip-accent;\n }\n}\n\n.tna-chip-list {\n @include spacing.space-above;\n\n display: flex;\n flex-wrap: wrap;\n gap: spacing.space(0.5) spacing.space(1.5);\n\n list-style: none;\n\n &__item {\n display: flex;\n align-items: center;\n }\n}\n\n%heading {\n @include colour.colour-font(\"font-dark\");\n text-wrap: pretty;\n\n a {\n display: inline-block;\n\n vertical-align: top;\n\n &::after {\n content: \"\";\n\n width: 0.3125em;\n height: 0.3125em;\n margin-bottom: 0.1em;\n margin-left: 0.375em;\n\n display: inline-block;\n\n vertical-align: middle;\n\n transform: rotate(45deg);\n\n @include colour.colour-border(\"link\", 0.125em, solid, top);\n @include colour.colour-border(\"link\", 0.125em, solid, right);\n }\n\n &:not(.tna-link--no-visited-state):visited {\n &::after {\n @include colour.colour-border(\"link-visited\");\n }\n }\n }\n\n strong {\n font-weight: inherit;\n }\n}\n\n%heading-xl {\n @extend %heading;\n\n @include typography.heading-font;\n @include typography.heading-generator(\n typographyVars.$heading-xl-font-size-default,\n typographyVars.$heading-xl-font-size-medium,\n typographyVars.$heading-xl-font-size-small,\n typographyVars.$heading-xl-font-size-tiny,\n typographyVars.$heading-xl-line-height\n );\n}\n\n%heading-l {\n @extend %heading;\n\n @include typography.heading-font;\n @include typography.heading-generator(\n typographyVars.$heading-l-font-size-default,\n typographyVars.$heading-l-font-size-medium,\n typographyVars.$heading-l-font-size-small,\n typographyVars.$heading-l-font-size-tiny,\n typographyVars.$heading-l-line-height\n );\n\n a {\n &::after {\n width: 0.275em;\n height: 0.275em;\n margin-bottom: 0;\n margin-left: 0.25em;\n\n border-top-width: 0.1em;\n border-right-width: 0.1em;\n }\n }\n}\n\n%heading-m {\n @extend %heading;\n\n @include typography.main-font-weight-bold;\n @include typography.heading-generator(\n typographyVars.$heading-m-font-size-default,\n typographyVars.$heading-m-font-size-medium,\n typographyVars.$heading-m-font-size-small,\n typographyVars.$heading-m-font-size-tiny,\n typographyVars.$heading-m-line-height\n );\n}\n\n%heading-s {\n @extend %heading;\n\n @include typography.main-font-weight-bold;\n @include typography.heading-generator(\n typographyVars.$heading-s-font-size-default,\n typographyVars.$heading-s-font-size-medium,\n typographyVars.$heading-s-font-size-small,\n typographyVars.$heading-s-font-size-tiny,\n typographyVars.$heading-s-line-height\n );\n}\n\n%heading-xs {\n @extend %heading;\n\n @include typography.main-font-weight;\n\n font-size: 1em;\n line-height: typographyVars.$heading-s-line-height;\n}\n\n%headings-and-heading-groups {\n @include spacing.space-above;\n margin-bottom: 0;\n padding: spacing.space(1) 0 0;\n\n &:first-child {\n padding-top: 0;\n }\n\n + p,\n + .tna-large-paragraph,\n + .tna-scene-setter {\n margin-top: spacing.space(1);\n }\n}\n\n.tna-heading {\n &-xl {\n @extend %heading-xl;\n @extend %headings-and-heading-groups;\n }\n\n &-l {\n @extend %heading-l;\n @extend %headings-and-heading-groups;\n }\n\n &-m {\n @extend %heading-m;\n @extend %headings-and-heading-groups;\n }\n\n &-s {\n @extend %heading-s;\n @extend %headings-and-heading-groups;\n }\n\n &-xs {\n @extend %heading-xs;\n @extend %headings-and-heading-groups;\n }\n\n &--no-link-arrow {\n a {\n &::after {\n display: none;\n }\n }\n }\n}\n\n.tna-hgroup {\n &-xl,\n &-l,\n &-m,\n &-s {\n @extend %headings-and-heading-groups;\n }\n\n &__supertitle {\n margin: 0 0 spacing.space(0.25);\n\n @extend %chip;\n\n &--plain {\n @extend %chip-plain;\n }\n\n &:not(&--plain) {\n @extend %chip-accent;\n }\n }\n\n &__title {\n margin: 0;\n\n display: block;\n }\n\n &-xl &__title {\n @extend %heading-xl;\n }\n\n &-l &__title {\n @extend %heading-l;\n }\n\n &-m &__title {\n @extend %heading-m;\n }\n\n &-s &__title {\n @extend %heading-s;\n }\n}\n\n.tna-blockquote {\n @include spacing.space-above;\n margin-right: 0;\n margin-bottom: 0;\n margin-left: 0;\n padding: spacing.space(1) spacing.space(1) spacing.space(1) spacing.space(2);\n\n @include colour.thick-keyline-accent(left);\n\n // &::before {\n // content: \"\\201C\";\n\n // display: block;\n\n // font-family: Georgia, \"Times New Roman\", Times, serif;\n // font-size: 3em;\n // line-height: 1;\n // @include colour.colour-font(\"font-light\");\n // }\n\n &__quote {\n @include typography.main-font-weight-medium;\n quotes: auto;\n quotes: \"‘\" \"’\";\n\n &:has(:is(ul, ol)) {\n quotes: none;\n }\n\n > :first-child::before {\n content: open-quote;\n }\n\n > :last-child::after {\n content: close-quote;\n }\n }\n\n &__citation {\n margin-top: spacing.space(1);\n\n @include typography.font-size(16);\n\n &::before {\n content: \"\\2014\" \" \";\n content: \"\\2014\" \" \" / \"\";\n }\n }\n\n @include media.on-tiny {\n padding: spacing.space(0.5) spacing.space(0.5) spacing.space(0.5)\n #{spacing.space(1)};\n }\n}\n\n.tna-large-paragraph {\n @include spacing.space-above;\n\n @include typography.font-size(22);\n @include colour.colour-font(\"font-dark\");\n\n @include media.on-mobile {\n @include typography.font-size(20);\n }\n\n &--bold {\n @include colour.colour-font(\"font-base\");\n @include typography.main-font-weight-medium;\n }\n}\n\n.tna-scene-setter {\n @include spacing.space-above;\n\n @include typography.detail-font;\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(22);\n line-height: 1.7;\n\n @include media.on-mobile {\n @include typography.font-size(20);\n }\n}\n\naddress {\n line-height: 1.375;\n font-style: inherit;\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n@use \"../../utilities/typography\" as typographyUtils;\n\nul {\n list-style-type: disc;\n\n & & {\n list-style-type: circle;\n }\n\n & & & {\n list-style-type: square;\n }\n\n & & & & {\n list-style-type: disc;\n }\n}\n\nol {\n list-style-type: decimal;\n\n & & {\n list-style-type: lower-alpha;\n }\n\n & & & {\n list-style-type: lower-roman;\n }\n\n & & & & {\n list-style-type: decimal;\n }\n}\n\n.tna-ul,\n.tna-ol {\n margin-top: spacing.space(1);\n padding-left: spacing.space(2.5);\n\n &:first-child {\n margin-top: 0;\n }\n\n &--plain {\n padding-left: 0;\n\n list-style: none !important;\n\n > li::marker {\n content: \"\";\n }\n }\n\n > li {\n &::marker {\n @include typography.main-font-weight-medium;\n }\n }\n\n &--dashed {\n > li::marker {\n content: \"— \";\n @include typography.main-font-weight;\n }\n }\n\n &--spaced > li + li {\n margin-top: spacing.space(0.5);\n }\n\n &:not(&--plain) > li > & {\n padding-left: spacing.space(1.25);\n }\n}\n\n.tna-dl-chips {\n @include spacing.space-above(true);\n\n display: flex;\n flex-wrap: wrap;\n gap: spacing.space(0.75) spacing.space(1.5);\n\n @extend %chip-plain;\n\n > dt {\n position: absolute;\n\n font-size: 0;\n }\n\n &__item {\n @extend %chip;\n }\n\n a#{&}__item {\n cursor: pointer;\n }\n\n &:not(&--plain) {\n gap: spacing.space(0.5) spacing.space(1);\n }\n\n &--plain &__item {\n @extend %chip-plain;\n }\n\n &:not(&--plain) &__item {\n @extend %chip-accent;\n }\n\n &--plain a#{&}__item {\n @include colour.colour-font(\"link\");\n }\n\n &--stacked {\n flex-direction: column;\n }\n}\n\n@mixin stacked-dl {\n display: block;\n\n &--lined {\n padding-bottom: 0;\n\n > dd {\n border-top: none;\n\n padding-top: 0;\n padding-bottom: spacing.space(0.5);\n }\n }\n\n &--zebra {\n > dt {\n --background: var(--background-tint);\n\n @include colour.colour-background(\"background\");\n }\n\n > dd:nth-child(1n) {\n background: none;\n }\n }\n}\n\n.tna-dl {\n @include spacing.space-above;\n\n display: grid;\n grid-template-columns: auto;\n gap: spacing.space(0.5) 0;\n\n &--left-weighted {\n grid-template-columns: 2fr 1fr;\n }\n\n &--right-weighted {\n grid-template-columns: 1fr 2fr;\n }\n\n > dt,\n > dd {\n margin: 0;\n\n overflow-wrap: break-word;\n }\n\n > dt {\n @include typography.main-font-weight-bold;\n position: relative;\n\n .fa-solid,\n .fa-brands {\n display: block;\n\n position: absolute;\n top: 0;\n left: 0;\n\n line-height: inherit;\n @include colour.colour-font(\"icon-light\");\n }\n }\n\n &:has(> dt > .fa-solid, > dt > .fa-brands) {\n > dt {\n padding-left: spacing.space(2);\n }\n }\n\n > dd {\n padding-left: spacing.space(2);\n\n grid-column-start: 2;\n }\n\n &--lined {\n padding-bottom: spacing.space(0.5);\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n /* stylelint-disable-next-line no-descending-specificity */\n > dt,\n > dd {\n padding-top: spacing.space(0.5);\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n\n .fa-solid,\n .fa-brands {\n top: spacing.space(0.5);\n }\n }\n }\n\n &--zebra {\n gap: 0;\n\n /* stylelint-disable-next-line no-descending-specificity */\n > dt,\n > dd {\n padding: spacing.space(0.5) spacing.space(1) spacing.space(0.5)\n spacing.space(1);\n }\n\n > dt {\n .fa-solid,\n .fa-brands {\n top: spacing.space(0.5);\n left: spacing.space(1);\n }\n }\n\n > dt:first-child,\n > dd:nth-of-type(2n) + dt,\n > dd:nth-of-type(2n + 1) {\n @include colour.tint;\n }\n\n &:has(> dt > .fa-solid, > dt > .fa-brands) {\n > dt {\n padding-left: spacing.space(3);\n }\n }\n }\n\n &--stacked#{&} {\n @include stacked-dl;\n }\n\n @include media.on-mobile {\n @include stacked-dl;\n }\n}\n\nli,\ndd {\n p {\n margin-top: spacing.space(0.25);\n\n &:first-child {\n margin-top: 0;\n }\n }\n}\n",".tna-logo {\n width: 6rem;\n aspect-ratio: 1;\n\n display: block;\n\n svg {\n width: 100%;\n height: 100%;\n }\n\n &__background {\n fill: transparent;\n }\n\n &__foreground {\n fill: currentColor;\n }\n\n &--solid &__background {\n fill: #fff;\n }\n\n &--solid &__foreground {\n fill: #010101;\n }\n}\n","@use \"sass:map\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n\n@mixin hide-on($suffix) {\n .tna-\\!--hide-on-#{$suffix} {\n display: none !important;\n }\n}\n\n@include spacing.no-spacing-generator;\n@include spacing.spacing-generator;\n\n@include media.on-large {\n @include spacing.no-spacing-generator(\"large\");\n @include hide-on(\"large\");\n}\n\n@include media.on-medium {\n @include spacing.no-spacing-generator(\"medium\");\n @include hide-on(\"medium\");\n}\n\n@include media.on-small {\n @include spacing.no-spacing-generator(\"small\");\n @include hide-on(\"small\");\n}\n\n@include media.on-tiny {\n @include spacing.no-spacing-generator(\"tiny\");\n @include hide-on(\"tiny\");\n}\n\n.tna-\\!--hide-on-print {\n @media print {\n display: none;\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/typography\";\n\n* {\n margin: 0;\n padding: 0;\n\n @media (prefers-contrast: more) {\n background-image: none;\n }\n}\n\n/*\n * ------------------------------------------\n * Disable the \"Auto dark mode\" feature as we\n * have our own dark theme\n * ------------------------------------------\n */\n:root {\n color-scheme: only light;\n}\n\n/*\n * ------------------------------------------\n * If the browser supports -apple-system-body\n * which at the moment is just iOS then using\n * the system body font we can respond to the\n * Dynamic Type setting in iOS, however we do\n * disable it for any non-touch Apple devices\n * such as Mac OS, because the default system\n * font size is set to 13px rather than 16px\n * ------------------------------------------\n */\n@supports (font: -apple-system-body) and (-webkit-touch-callout: default) {\n html {\n /* stylelint-disable-next-line font-family-no-missing-generic-family-keyword */\n font: -apple-system-body;\n }\n}\n\nimg,\nsvg,\npicture,\nvideo,\ncanvas {\n max-width: 100%;\n height: auto;\n\n display: block;\n}\n\nbutton,\ninput,\nselect,\ntextarea {\n font-family: inherit;\n font-size: inherit;\n}\n\n[hidden] {\n display: none !important;\n}\n\nhr {\n @include colour.colour-border(\"keyline\", 0, solid);\n border-top-width: 1px;\n\n &.tna-hr-dark {\n @include colour.colour-border(\"keyline-dark\");\n }\n}\n","@use \"sass:math\";\n@use \"sass:selector\";\n@use \"../../variables/a11y\" as a11yVariables;\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n$table-overflow-shadow-width: 1.25rem;\n$table-overflow-shadow-colour: rgb(0 0 0 / 40%);\n$table-overflow-shadow-colour-hidden: rgb(0 0 0 / 0%);\n\n@property --overflow-shadow-start {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #{$table-overflow-shadow-colour-hidden};\n}\n\n@property --overflow-shadow-end {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #{$table-overflow-shadow-colour-hidden};\n}\n\n@keyframes overflow-shadows {\n 0% {\n --overflow-shadow-start: #{$table-overflow-shadow-colour-hidden};\n --overflow-shadow-end: #{$table-overflow-shadow-colour};\n }\n\n 5% {\n --overflow-shadow-start: #{$table-overflow-shadow-colour};\n }\n\n 95% {\n --overflow-shadow-end: #{$table-overflow-shadow-colour};\n }\n\n 100% {\n --overflow-shadow-start: #{$table-overflow-shadow-colour};\n --overflow-shadow-end: #{$table-overflow-shadow-colour-hidden};\n }\n}\n\n.tna-table {\n @include spacing.space-above;\n max-width: 100%;\n margin-bottom: spacing.space(4);\n\n position: relative;\n z-index: 1;\n\n text-align: left;\n\n border-collapse: collapse;\n\n &:last-child {\n margin-bottom: 0;\n }\n\n &__caption {\n width: 100%;\n padding: spacing.space(1) 0 0;\n\n caption-side: bottom;\n\n @include typography.font-size(16);\n }\n\n &__head {\n vertical-align: bottom;\n }\n\n &__body {\n vertical-align: top;\n }\n\n &__foot {\n @include typography.main-font-weight-bold;\n vertical-align: top;\n }\n\n &__row {\n }\n\n &__header {\n }\n\n &__cell {\n }\n\n &__header,\n &__cell {\n padding: spacing.space(0.25) spacing.space(1);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &:first-child {\n padding-left: 0;\n }\n\n &:last-child {\n padding-right: 0;\n }\n\n &--numeric {\n text-align: right;\n }\n\n &--align-left {\n text-align: left;\n }\n\n &--align-centre {\n text-align: center;\n }\n\n &--align-right {\n text-align: right;\n }\n\n &--align-justify {\n text-align: justify;\n }\n\n &--align-top {\n vertical-align: top;\n }\n\n &--align-middle {\n vertical-align: middle;\n }\n\n &--align-bottom {\n vertical-align: bottom;\n }\n }\n\n &__head &__header {\n @include colour.thick-keyline-dark(bottom);\n }\n\n &__foot &__header,\n &__foot &__cell {\n @include colour.thick-keyline-dark(top);\n }\n\n p {\n + p {\n margin-top: spacing.space(0.25);\n }\n }\n\n &--full {\n width: 100%;\n }\n}\n\n.tna-table-wrapper {\n @include spacing.space-above;\n margin-bottom: spacing.space(4);\n\n overflow: auto;\n\n background:\n linear-gradient(\n to right,\n colour.colour-var(\"background\") 50%,\n rgb(255 255 255 / 0%)\n ),\n linear-gradient(\n to right,\n rgb(255 255 255 / 0%),\n colour.colour-var(\"background\") 50%\n )\n 0 100%,\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at left center,\n #{$table-overflow-shadow-colour},\n #{$table-overflow-shadow-colour-hidden}\n ),\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at right center,\n #{$table-overflow-shadow-colour},\n #{$table-overflow-shadow-colour-hidden}\n )\n 0 100% transparent;\n background-size:\n #{$table-overflow-shadow-width * 2} 100%,\n #{$table-overflow-shadow-width * 2} 100%,\n 100% 100%,\n 100% 100%;\n background-repeat: no-repeat;\n background-position:\n 0 0,\n 100%,\n 0 0,\n 100%;\n background-attachment: local, local, scroll, scroll;\n\n border-radius: 0.1px;\n\n container-type: inline-size;\n\n contain: paint;\n\n /*\n * ------------------------------------------\n * Can remove the @supports rule when support\n * for the scroll-driven animations below has\n * been enabled by default in Firefox and the\n * documented scroll-timeline syntax (x and y\n * as opposed to vertical and horizontal) can\n * be used\n * https://caniuse.com/mdn-css_properties_animation-timeline_view\n * ------------------------------------------\n */\n @supports (scroll-timeline: --overflow-shadows x) {\n background:\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at left center,\n var(--overflow-shadow-start),\n #{$table-overflow-shadow-colour-hidden}\n ),\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at right center,\n var(--overflow-shadow-end),\n #{$table-overflow-shadow-colour-hidden}\n )\n transparent;\n background-position: 0;\n\n animation: overflow-shadows 1ms linear;\n animation-timeline: --overflow-shadows;\n scroll-timeline: --overflow-shadows x;\n }\n\n &:last-child {\n margin-bottom: 0;\n }\n\n &:focus:not(:focus-visible) {\n @include a11y.no-focus-outline;\n }\n\n .tna-table {\n &__caption {\n max-width: calc(100vw - #{grid.gutter-width-double()});\n max-width: 100cqw;\n\n position: sticky;\n left: 0;\n\n @include media.on-tiny {\n max-width: calc(100vw - #{grid.gutter-width-tiny-double()});\n max-width: 100cqw;\n }\n }\n }\n\n // &--sticky-first-column {\n // background: radial-gradient(\n // ellipse #{$table-overflow-shadow-width} 50% at right center,\n // var(--overflow-shadow-end),\n // #{$table-overflow-shadow-colour-hidden}\n // )\n // transparent;\n\n // .tna-table {\n // &__header,\n // &__cell {\n // &:first-child {\n // max-width: 50vw;\n // max-width: 50cqw;\n\n // position: sticky;\n // left: 0;\n // z-index: 1;\n\n // overflow-wrap: break-word;\n\n // hyphens: auto;\n // @include colour.colour-background(\"background\");\n\n // &::after {\n // content: \"\";\n\n // width: 0.75rem;\n\n // position: absolute;\n // top: 0;\n // bottom: -1px;\n // left: 100%;\n\n // background: linear-gradient(\n // 90deg,\n // var(--overflow-shadow-start) 0%,\n // #{$table-overflow-shadow-colour-hidden} 100%\n // );\n // animation: overflow-shadows linear;\n // animation-timeline: --overflow-shadows;\n // }\n // }\n // }\n // }\n // }\n\n &--scroll {\n .tna-table {\n &__caption {\n &::after {\n content: \" (scroll to see more)\";\n }\n }\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-accordion {\n @include spacing.space-above;\n\n // NON INTERACTIVE\n &__item {\n @include spacing.space-above;\n }\n\n &__heading {\n padding-top: spacing.space(1);\n }\n\n &__body {\n padding-top: spacing.space(1);\n }\n\n // INTERACTIVE\n &__toggle-all {\n margin-bottom: spacing.space(1);\n padding: 0;\n\n background: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n @include colour.colour-font(\"link\");\n @include typography.font-size(16);\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__details {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n position: relative;\n z-index: 1;\n\n &:first-of-type {\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n }\n }\n\n &__summary {\n width: 100%;\n margin: 0;\n padding: spacing.space(0.5) spacing.space(3) spacing.space(0.5)\n spacing.space(1);\n\n display: block;\n\n position: relative;\n\n line-height: inherit;\n text-align: left;\n\n list-style: none;\n\n background: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(18);\n @include typography.main-font(true);\n\n * {\n font-size: inherit;\n }\n\n &::before {\n content: \"\";\n\n width: 0;\n height: 0;\n\n position: absolute;\n top: calc(50% - #{math.div(math.sqrt(3), 4)}rem);\n right: 0.75rem;\n\n border-width: #{math.div(math.sqrt(3), 2)}rem 0.5rem 0 0.5rem;\n border-color: colour.colour-var(\"font-light\") transparent;\n border-style: solid;\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n @include colour.colour-background(\"background-tint\");\n\n &::before {\n border-color: colour.colour-var(\"font-dark\") transparent;\n }\n }\n\n &[aria-expanded=\"true\"] {\n &::before {\n border-width: 0 0.5rem #{math.div(math.sqrt(3), 2)}rem 0.5rem;\n }\n }\n\n &:active {\n z-index: 1;\n }\n }\n\n &__content {\n padding: spacing.space(1);\n\n position: relative;\n\n border-radius: 0.1px;\n }\n\n @include colour.on-forced-colours {\n &__summary {\n &::before {\n content: \"\\2193\";\n\n width: auto;\n height: auto;\n\n top: calc(50% - 0.5rem);\n\n line-height: 1rem;\n\n border: none;\n }\n\n &[aria-expanded=\"true\"] {\n &::before {\n content: \"\\2191\";\n\n border: none;\n }\n }\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-back-link {\n display: inline-flex;\n gap: spacing.space(0.5);\n\n &,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n\n &,\n &:hover,\n &:focus-visible {\n text-decoration: none;\n }\n\n &__inner {\n text-decoration: underline;\n @include typography.interactable-text-decoration;\n }\n\n &:hover &__inner {\n @include typography.interacted-text-decoration;\n }\n\n &::before {\n content: \"\\2039\";\n content: \"\\2039\" / \"\";\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-breadcrumbs {\n border-radius: 0.1px;\n\n &__list {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-wrap: wrap;\n\n list-style: none;\n }\n\n &__item {\n display: flex;\n\n + .tna-breadcrumbs__item {\n &::before {\n content: \"\\203A\";\n content: \"\\203A\" / \"\";\n\n margin: 0 spacing.space(0.75);\n\n display: inline-block;\n\n vertical-align: baseline;\n }\n }\n\n &--expandable {\n display: none;\n\n @include media.on-mobile {\n display: inline-block !important;\n }\n }\n }\n\n &__link {\n display: inline-block;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n }\n\n button#{&}__link {\n height: 100%;\n margin: 0;\n padding: 0;\n\n appearance: none;\n\n line-height: inherit;\n\n background-color: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &:hover {\n color: inherit;\n @include typography.interacted-text-decoration;\n\n background-color: transparent;\n }\n }\n\n @include media.on-mobile {\n &--collapsed &__item:not(:first-child, &__item--expandable, :last-child) {\n display: none;\n }\n }\n\n @include colour.on-high-contrast {\n &__link {\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"link\");\n }\n }\n }\n}\n","@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n\n.tna-button-group {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: spacing.space(1);\n\n @include spacing.space-above;\n\n @include media.on-tiny {\n flex-direction: column;\n align-items: stretch;\n }\n\n &--small {\n gap: spacing.space(0.5);\n }\n\n &--centred {\n justify-content: center;\n }\n\n &--full {\n justify-content: stretch;\n\n @include media.on-mobile {\n flex-direction: column;\n\n align-items: stretch;\n }\n\n .tna-button {\n margin: 0;\n\n flex: 1;\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n@use \"button-group\";\n\n$button-border-width: 4px !default;\n\n.tna-button {\n padding: spacing.space(0.25) spacing.space(1);\n\n display: inline-flex;\n align-items: baseline;\n justify-content: center;\n gap: spacing.space(0.75);\n\n line-height: 2rem;\n text-align: center;\n text-decoration: none;\n text-wrap: balance;\n\n cursor: pointer;\n\n -webkit-print-color-adjust: exact;\n print-color-adjust: exact;\n\n @include typography.font-size(18);\n @include typography.main-font-weight-bold;\n\n @include colour.colour-background(\"button-background\");\n\n @include colour.colour-border(\"button-background\", $button-border-width);\n @include borders.rounded-border;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"button-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"button-hover-text\");\n text-decoration: none;\n\n background: transparent;\n }\n\n .fa-solid {\n display: block;\n }\n\n svg {\n height: 1.1em;\n flex-shrink: 0;\n\n align-self: center;\n\n fill: currentColor;\n }\n\n &--plain {\n @include typography.main-font-weight;\n text-decoration: underline;\n\n background-color: transparent;\n\n border-color: transparent;\n border-radius: 0.1px;\n\n &,\n &:link,\n &:visited,\n &:hover {\n @include colour.colour-font(\"link\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &--accent {\n @include colour.colour-background(\"button-accented-background\");\n\n @include colour.colour-border(\"button-accented-background\");\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"button-accented-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n &--icon-right {\n flex-direction: row-reverse;\n\n &:has(.fa-solid) {\n align-items: center;\n // justify-content: space-between;\n }\n }\n\n &--small,\n &-group--small & {\n padding: 0 spacing.space(0.5);\n\n @include typography.font-size(14);\n line-height: 1.5rem;\n }\n\n @mixin icon-only {\n padding-right: 0;\n padding-left: 0;\n\n gap: 0;\n\n font-size: 0 !important;\n line-height: 0 !important;\n\n .fa-solid {\n width: 2.5rem;\n\n line-height: 2rem;\n\n @include typography.font-size(18);\n }\n\n svg {\n height: 1.5rem;\n margin: 0.5rem;\n }\n }\n\n @mixin icon-only-small {\n padding-right: 0;\n padding-left: 0;\n\n .fa-solid {\n width: 1.5rem;\n\n line-height: 1.5rem;\n }\n\n svg {\n height: 1.2rem;\n margin: 0.5rem;\n }\n }\n\n &--icon-only {\n @include icon-only;\n }\n\n &--small#{&}--icon-only,\n &-group--small &--icon-only {\n @include icon-only-small;\n }\n\n @include media.on-mobile {\n &--icon-only-mobile {\n @include icon-only;\n }\n\n &--small#{&}--icon-only-mobile,\n &-group--small &--icon-only-mobile {\n @include icon-only-small;\n }\n }\n\n &--solid-hover {\n &:not(.tna-button--plain):hover {\n @include colour.colour-font(\"font-dark\");\n\n @include colour.colour-background(\"background\");\n }\n }\n\n .tna-background-accent &,\n .tna-template--dark-theme .tna-background-accent-light & {\n &:hover {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n .tna-background-accent &--accent,\n .tna-template--dark-theme .tna-background-accent-light &--accent {\n @include colour.colour-background(\"contrast-button-background\");\n\n @include colour.colour-border(\"contrast-button-background\");\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"contrast-button-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"contrast-font-dark\");\n\n @include colour.colour-background(\"contrast-background\");\n }\n }\n\n @media (prefers-color-scheme: dark) {\n .tna-template--system-theme .tna-background-accent-light & {\n &:hover {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n .tna-template--system-theme .tna-background-accent-light &--accent {\n @include colour.colour-background(\"contrast-button-background\");\n\n @include colour.colour-border(\"contrast-button-background\");\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"contrast-button-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"contrast-font-dark\");\n\n @include colour.colour-background(\"contrast-background\");\n }\n }\n }\n\n @include colour.on-forced-colours {\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../variables/a11y\" as a11yVars;\n@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n@mixin horizontal-card-layout($modifierClass, $innerPaddingAmount) {\n &#{$modifierClass} {\n padding-bottom: 0;\n\n display: grid;\n grid-template: min-content 1fr / 50% 50%;\n grid-template-areas:\n \"image header\"\n \"image body\";\n gap: 0;\n\n > * + * {\n margin-top: spacing.space(0.5);\n }\n\n > :first-child {\n padding-top: spacing.space($innerPaddingAmount - 0.25);\n }\n\n > :last-child {\n padding-bottom: spacing.space($innerPaddingAmount);\n }\n }\n\n &#{$modifierClass}:not(:has(&__image-container)) {\n grid-template-columns: 0 100%;\n }\n\n &#{$modifierClass}#{&}--flipped {\n grid-template-areas:\n \"header image\"\n \"body image\"\n \"footer image\";\n }\n\n &#{$modifierClass}#{&}--flipped:not(:has(&__image-container)) {\n grid-template-columns: 100% 0;\n }\n\n &#{$modifierClass} &__heading,\n &#{$modifierClass} &__body {\n padding-right: spacing.space($innerPaddingAmount);\n padding-left: spacing.space($innerPaddingAmount);\n }\n\n &#{$modifierClass} &__heading {\n grid-area: header;\n }\n\n &#{$modifierClass} &__image-container {\n width: 100%;\n height: 100%;\n margin: 0;\n padding: 0;\n\n grid-area: image;\n\n border-radius: bordersVars.$rounded-border-radius 0 0\n bordersVars.$rounded-border-radius;\n }\n\n &#{$modifierClass}#{&}--flipped &__image-container {\n border-radius: 0 bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0;\n }\n\n &#{$modifierClass} &__body {\n grid-area: body;\n }\n}\n\n.tna-card {\n @include spacing.space-above;\n\n display: flex;\n flex-direction: column;\n gap: spacing.space(0.5);\n\n position: relative;\n z-index: 1;\n\n @include borders.rounded-border;\n\n &:not(:has(&__image-container)) {\n padding-top: spacing.space(0.5);\n\n @include colour.thick-keyline-dark(top);\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &__heading {\n order: 2;\n\n .tna-hgroup__supertitle {\n margin-top: spacing.space(0.25);\n }\n }\n\n &:not(:has(&__image-container)) &__heading {\n .tna-hgroup__supertitle {\n margin-top: spacing.space(0.5);\n }\n }\n\n &--full-click {\n &:hover {\n @include colour.colour-outline(\n \"base-keyline\",\n a11yVars.$focus-outline-active-outer-width,\n solid\n );\n outline-offset: a11yVars.$focus-outline-active-inner-width;\n }\n }\n\n @include a11y.faux-full-outline(\"&--full-click &__heading-link\");\n\n &--full-click#{&}:not(:has(&__image-container)) &__heading-link::before {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--full-click#{&}--padded#{&}:not(:has(&__image-container))\n &__heading-link::before {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--full-click:not(:has(&__image-container)) &__heading-link {\n &::before {\n top: -#{bordersVars.$thick-border-width};\n }\n }\n\n &--full-height {\n height: 100%;\n\n box-sizing: border-box;\n }\n\n &__image-container {\n aspect-ratio: 3/2;\n margin-bottom: spacing.space(0.25);\n\n overflow: hidden;\n\n position: relative;\n\n order: 1;\n\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n\n @include colour.image-loader-background;\n }\n\n &__image {\n position: absolute;\n inset: 0;\n z-index: 1;\n\n img {\n width: 100%;\n height: 100%;\n\n object-fit: cover;\n }\n }\n\n &__image-label {\n position: absolute;\n top: spacing.space(0.5);\n left: spacing.space(0.5);\n z-index: 2;\n }\n\n &__body {\n order: 3;\n\n display: flex;\n flex-direction: column;\n\n gap: spacing.space(1);\n\n > * {\n margin-top: 0;\n }\n }\n\n &__meta {\n padding-top: spacing.space(0.5);\n }\n\n &__actions {\n margin-top: spacing.space(0.5);\n\n display: flex;\n gap: spacing.space(1) spacing.space(2);\n }\n\n &__action {\n @include typography.main-font-weight-bold;\n }\n\n &--padded {\n padding-bottom: spacing.space(1);\n }\n\n &--padded:not(:has(&__image-container)) {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--padded &__heading,\n &--padded &__body {\n padding-right: spacing.space(1);\n padding-left: spacing.space(1);\n }\n\n &--plain {\n &::after {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: -1;\n\n border-radius: inherit;\n @include colour.colour-border(\"keyline\", 1px, solid);\n }\n }\n\n &--plain:not(:has(&__image-container)) {\n &::after {\n border-top-width: 0;\n }\n }\n\n @include colour.on-high-contrast {\n padding-bottom: spacing.space(1);\n @include borders.rounded-border;\n\n &:not(&--padded),\n &--plain {\n @include colour.colour-border(\"keyline-dark\", 1px, solid);\n }\n\n &--full-click:not(:has(&__image-container)) {\n @include colour.thick-keyline-dark(top);\n }\n\n &__heading,\n &__body {\n padding-right: spacing.space(1);\n padding-left: spacing.space(1);\n }\n\n &__image-container {\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n }\n\n &:not(:has(&__image-container)) {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--full-click:not(&--padded) &__heading-link::before {\n @include borders.rounded-border;\n }\n\n &--full-click:not(:has(&__image-container), &--padded)\n &__heading-link::before {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--padded {\n &::after {\n display: none;\n }\n }\n }\n\n @include colour.on-forced-colours {\n padding-bottom: spacing.space(1);\n @include colour.colour-border(\"keyline-dark\", 1px, solid);\n @include borders.rounded-border;\n\n &__heading,\n &__body {\n padding-right: spacing.space(1);\n padding-left: spacing.space(1);\n }\n\n &--full-click:not(:has(&__image-container)) &__heading-link {\n &::before {\n top: -#{bordersVars.$thick-border-width - 1px};\n }\n }\n }\n\n @include media.on-larger-than-mobile {\n @include horizontal-card-layout(\"--horizontal\", 1.25);\n\n &--horizontal-small-image {\n grid-template-columns: max(10rem, 25%) 1fr;\n }\n\n &--horizontal-small-image#{&}--flipped {\n grid-template-columns: 1fr max(10rem, 25%);\n }\n }\n\n @include media.on-small {\n @include horizontal-card-layout(\"--horizontal-on-small\", 1);\n\n &--horizontal-small-image {\n grid-template-columns: max(10rem, 25%) 1fr;\n }\n\n &--horizontal-small-image#{&}--flipped {\n grid-template-columns: 1fr max(10rem, 25%);\n }\n }\n}\n","$focus-outline-inner-width: 3px !default;\n$focus-outline-outer-width: 3px !default;\n$focus-outline-total-width: $focus-outline-inner-width +\n $focus-outline-outer-width;\n$focus-outline-active-inner-width: $focus-outline-inner-width - 1px !default;\n$focus-outline-active-outer-width: $focus-outline-outer-width - 1px !default;\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-compound-filters {\n @include spacing.space-above;\n\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: spacing.space(0.5) spacing.space(0.75);\n\n list-style: none;\n\n &__item {\n padding: 0 spacing.space(0.125) 0 spacing.space(0.75);\n\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n line-height: 1.75;\n\n @include borders.rounded-border;\n\n @include typography.font-size(16);\n\n @include colour.colour-border(\"keyline\", 1px);\n\n &--remove {\n padding-right: 0;\n padding-left: 0;\n\n background: none;\n\n border: none;\n border-radius: 0;\n }\n }\n\n &__link {\n width: 1.5rem;\n height: 1.5rem;\n\n position: relative;\n\n flex-shrink: 0;\n\n font-size: 0;\n line-height: 0;\n\n text-decoration: none;\n\n @include borders.rounded-border;\n\n &::before,\n &::after {\n content: \"\";\n\n height: 1rem;\n margin-left: -1px;\n\n display: block;\n\n position: absolute;\n top: 0.25rem;\n left: 50%;\n\n @include colour.colour-border(\"font-base\", 2px, solid, left);\n }\n\n &::before {\n transform: rotate(45deg);\n }\n\n &::after {\n transform: rotate(-45deg);\n }\n\n &:hover {\n @include colour.contrast;\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-cookie-banner {\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n\n @include media.on-tiny {\n padding-top: 1rem;\n padding-bottom: 1rem;\n\n @include typography.font-size(16);\n }\n\n &__message {\n &--prompt {\n }\n\n &--accepted {\n }\n\n &--rejected {\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../variables/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-details {\n margin-top: spacing.space(1);\n\n &:first-child {\n margin-top: 0;\n }\n\n &__details {\n }\n\n &__summary {\n width: fit-content;\n padding: spacing.space(0.5) spacing.space(1) spacing.space(0.5)\n spacing.space(2.75);\n\n display: block;\n\n position: relative;\n z-index: 2;\n\n @include colour.colour-font(\"link\");\n text-decoration: underline;\n text-decoration-thickness: 1.5px;\n\n list-style: none;\n\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &::-webkit-details-marker {\n display: none;\n }\n\n &::before {\n content: \"\";\n\n width: 0;\n height: 0;\n\n position: absolute;\n top: calc(50% - 0.5rem);\n left: 0.75rem;\n\n border-width: 0.5rem 0 0.5rem #{math.div(math.sqrt(3), 2)}rem;\n border-color: transparent transparent transparent\n colour.colour-var(\"link\");\n border-style: solid;\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__content {\n padding: 0 0 0 spacing.space(2.75);\n }\n\n &__details[open] &__summary {\n &::before {\n top: calc(50% - #{math.div(math.sqrt(3), 4)}rem);\n\n border-width: #{math.div(math.sqrt(3), 2)}rem 0.5rem 0 0.5rem;\n border-color: colour.colour-var(\"link\") transparent transparent\n transparent;\n }\n }\n\n &__details[open] &__content {\n position: relative;\n z-index: 1;\n\n &::before {\n content: \"\";\n\n display: block;\n\n position: absolute;\n inset: 0 auto 0 calc(1.5rem - #{math.div(borders.$thick-border-width, 2)});\n\n @include colour.thick-keyline(left);\n }\n }\n\n @include colour.on-forced-colours {\n &__summary {\n &::before {\n content: \"\\2192\";\n\n width: auto;\n height: auto;\n\n top: calc(50% - 0.5rem);\n\n line-height: 1rem;\n\n border: none;\n }\n }\n\n &__details[open] &__summary {\n &::before {\n content: \"\\2193\";\n\n border: none;\n }\n }\n }\n}\n","@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-files-list {\n @include spacing.space-above;\n padding: spacing.space(1);\n\n @include colour.tint;\n\n @include borders.rounded-border;\n\n &__items {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-direction: column;\n gap: spacing.space(1);\n flex: 1;\n\n list-style: none;\n\n @include colour.colour-border(\"keyline\", 0, solid);\n border-left-width: 1px;\n }\n\n &__item {\n padding: 0 0 0 spacing.space(0.5);\n\n display: grid;\n grid-template-columns: auto 1fr;\n gap: spacing.space(0.25) spacing.space(1);\n\n position: relative;\n }\n\n &__link {\n }\n\n &__item-title {\n grid-column: 2;\n grid-row: 1;\n }\n\n &__item-icon {\n margin: spacing.space(0.5) 0;\n\n grid-column: 1;\n grid-row: 1/3;\n @include typography.font-size(36);\n }\n\n &__item-body {\n grid-column: 2;\n grid-row: 2;\n }\n\n &__item-meta {\n padding-bottom: spacing.space(0.25);\n }\n\n &__item-description {\n margin-top: 0;\n\n @include typography.font-size(16);\n }\n\n &--full-click {\n }\n\n @include a11y.faux-full-outline(\"&--full-click &__link\");\n\n &--full-click &__link {\n &:hover {\n &::before {\n @include colour.thick-keyline(left);\n }\n }\n }\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-footer {\n &__inner {\n @include colour.contrast;\n\n padding-top: spacing.space(1);\n padding-bottom: spacing.space(3);\n }\n\n &__theme-selector {\n .tna-button-group {\n justify-content: flex-end;\n }\n\n @include colour.on-forced-colours {\n display: none;\n }\n }\n\n &__theme-selector-button {\n @include typography.main-font-weight-bold;\n }\n\n &__theme-selector-notice {\n margin-top: spacing.space(0.5);\n margin-bottom: spacing.space(0.25);\n padding: spacing.space(0.5) spacing.space(0.75);\n\n @include typography.font-size(16);\n line-height: 1.5;\n\n @include colour.blue-accent;\n @include colour.accent-light;\n\n @include borders.rounded-border;\n @include colour.thick-keyline-accent(left);\n }\n\n &__theme-selector-enable-settings-cookies {\n appearance: none;\n\n line-height: inherit;\n text-decoration: underline;\n\n background: none;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n @include colour.colour-font(\"link\");\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n .tna-logo {\n margin-top: spacing.space(2);\n }\n\n &__title {\n margin-top: spacing.space(1);\n margin-bottom: 0;\n padding-top: 0;\n }\n\n &__address {\n }\n\n &__meta {\n margin-top: spacing.space(1);\n\n @include typography.font-size(16);\n }\n\n &__social {\n margin-top: spacing.space(2);\n\n &-items {\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n gap: spacing.space(1) spacing.space(2);\n }\n\n &-item {\n &-link {\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n @include typography.font-size(16);\n line-height: 1.25;\n text-decoration: none;\n\n svg {\n height: 1.5em;\n\n path {\n fill: currentColor;\n }\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n &-text {\n }\n }\n }\n }\n\n &__mailing-list {\n margin-top: spacing.space(2);\n padding: spacing.space(1);\n\n @include typography.font-size(16);\n\n background-color: rgb(255 255 255 / 14%);\n\n @include borders.rounded-border;\n }\n\n &__navigation {\n &-block {\n padding-top: spacing.space(2);\n\n &-heading {\n }\n\n &-items {\n }\n\n &-item {\n padding-top: spacing.space(0.375);\n padding-bottom: spacing.space(0.375);\n\n @include typography.font-size(16);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &-link {\n display: inline-block;\n\n text-decoration: none;\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n .fa-solid {\n margin-left: spacing.space(0.75);\n }\n }\n }\n }\n }\n\n &__legal {\n padding-top: spacing.space(3);\n\n @include typography.font-size(16);\n\n &-items {\n margin-bottom: 0;\n\n text-align: center;\n\n @include media.on-tiny {\n text-align: inherit;\n }\n }\n\n &-item {\n padding: spacing.space(0.5);\n\n display: inline-block;\n\n @include media.on-tiny {\n display: block;\n }\n\n &-link {\n }\n }\n }\n\n hr {\n margin-top: spacing.space(1.5);\n margin-bottom: spacing.space(0.5);\n }\n\n &__licence {\n @include typography.font-size(16);\n\n &.tna-container {\n align-items: center;\n }\n\n .tna-column {\n margin-top: spacing.space(1);\n }\n }\n\n &__licence-logo {\n display: block;\n }\n\n &__govuk {\n text-align: center;\n\n &-link {\n display: inline-block;\n }\n\n &-logotype-crown {\n margin: 0 auto spacing.space(0.125);\n\n display: block;\n }\n }\n\n @include media.on-mobile {\n &__inner {\n padding-top: 0;\n padding-bottom: spacing.space(2);\n }\n }\n\n @include media.on-tiny {\n &__social-items {\n flex-direction: column;\n }\n\n &__social-item-link {\n @include typography.font-size(14);\n }\n }\n\n @include colour.on-high-contrast {\n &__theme-selector {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.thick-keyline-dark(top);\n\n &__navigation {\n &-block {\n &-items {\n @include colour.thick-keyline-dark(top);\n }\n }\n }\n\n &__mailing-list {\n background-color: transparent;\n\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-gallery {\n @include spacing.space-above;\n\n display: grid;\n grid-template: min-content min-content 1fr / 2fr 1fr;\n gap: 0 spacing.space(1);\n\n border-radius: 0.1px;\n\n &__header {\n padding-bottom: spacing.space(1);\n\n grid-column: 1 / 3;\n grid-row: 1;\n\n display: flex;\n gap: spacing.space(2);\n }\n\n &__header-inner {\n flex: 1;\n }\n\n &__items,\n &__navigation-buttons {\n grid-column: 1 / 3;\n grid-row: 2;\n }\n\n &__items {\n position: relative;\n z-index: 1;\n\n border-radius: 0.1px;\n\n .tna-template--clicked &:focus {\n @include a11y.no-focus-outline;\n }\n }\n\n &__item {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n justify-content: center;\n }\n\n &__item-header {\n padding: 0 spacing.space(1) spacing.space(1);\n\n line-height: 1;\n text-align: center;\n\n @include typography.main-font-weight-bold;\n @include typography.font-size(16);\n }\n\n &__item-figure {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n gap: spacing.space(1);\n }\n\n &__item-figure-inner {\n width: 100%;\n\n position: relative;\n\n @include colour.contrast;\n\n @include borders.rounded-border;\n }\n\n &__item-image {\n margin: 0 auto;\n }\n\n &__item-description {\n margin-bottom: spacing.space(1);\n padding: spacing.space(0.5) spacing.space(1);\n\n align-self: flex-start;\n\n @include colour.thick-keyline-dark(left);\n }\n\n &__navigation-buttons {\n width: 100%;\n max-height: 50vh;\n aspect-ratio: 3 / 2;\n\n position: relative;\n top: spacing.space(2);\n z-index: 2;\n\n pointer-events: none;\n\n .tna-template--touched & {\n display: none;\n }\n }\n\n &__navigation-button {\n width: 35%;\n\n display: flex;\n align-items: center;\n\n position: absolute;\n top: 0;\n bottom: 0;\n\n background: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n opacity: 0;\n\n cursor: pointer;\n pointer-events: auto;\n @include typography.main-font-weight-bold;\n\n &:hover,\n &:focus-visible {\n opacity: 1;\n }\n }\n\n &__navigation-prev {\n padding-left: 1rem;\n\n justify-content: flex-start;\n\n left: 0;\n }\n\n &__navigation-next {\n padding-right: 1rem;\n\n justify-content: flex-end;\n\n right: 0;\n }\n\n &__navigation-button-label {\n @include colour.accent;\n\n &,\n &:hover {\n @include colour.colour-font(\"button-accented-text\");\n @include colour.colour-background(\"button-accented-background\");\n @include colour.colour-border(\"button-accented-background\");\n }\n }\n\n &__navigation-button-icon {\n content: \"\";\n\n width: 0.75rem;\n height: 0.75rem;\n\n display: block;\n flex: none;\n\n @include colour.colour-border(\"font-dark\", 4px, solid, top);\n @include colour.colour-border(\"font-dark\", 4px, solid, right);\n\n transform-origin: 50% 50%;\n }\n\n &__navigation-prev &__navigation-button-icon {\n transform: rotate(-135deg);\n }\n\n &__navigation-next &__navigation-button-icon {\n transform: rotate(45deg);\n }\n\n &__navigation {\n max-height: 40rem;\n max-height: clamp(15rem, calc(100vh - #{spacing.space(2)}), 40rem);\n padding: spacing.space(1);\n\n grid-column: 1 / 3;\n grid-row: 3;\n\n display: grid;\n grid-template-columns: repeat(6, 1fr);\n grid-auto-rows: min-content;\n gap: spacing.space(1);\n\n overflow: auto;\n }\n\n &__navigation-item {\n min-width: 0;\n min-height: 0;\n aspect-ratio: 1;\n\n position: relative;\n\n border: none;\n @include borders.rounded-border;\n\n cursor: pointer;\n\n @include colour.contrast;\n\n @include colour.image-loader-background;\n\n &:hover {\n &::after {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: 2;\n\n @include colour.thick-keyline-accent;\n }\n }\n\n &[aria-current=\"true\"] {\n @include colour.accent;\n\n &::after {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: 2;\n\n @include colour.thick-keyline-brand(\"\", \"black\");\n }\n }\n }\n\n &__navigation-item-image {\n width: 100%;\n height: 100%;\n\n position: absolute;\n inset: 0;\n object-fit: cover;\n }\n\n &__navigation-item-label {\n padding: spacing.space(0.25) spacing.space(0.75);\n\n display: inline-block;\n\n position: absolute;\n top: 0;\n left: 0;\n z-index: 4;\n\n text-transform: capitalize;\n\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(24);\n @include typography.main-font-weight-bold;\n\n @include colour.colour-background(\"background\");\n\n border-radius: 0 0 bordersVars.$rounded-border-radius 0;\n }\n\n &--interactive &__item-figure-inner {\n max-height: 50vh;\n aspect-ratio: 3 / 2;\n }\n\n &--interactive &__item-image {\n width: 100%;\n height: 100%;\n\n position: absolute;\n inset: 0;\n z-index: 1;\n object-fit: contain;\n }\n\n @include media.on-medium {\n &__navigation {\n grid-template-columns: repeat(4, 1fr);\n }\n }\n\n @include media.on-mobile {\n &__navigation {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n\n @include media.on-tiny {\n &__navigation-item-label {\n @include typography.font-size(18);\n }\n }\n\n &--bounded {\n @include borders.rounded-border;\n @include colour.tint;\n }\n\n &--bounded &__header {\n padding: spacing.space(1);\n }\n\n &--bounded &__navigation-buttons {\n top: spacing.space(3);\n }\n\n &--bounded &__item-header {\n padding-top: spacing.space(1);\n }\n\n &--bounded &__item-figure-inner {\n border-radius: 0.1px;\n }\n\n &--bounded &__item-description {\n margin-right: spacing.space(1);\n margin-left: spacing.space(1);\n }\n\n &__items--hide-item-titles &__item &__item-header {\n display: none;\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-global-header {\n @include colour.contrast;\n background: linear-gradient(\n 0deg,\n rgb(34 34 34 / 100%) 0%,\n rgb(0 0 0 / 100%) 100%\n );\n\n @include colour.colour-font(\"font-base\");\n\n .tna-template--dark-theme & {\n background: colour.brand-colour(\"black\");\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n background: colour.brand-colour(\"black\");\n }\n }\n\n @include colour.on-high-contrast {\n background: colour.brand-colour(\"black\");\n }\n\n &__main {\n padding-top: spacing.space(1);\n padding-bottom: spacing.space(1.5);\n }\n\n &__logo-wrapper {\n margin-top: spacing.space(0.5);\n\n display: flex;\n }\n\n &__logo {\n display: flex;\n align-items: flex-end;\n gap: spacing.space(1);\n\n text-decoration: none;\n\n &--link {\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n\n &:hover {\n @include colour.colour-outline(\"font-dark\", 0.3125rem, solid);\n outline-offset: 2px;\n }\n }\n }\n\n &__logo-strapline {\n padding-right: spacing.space(0.625);\n\n line-height: math.div(6.75rem, 3);\n text-transform: uppercase;\n\n @include typography.heading-font;\n @include typography.font-size(20);\n }\n\n &__navigation-button-wrapper {\n display: none;\n }\n\n &__hamburger {\n width: 2rem;\n height: 0.25rem;\n\n display: inline-block;\n\n @include colour.colour-background(\"font-dark\");\n\n &::before,\n &::after {\n content: \"\";\n\n width: 2rem;\n height: 0.25rem;\n\n display: block;\n\n position: absolute;\n right: 0;\n\n background-color: inherit;\n }\n\n &::before {\n top: 0;\n }\n\n &::after {\n bottom: 0;\n }\n }\n\n &__navigation-button {\n height: 2rem;\n padding: 0;\n\n appearance: none;\n display: flex;\n align-items: center;\n gap: 0.75rem;\n\n position: relative;\n\n color: inherit;\n\n background: none;\n\n border: 0 transparent solid;\n border-width: 0.25rem 0;\n border-radius: 0.1px;\n\n cursor: pointer;\n @include typography.main-font-weight-bold;\n @include typography.font-size(16);\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n &--opened {\n .tna-global-header__hamburger {\n height: 0;\n\n &::before {\n top: 0.625rem;\n\n transform: rotate(-135deg);\n }\n\n &::after {\n bottom: 0.625rem;\n\n transform: rotate(135deg);\n }\n }\n }\n }\n\n &__navigation-wrapper {\n }\n\n &__navigation {\n height: 100%;\n margin: spacing.space(0.5) 0 0;\n\n position: relative;\n\n columns: 2;\n column-gap: spacing.space(2);\n\n list-style: none;\n }\n\n &__navigation-item {\n break-inside: avoid;\n }\n\n &__navigation-item-link {\n min-width: 15rem;\n height: math.div(6.75rem, 3);\n\n display: block;\n box-sizing: border-box;\n\n line-height: math.div(6.75rem, 3);\n text-decoration: none;\n\n @include typography.font-size(17);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__top-navigation {\n padding: 0 0 spacing.space(0.5);\n\n display: flex;\n justify-content: flex-end;\n gap: spacing.space(1.5);\n\n @include typography.font-size(15);\n list-style: none;\n }\n\n &__top-navigation-item {\n }\n\n &__top-navigation-link {\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n text-decoration: none;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-light\");\n }\n\n &:hover,\n &:focus-visible {\n @include colour.colour-font(\"font-base\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n svg {\n height: 1em;\n\n display: inline-block;\n\n path {\n fill: currentColor;\n }\n }\n }\n\n .tna-logo {\n width: 6.75rem;\n\n flex-shrink: 0;\n }\n\n @include media.on-medium {\n &__navigation {\n column-gap: spacing.space(1);\n }\n\n &__navigation-item-link {\n @include typography.font-size(16);\n }\n\n &--collapse-on-medium &__navigation-wrapper {\n width: 100%;\n }\n\n &--collapse-on-medium &__top-navigation-wrapper {\n flex: 1;\n order: 2;\n }\n\n &--collapse-on-medium &__main {\n padding-bottom: spacing.space(1);\n }\n\n &--collapse-on-medium &__logo {\n gap: spacing.space(0.75);\n }\n\n &--collapse-on-medium &__logo-wrapper {\n margin-top: spacing.space(0.5);\n margin-bottom: spacing.space(0.5);\n }\n\n &--collapse-on-medium .tna-logo {\n width: 5rem;\n }\n\n &--collapse-on-medium &__logo-strapline {\n line-height: math.div(5rem, 3);\n }\n\n &--collapse-on-medium &__navigation {\n margin-bottom: spacing.space(0.5);\n }\n\n &--collapse-on-medium &__navigation,\n &--collapse-on-medium &__navigation-item,\n &--collapse-on-medium &__navigation-item-link {\n height: auto;\n }\n }\n\n @include media.on-mobile {\n &__main {\n padding-bottom: 0;\n }\n\n &__logo-wrapper,\n &__navigation-button-wrapper {\n margin-top: 0;\n margin-bottom: spacing.space(1);\n }\n\n &__logo {\n gap: spacing.space(0.75);\n }\n\n &__navigation-button-wrapper {\n display: flex;\n align-items: center;\n }\n\n &__navigation,\n &__navigation-item,\n &__navigation-item-link {\n height: auto;\n }\n\n &__navigation {\n margin-top: 0;\n\n columns: 1;\n\n background-color: rgb(255 255 255 / 10%);\n\n @include colour.colour-border(\"keyline-dark\", 2px, solid, top);\n @include colour.colour-border(\"keyline-dark\", 2px, solid, bottom);\n }\n\n &__navigation-item {\n flex-direction: column;\n align-items: flex-start;\n }\n\n &__navigation-item-link {\n line-height: 1.75rem;\n @include typography.main-font-weight-medium;\n }\n\n &__navigation-item:last-child &__navigation-item-link {\n border-bottom: none;\n }\n\n &__navigation-item-contents {\n display: block;\n }\n\n &__navigation-item-children {\n margin-bottom: spacing.space(1);\n margin-left: spacing.space(1.5);\n }\n\n &__top-navigation {\n padding-top: spacing.space(0.5);\n padding-bottom: spacing.space(0.5);\n\n justify-content: flex-start;\n\n gap: spacing.space(1.5);\n }\n\n &__top-navigation-link {\n padding: spacing.space(0.25) 0;\n }\n }\n\n @include media.on-small {\n .tna-logo {\n width: 4rem;\n }\n\n &__logo-strapline {\n line-height: 1.25rem;\n }\n\n &__navigation {\n width: calc(100% + #{grid.gutter-width-double()});\n\n left: -#{grid.gutter-width()};\n }\n\n &__navigation-item-link {\n padding: spacing.space(0.5) grid.gutter-width();\n }\n }\n\n @include media.on-tiny {\n .tna-logo {\n width: 3.5rem;\n }\n\n &__logo-strapline {\n line-height: 1;\n }\n\n &__navigation-button {\n @include typography.font-size(14);\n }\n\n &__navigation {\n width: calc(100% + #{grid.gutter-width-tiny-double()});\n\n left: -#{grid.gutter-width-tiny()};\n }\n\n &__navigation-item-link {\n padding: spacing.space(0.5) grid.gutter-width-tiny();\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n @include colour.on-forced-colours {\n &__navigation-button {\n height: auto;\n\n line-height: 2;\n @include typography.font-size(18);\n @include typography.main-font-weight-bold;\n\n border: none;\n }\n\n &__hamburger {\n display: none;\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-header {\n @include colour.contrast;\n\n position: relative;\n\n background: linear-gradient(\n 0deg,\n rgb(34 34 34 / 100%) 0%,\n rgb(0 0 0 / 100%) 100%\n );\n\n .tna-template--dark-theme & {\n background: colour.brand-colour(\"black\");\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n background: colour.brand-colour(\"black\");\n }\n }\n\n @include colour.on-high-contrast {\n background: colour.brand-colour(\"black\");\n }\n\n &__contents {\n &.tna-container {\n justify-content: space-between;\n }\n }\n\n &__logo-wrapper {\n padding-top: spacing.space(1.25);\n padding-bottom: spacing.space(1.25);\n }\n\n &__logo {\n display: flex;\n align-items: flex-end;\n\n color: inherit;\n text-decoration: none;\n\n &--link {\n &,\n &:link,\n &:visited {\n color: inherit;\n }\n\n &:hover:not(:focus) {\n text-decoration: none;\n\n @include colour.colour-outline(\"font-dark\", 0.3125rem, solid);\n outline-offset: 1px;\n }\n }\n }\n\n &__logo-strapline {\n margin: 0 spacing.space(0.75);\n\n display: inline-block;\n\n line-height: 1.625rem;\n @include typography.heading-font;\n @include typography.font-size(20);\n text-transform: uppercase;\n }\n\n &__navigation-button-wrapper {\n align-self: center;\n\n display: none;\n }\n\n &__hamburger {\n width: 2rem;\n height: 0.25rem;\n\n display: inline-block;\n\n @include colour.colour-background(\"font-dark\");\n\n &::before,\n &::after {\n content: \"\";\n\n width: 2rem;\n height: 0.25rem;\n\n display: block;\n\n position: absolute;\n right: 0;\n\n background-color: inherit;\n }\n\n &::before {\n top: 0;\n }\n\n &::after {\n bottom: 0;\n }\n }\n\n &__navigation-button {\n height: 2rem;\n padding: 0;\n\n appearance: none;\n\n display: flex;\n align-items: center;\n gap: 0.75rem;\n\n position: relative;\n\n color: inherit;\n @include typography.main-font-weight-bold;\n @include typography.font-size(16);\n\n background: none;\n\n border: 0 transparent solid;\n border-width: 0.25rem 0;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n &--opened {\n .tna-header__hamburger {\n height: 0;\n\n &::before {\n top: 0.625rem;\n\n transform: rotate(-135deg);\n }\n\n &::after {\n bottom: 0.625rem;\n\n transform: rotate(135deg);\n }\n }\n }\n }\n\n &__navigation {\n display: flex;\n flex-direction: column-reverse;\n align-items: flex-end;\n justify-content: space-between;\n\n position: relative;\n z-index: 2;\n }\n\n &__top-navigation-items {\n margin: 0;\n padding: spacing.space(1.25) 0;\n\n display: flex;\n justify-content: flex-end;\n gap: spacing.space(0.5) spacing.space(1.5);\n\n line-height: 1;\n\n list-style: none;\n\n @include typography.font-size(15);\n }\n\n &__top-navigation-item {\n display: block;\n }\n\n &__top-navigation-item-link {\n display: flex;\n align-items: center;\n\n text-decoration: none;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-light\");\n }\n\n &:hover,\n &:focus-visible,\n &--selected {\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n }\n\n &:hover,\n &--selected {\n @include typography.interacted-text-decoration;\n }\n\n .fa-solid {\n margin-right: spacing.space(0.375);\n }\n }\n\n &__navigation-items {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-wrap: nowrap;\n gap: spacing.space(2);\n\n white-space: nowrap;\n\n list-style: none;\n }\n\n &__navigation-item {\n }\n\n &__navigation-item-link {\n padding: spacing.space(0.5) 0;\n\n display: inline-block;\n\n position: relative;\n\n line-height: 2;\n text-decoration: none;\n\n @include typography.main-font-weight-medium;\n\n &::after {\n content: \"\";\n\n height: 0;\n\n position: absolute;\n right: 0;\n bottom: 0;\n left: 0;\n\n @include colour.colour-background(\"font-dark\");\n }\n\n &,\n &:link,\n &:visited {\n color: inherit;\n }\n\n &--selected {\n &::after {\n @include colour.thick-keyline-dark(top);\n }\n }\n }\n\n &.tna-background-accent {\n background: colour.colour-var(\"background\");\n }\n\n &.tna-background-accent &__navigation {\n @include colour.contrast-on-mobile;\n }\n\n .tna-logo {\n width: 5rem;\n\n flex-shrink: 0;\n }\n\n @include media.on-mobile {\n &__logo-wrapper {\n padding-top: spacing.space(1);\n padding-bottom: spacing.space(1);\n }\n\n &__contents {\n &.tna-container {\n padding-right: 0;\n padding-left: 0;\n }\n }\n\n &__navigation-button-wrapper {\n display: block;\n\n &.tna-column {\n padding-left: 0;\n }\n }\n\n &__navigation {\n flex-direction: column;\n align-items: stretch;\n\n &.tna-column {\n padding-right: 0;\n padding-left: 0;\n }\n }\n\n &__top-navigation-items {\n padding: spacing.space(0.5) spacing.space(1);\n\n justify-content: flex-start;\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &__top-navigation-item {\n margin: 0;\n }\n\n &__top-navigation-item-link {\n padding: spacing.space(0.5) 0;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-light\");\n }\n\n &:hover,\n &:focus-visible {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n &__navigation-items {\n width: 100%;\n\n flex-direction: column;\n gap: 0;\n\n background-color: rgb(255 255 255 / 10%);\n\n @include colour.colour-border(\"keyline-dark\", 2px, solid, top);\n @include colour.colour-border(\"keyline-dark\", 2px, solid, bottom);\n }\n\n &__navigation-item {\n margin: 0;\n\n display: block;\n\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n\n &:first-child {\n border-top: none;\n }\n }\n\n &__navigation-item-link {\n display: block;\n\n line-height: 1.75rem;\n\n &::after {\n width: 0;\n height: auto;\n\n top: 0;\n right: auto;\n }\n\n &--selected {\n &::after {\n @include colour.colour-border(\"keyline\", 0.5rem, solid, left);\n }\n }\n }\n }\n\n @include media.on-small {\n .tna-logo {\n width: 4rem;\n }\n\n &__logo-strapline {\n line-height: 1.25rem;\n }\n\n &__logo-wrapper,\n &__navigation-item-link,\n &__navigation-button-wrapper {\n padding-right: grid.gutter-width();\n }\n\n &__logo-wrapper,\n &__navigation-item-link {\n padding-left: grid.gutter-width();\n }\n\n &__top-navigation-items {\n padding-right: grid.gutter-width();\n padding-left: grid.gutter-width();\n }\n }\n\n @include media.on-tiny {\n &__navigation-button-wrapper,\n &__logo-wrapper {\n padding-right: grid.gutter-width-tiny();\n }\n\n &__logo-wrapper {\n padding-left: grid.gutter-width-tiny();\n }\n\n .tna-logo {\n width: 3.5rem;\n }\n\n &__logo-strapline {\n font-size: 0.9rem;\n line-height: 1.25;\n }\n\n &__navigation-button {\n @include typography.font-size(14);\n }\n\n &__top-navigation-items {\n gap: 0.5rem;\n }\n\n &__navigation-item-link {\n padding-right: grid.gutter-width-tiny();\n padding-left: calc(#{grid.gutter-width-tiny()} + 0.5rem);\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n @include colour.on-forced-colours {\n &__navigation-button {\n height: auto;\n\n line-height: 2;\n @include typography.font-size(18);\n @include typography.main-font-weight-bold;\n\n border: none;\n }\n\n &__hamburger {\n display: none;\n }\n }\n}\n","@use \"sass:math\";\n\n@use \"../../variables/borders\" as bordersVars;\n@use \"../../variables/grid\" as gridVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n$padding-units-top: 10 !default;\n$padding-units-bottom: 2 !default;\n$padding-units-narrow: 3 !default;\n$shift-units: 5 !default;\n\n.tna-hero {\n &__figure {\n min-height: clamp(\n #{spacing.space($padding-units-top + $padding-units-bottom)},\n calc(40vw - #{spacing.space($padding-units-top + $padding-units-bottom)}),\n 50rem\n );\n margin: 0;\n padding-top: spacing.space($padding-units-top);\n padding-bottom: spacing.space($padding-units-bottom);\n\n display: flex;\n align-items: flex-end;\n\n position: relative;\n }\n\n &__caption {\n width: 100%;\n\n overflow: visible;\n\n position: absolute;\n top: 0;\n right: 0;\n z-index: 5;\n }\n\n &__details {\n width: 100%;\n\n overflow: visible;\n }\n\n &__details-summary {\n position: absolute;\n top: spacing.space(0.5);\n right: spacing.space(0.5);\n z-index: 2;\n\n &:hover {\n @include colour.colour-font(\"font-dark\", true);\n\n @include colour.colour-background(\"background\", true);\n }\n }\n\n &__details-summary-icon {\n }\n\n &__information {\n width: 45rem;\n max-width: 75vw;\n padding: spacing.space(0.625) spacing.space(3.25) spacing.space(0.625)\n spacing.space(1);\n\n position: absolute;\n top: 0;\n right: 0;\n z-index: 1;\n\n @include colour.contrast;\n\n @include typography.font-size(16);\n\n border-bottom-left-radius: bordersVars.$rounded-border-radius;\n\n p + p {\n margin-top: spacing.space(0.5);\n }\n }\n\n &__image {\n position: absolute;\n inset: 0;\n z-index: 1;\n\n @include colour.image-loader-background;\n\n img {\n width: 100%;\n height: 100%;\n\n object-fit: cover;\n }\n }\n\n &__details[open] &__details-summary {\n width: 2rem;\n height: 2rem;\n padding: 0;\n\n font-size: 0;\n line-height: 2rem;\n text-align: center;\n\n border: none;\n\n @include colour.contrast;\n\n &::before,\n &::after {\n content: \"\";\n\n width: 1.5rem;\n height: 0.125rem;\n\n display: block;\n\n position: absolute;\n top: 50%;\n left: 50%;\n\n @include colour.colour-background(\"font-dark\");\n }\n\n &::before {\n transform: translate(-50%, -50%) rotate(45deg);\n }\n\n &::after {\n transform: translate(-50%, -50%) rotate(-45deg);\n }\n\n &:hover {\n &::before,\n &::after {\n height: 0.25rem;\n }\n }\n\n &-icon {\n font-size: 0;\n }\n }\n\n &__inner {\n position: relative;\n z-index: 4;\n }\n\n &:not(.tna-background-accent, .tna-background-tint) &__inner {\n // @include colour.contrast-on-mobile;\n }\n\n &__content {\n }\n\n &__content-inner {\n padding: spacing.space(2);\n\n @include colour.colour-background(\"background\");\n\n @include borders.rounded-border;\n }\n\n &__heading {\n }\n\n &__body {\n }\n\n &--split {\n }\n\n &--split &__figure {\n min-height: clamp(15rem, #{math.div(100vw, 3)}, 50rem);\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n\n align-items: center;\n\n box-sizing: border-box;\n }\n\n &--split &__information {\n max-width: 50%;\n\n box-sizing: border-box;\n }\n\n &--split &__image {\n left: 50%;\n }\n\n &--split &__content {\n width: 50%;\n padding-right: grid.gutter-width();\n }\n\n &--split &__content-inner {\n padding: 0;\n\n border-left: none;\n }\n\n @include media.on-larger-than-mobile {\n &--shift {\n margin-bottom: spacing.space($shift-units - $padding-units-bottom);\n }\n\n &--shift#{&}--narrow {\n margin-bottom: spacing.space($shift-units - $padding-units-narrow);\n }\n }\n\n &--shift &__content-inner {\n position: relative;\n top: spacing.space($shift-units);\n }\n\n &--narrow {\n }\n\n &--narrow &__figure {\n min-height: max(#{spacing.space($padding-units-narrow * 2)}, 20rem);\n padding-top: spacing.space($padding-units-narrow);\n padding-bottom: spacing.space($padding-units-narrow);\n }\n\n @include media.on-mobile {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &.tna-background-tint,\n &.tna-background-contrast,\n &.tna-background-accent,\n &.tna-background-accent-light {\n border-bottom: none;\n }\n\n & &__figure {\n min-height: auto;\n padding: 0;\n\n flex-direction: column;\n }\n\n &__caption {\n order: 2;\n }\n\n &__details {\n }\n\n &__details-summary {\n top: spacing.space(0.25);\n right: spacing.space(0.25);\n }\n\n &__details[open] &__details-summary {\n top: spacing.space(0.5);\n right: spacing.space(0.5);\n }\n\n &__details-summary-icon {\n }\n\n &__information,\n &--split &__information {\n width: auto;\n max-width: none;\n\n left: 0;\n\n border-bottom-left-radius: 0;\n }\n\n &__image {\n width: 100%;\n\n position: static;\n\n order: 1;\n\n img {\n height: auto;\n }\n }\n\n &__inner {\n order: 3;\n }\n\n &__content {\n }\n\n &__content-inner {\n padding-right: 0;\n padding-left: 0;\n\n border-left: none;\n }\n\n &__heading {\n }\n\n &__body {\n margin-top: spacing.space(1);\n }\n\n &--shift {\n }\n\n &--split &__content {\n width: 100%;\n padding-right: grid.gutter-width-half();\n }\n\n &--shift &__content-inner {\n position: static;\n }\n\n &--split &__figure {\n min-height: auto;\n padding-top: 0;\n padding-bottom: 0;\n }\n\n &--split &__content-inner {\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-index-grid {\n @include spacing.space-above;\n\n &__heading {\n }\n\n &__items {\n @include spacing.space-above;\n\n margin-bottom: 0;\n\n display: flex;\n gap: spacing.space(2) 0;\n\n list-style: none;\n }\n\n &__item {\n @include colour.contrast;\n\n height: 100%;\n\n display: flex;\n flex-direction: column;\n\n position: relative;\n\n text-decoration: none;\n\n @include borders.rounded-border;\n\n .tna-background-contrast & {\n @include colour.accent;\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n }\n\n &__item-image {\n width: 100%;\n height: auto;\n\n @include colour.image-loader-background;\n\n pointer-events: none;\n\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n }\n\n &__item-content {\n padding: spacing.space(1);\n\n flex: 1;\n }\n\n &__item-label {\n position: absolute;\n top: spacing.space(0.5);\n left: spacing.space(0.5);\n }\n\n &__item-title {\n @include typography.main-font-weight-bold;\n text-decoration: underline;\n\n .tna-index-grid__item:hover & {\n &,\n &:link,\n &:visited {\n @include typography.interacted-text-decoration;\n }\n }\n }\n\n &__item-subtitle {\n @include colour.colour-font(\"font-light\");\n @include typography.font-size(16);\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-pagination {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n justify-content: center;\n gap: spacing.space(1);\n\n @include spacing.space-above;\n\n &:not(:has(&__list)) {\n flex-wrap: nowrap;\n align-items: flex-start;\n justify-content: space-between;\n gap: spacing.space(2);\n }\n\n &__prev-next {\n &--prev {\n text-align: left;\n }\n\n &--next {\n text-align: right;\n }\n\n &-button {\n text-align: inherit;\n text-wrap: wrap;\n\n &--prev {\n }\n\n &--next {\n }\n\n &-text {\n display: block;\n }\n\n &-title {\n display: block;\n }\n\n &-description {\n padding-bottom: spacing.space(0.25);\n\n display: block;\n\n line-height: 1.25;\n @include typography.font-size(16);\n }\n\n &:has(&-description) {\n svg {\n margin-top: 0.35em;\n\n align-self: flex-start;\n }\n }\n }\n }\n\n :has(&__prev-next-button-description) &__prev-next-button-title {\n @include typography.main-font-weight-bold;\n }\n\n &:not(:has(&__list)) &__prev-next {\n flex: 1;\n\n &-button {\n padding: 0;\n\n border-width: 0;\n\n &-title {\n @include typography.main-font-weight-bold;\n }\n }\n }\n\n &__link {\n min-width: 1.5rem;\n padding-right: spacing.space(0.5);\n padding-left: spacing.space(0.5);\n }\n\n &__list {\n margin: 0;\n padding: 0;\n\n display: flex;\n align-items: center;\n gap: spacing.space(0.25);\n\n list-style: none;\n }\n\n &__item {\n &--ellipses {\n min-width: 2rem;\n padding: spacing.space(0.5);\n\n text-align: center;\n }\n\n &--current {\n }\n }\n\n @include media.on-mobile {\n flex-direction: column;\n gap: spacing.space(0.5);\n\n &:not(:has(&__list)) {\n align-items: flex-start;\n gap: spacing.space(1);\n }\n\n &:not(:has(&__list)) &__prev-next {\n &--next {\n text-align: left;\n }\n\n &-button {\n &--next {\n flex-direction: row;\n }\n }\n }\n }\n\n @include media.on-tiny {\n &:has(&__list) &__item {\n &:not(:is(&:first-child, &:last-child, &--current, &--ellipses)) {\n display: none;\n }\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-panel {\n padding: spacing.space(2);\n\n @include colour.green-accent;\n @include colour.accent;\n\n text-align: center;\n\n &__heading {\n }\n\n &__content {\n margin-top: spacing.space(1);\n\n @include typography.font-size(22);\n\n p + p {\n margin-top: spacing.space(0.5);\n }\n }\n\n @include media.on-mobile {\n padding: spacing.space(1);\n\n &__content {\n @include typography.font-size(18);\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-phase-banner {\n @include colour.contrast;\n\n padding-top: spacing.space(0.5);\n padding-bottom: spacing.space(0.5);\n\n @include typography.font-size(16);\n\n .tna-container {\n align-items: center;\n }\n\n &__phase {\n @include typography.main-font-weight-bold;\n text-transform: uppercase;\n }\n\n &__message {\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/shadows\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-picture {\n @include spacing.space-above;\n margin-right: 0;\n margin-bottom: 0;\n margin-left: 0;\n padding: 0;\n\n &__image-wrapper {\n padding: spacing.space(1.5);\n\n position: relative;\n\n @include borders.rounded-border;\n }\n\n &__image-wrapper:has(+ #{&}__transcript:not([hidden])) {\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n }\n\n &__image {\n width: auto;\n height: auto;\n max-height: 40rem;\n margin: 0 auto;\n\n @include shadows.drop-shadow;\n\n @include colour.image-loader-background;\n }\n\n &__toggle-transcript {\n position: absolute;\n right: spacing.space(1);\n bottom: spacing.space(1);\n }\n\n &__transcript {\n @include colour.contrast;\n\n max-height: 25rem;\n\n padding: spacing.space(1.5);\n\n overflow: auto;\n\n border-radius: 0 0 bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &__caption {\n margin: 0 spacing.space(1);\n padding: spacing.space(1);\n\n @include typography.font-size(16);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &--plain &__image-wrapper {\n padding: 0;\n }\n\n &--plain &__image {\n box-shadow: none;\n }\n\n @include media.on-tiny {\n &__image-wrapper {\n padding: 0;\n }\n\n .tna-column & {\n width: calc(100% + #{grid.gutter-width-tiny-double()});\n\n position: relative;\n left: -#{grid.gutter-width-tiny()};\n }\n\n &__image {\n max-height: 60rem;\n\n box-shadow: none;\n }\n\n &__caption {\n margin-right: 0;\n margin-left: 0;\n\n @include typography.font-size(14);\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline-dark\", 1px);\n\n &__caption {\n margin: 0;\n\n border: none;\n }\n }\n}\n","@mixin drop-shadow {\n box-shadow:\n 0 0.25rem 1rem -0.25rem rgb(0 0 0 / 25%),\n 0 0.125rem 0.5rem -0.25rem rgb(0 0 0 / 75%);\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-quick-filters {\n @include spacing.space-above;\n\n display: flex;\n flex-wrap: wrap;\n gap: spacing.space(0.25) spacing.space(1.25);\n\n @include typography.font-size(16);\n list-style: none;\n\n &--stacked {\n flex-direction: column;\n align-items: flex-start;\n }\n\n &--filled {\n align-items: flex-start;\n }\n\n &--stacked#{&}--filled {\n align-items: stretch;\n }\n\n &__item {\n }\n\n &--filled &__item {\n flex: 1 1 auto;\n\n text-align: center;\n }\n\n &__link {\n display: block;\n\n position: relative;\n }\n\n &__item--selected &__link {\n @include typography.main-font-weight-bold;\n\n &::after {\n content: \"\";\n\n height: 0;\n\n position: absolute;\n top: 100%;\n right: 0;\n left: 0;\n @include colour.thick-keyline-accent(\"bottom\");\n }\n }\n\n &--stacked &__item--selected &__link {\n padding-left: 0.75rem;\n\n border-bottom-width: 0;\n @include colour.thick-keyline-accent(\"left\");\n\n &::after {\n display: none;\n }\n }\n}\n","@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-secondary-navigation {\n display: flex;\n flex-flow: row wrap;\n\n gap: 0 spacing.space(2);\n\n line-height: 1.35;\n\n &__heading {\n padding-bottom: spacing.space(0.5);\n\n align-self: flex-end;\n\n line-height: inherit;\n\n @include colour.thick-keyline-transparent(bottom);\n }\n\n &__items {\n display: flex;\n align-items: flex-end;\n justify-content: flex-start;\n gap: spacing.space(2);\n\n list-style: none;\n }\n\n &__item {\n }\n\n &__link {\n width: 100%;\n padding: spacing.space(0.5) 0;\n\n display: block;\n\n box-sizing: border-box;\n\n line-height: inherit;\n\n text-align: left;\n text-decoration: underline;\n\n background: none;\n\n border: none;\n @include colour.thick-keyline-transparent(top);\n @include colour.thick-keyline-transparent(bottom);\n\n cursor: pointer;\n\n &,\n &:link {\n @include colour.colour-font(\"link\");\n }\n\n &:visited {\n @include colour.colour-font(\"link-visited\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__item--current &__link {\n @include colour.colour-font(\"font-base\");\n text-decoration: none;\n @include colour.thick-keyline-accent(bottom);\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &--overflow {\n overflow-x: auto;\n }\n\n &::after {\n content: \"\";\n\n width: 100%;\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &--no-bottom-border::after {\n display: none;\n }\n\n &--unindent::after {\n width: calc(100% + #{grid.gutter-width-double()});\n margin-right: -#{grid.gutter-width()};\n margin-left: -#{grid.gutter-width()};\n }\n\n @include media.on-smaller-than-large {\n flex-direction: column;\n gap: 0;\n\n &__heading {\n width: 100%;\n // padding-bottom: 0;\n border-bottom: none;\n\n align-self: flex-start;\n }\n }\n\n @include media.on-mobile {\n border-bottom: none;\n\n &__items {\n flex-direction: column;\n align-items: stretch;\n gap: 0;\n\n position: relative;\n // @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &__item {\n position: relative;\n\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n\n &--current {\n &::before {\n content: \"\";\n\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n @include colour.thick-keyline-accent(left);\n }\n }\n }\n\n &__link {\n padding: spacing.space(0.5) spacing.space(1);\n }\n\n &__link,\n &__item--current &__link {\n border-top: none;\n border-bottom: none;\n }\n\n &--overflow {\n overflow-x: visible;\n }\n }\n\n @include media.on-small {\n &--unindent &__items {\n margin-right: -#{grid.gutter-width()};\n margin-left: -#{grid.gutter-width()};\n }\n\n &--unindent &__link {\n padding: spacing.space(0.5) grid.gutter-width();\n }\n }\n\n @include media.on-tiny {\n &--unindent::after {\n width: calc(100% + #{grid.gutter-width-tiny-double()});\n }\n\n &--unindent::after,\n &--unindent &__items {\n margin-right: -#{grid.gutter-width-tiny()};\n margin-left: -#{grid.gutter-width-tiny()};\n }\n\n &--unindent &__link {\n padding: spacing.space(0.5) grid.gutter-width-tiny();\n }\n }\n}\n","@use \"../../variables/a11y\" as a11yVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-sidebar {\n width: 100%;\n\n @include typography.font-size(16);\n\n &__heading {\n }\n\n &__items,\n &__item-children {\n display: flex;\n flex-direction: column;\n gap: spacing.space(0.25);\n\n list-style: none;\n }\n\n &__items {\n padding-top: max(\n spacing.space(0.5),\n #{a11yVars.$focus-outline-total-width}\n );\n }\n\n &__item {\n }\n\n &__item-children {\n }\n\n &__item-child {\n }\n\n &__link {\n }\n\n /*\n * ------------------------------------------\n * Contents\n * ------------------------------------------\n */\n &--contents &__item-children {\n margin-top: spacing.space(0.25);\n padding-left: spacing.space(2);\n\n @include colour.thick-keyline(\"left\");\n }\n\n /*\n * ------------------------------------------\n * Sections\n * ------------------------------------------\n */\n &--sections &__items {\n line-height: 1.35;\n }\n\n &--sections &__link {\n padding: spacing.space(0.25) spacing.space(0.5);\n\n display: block;\n }\n\n &--sections &__item--current &__link {\n @include colour.accent;\n\n @include borders.rounded-border;\n }\n\n /*\n * ------------------------------------------\n * Pages\n * ------------------------------------------\n */\n &--pages &__item--current {\n padding-left: spacing.space(0.75);\n\n @include colour.thick-keyline-accent(\"left\");\n }\n\n &--pages &__item--current > &__link {\n @include typography.main-font-weight-bold;\n }\n\n &--pages &__item-children {\n gap: 0;\n }\n\n /*\n * ------------------------------------------\n * Dashed items\n * ------------------------------------------\n */\n &--contents &__items,\n &--pages &__item-children {\n padding-left: spacing.space(1.5);\n }\n\n &--contents &__item,\n &--contents &__item-child,\n &--pages &__item-child {\n list-style: \"— \" outside;\n\n &::marker {\n @include colour.colour-font(\"font-light\");\n }\n }\n\n /*\n * ------------------------------------------\n * Sticky\n * ------------------------------------------\n */\n &--sticky {\n max-height: 100vh;\n max-height: 100dvh;\n\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n\n position: sticky;\n top: 0;\n }\n\n @include media.on-small {\n &--static-on-mobile,\n &--static-on-small {\n max-height: none;\n\n position: static;\n }\n }\n\n @include media.on-tiny {\n &--static-on-mobile,\n &--static-on-tiny {\n max-height: none;\n\n position: static;\n }\n }\n\n &--sticky &__items {\n margin: 0;\n padding-bottom: a11yVars.$focus-outline-total-width;\n\n overflow-y: auto;\n\n flex: 1;\n }\n\n &--sticky#{&}--contents &__items,\n &--sticky#{&}--pages &__items {\n padding-right: spacing.space(1);\n }\n\n &--sticky#{&}--sections &__items,\n &--sticky#{&}--pages &__items {\n width: calc(100% - #{a11yVars.$focus-outline-total-width});\n padding-right: a11yVars.$focus-outline-total-width;\n padding-left: a11yVars.$focus-outline-total-width;\n\n box-sizing: content-box;\n\n position: relative;\n left: -#{a11yVars.$focus-outline-total-width};\n }\n}\n","@use \"../../variables/a11y\" as a11yVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n@use \"../../components/button/button\" as button;\n\n.tna-skip-link {\n width: 1px !important;\n height: 1px !important;\n margin: 0 !important;\n padding: 0 !important;\n\n display: block !important;\n\n overflow: hidden !important;\n\n position: absolute !important;\n top: -100vh !important;\n left: -100vw !important;\n\n white-space: nowrap !important;\n\n background-color: colour.brand-colour(\"yellow\");\n\n border: a11yVars.$focus-outline-outer-width #000 solid;\n\n -webkit-clip-path: inset(50%) !important;\n clip-path: inset(50%) !important;\n\n &,\n &:link,\n &:visited {\n color: colour.brand-colour(\"black\");\n }\n\n &:active,\n &:focus {\n width: auto !important;\n height: auto !important;\n margin: inherit !important;\n padding: spacing.space(1) spacing.space(1.5) !important;\n\n overflow: visible !important;\n\n position: static !important;\n\n white-space: inherit !important;\n\n outline: none !important;\n\n box-shadow: inset 0 0 0 a11yVars.$focus-outline-inner-width #fff !important;\n\n -webkit-clip-path: none !important;\n clip-path: none !important;\n }\n\n &::after {\n content: \"\\203A\";\n content: \"\\203A\" / \"\";\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-tabs {\n @include spacing.space-above;\n\n &__list {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-wrap: nowrap;\n align-items: stretch;\n gap: spacing.space(0.5);\n\n position: relative;\n z-index: 2;\n\n list-style: none;\n }\n\n &--small &__list {\n gap: spacing.space(0.25);\n }\n\n &__button {\n padding: bordersVars.$thick-border-width 0;\n\n position: relative;\n\n text-align: center;\n\n background: transparent;\n\n border: none;\n\n border: 1px transparent solid;\n border-bottom: none;\n\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n\n cursor: pointer;\n\n &:active {\n @include a11y.focus-outline;\n }\n\n &[aria-selected=\"true\"] {\n padding-top: 0;\n\n @include colour.colour-border(\"keyline\");\n\n &::after {\n content: \"\";\n\n height: 1px;\n\n position: absolute;\n top: 100%;\n right: 0;\n left: 0;\n\n @include colour.colour-background(\"background\");\n }\n }\n }\n\n &__button-inner {\n padding: spacing.space(0.5) spacing.space(0.75);\n\n display: block;\n\n text-decoration: underline;\n\n @include colour.colour-font(\"font-dark\");\n }\n\n &--small &__button-inner {\n padding: spacing.space(0.25) spacing.space(0.5) spacing.space(0.125);\n\n @include typography.font-size(16);\n }\n\n &__button:hover &__button-inner,\n &__button:focus-visible &__button-inner {\n @include typography.interacted-text-decoration;\n }\n\n &__button[aria-selected=\"true\"] &__button-inner {\n text-decoration: none;\n\n @include colour.thick-keyline-accent(top);\n border-radius: #{bordersVars.$rounded-border-radius - 1px}\n #{bordersVars.$rounded-border-radius - 1px} 0 0;\n }\n\n &__items {\n display: flex;\n flex-direction: column;\n gap: spacing.space(2);\n\n position: relative;\n z-index: 1;\n }\n\n &__item {\n border-radius: 0 0 bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--interactive &__item {\n padding: spacing.space(1);\n @include colour.colour-border(\"keyline\", 1px, solid);\n }\n\n &--tint#{&}--interactive &__button[aria-selected=\"true\"],\n &--tint#{&}--interactive &__button:hover &__button-inner,\n &--tint#{&}--interactive &__button:focus-visible &__button-inner,\n &--tint#{&}--interactive &__items {\n @include colour.tint;\n }\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-warning {\n @include spacing.space-above;\n padding: spacing.space(1);\n\n display: flex;\n align-items: flex-start;\n gap: spacing.space(1);\n\n @include colour.accent-light;\n @include colour.always-light;\n\n @include colour.colour-background-brand(\"cream\");\n\n @include colour.thick-keyline-brand(left, \"yellow\");\n @include borders.rounded-border;\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n\n @include media.on-tiny {\n flex-direction: column;\n gap: spacing.space(0.5);\n }\n\n &__heading {\n }\n\n &__heading-icon {\n width: 2rem;\n height: 2rem;\n\n display: block;\n\n line-height: 2rem;\n text-align: center;\n text-transform: lowercase;\n\n border-radius: 100%;\n\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(24);\n @include typography.main-font-weight-bold;\n\n @include colour.colour-border(\"font-dark\", 0.1875rem);\n\n @include media.on-mobile {\n width: 1.5rem;\n height: 1.5rem;\n\n @include typography.font-size(19);\n line-height: 1.5rem;\n\n @include colour.colour-border(\"font-dark\", 0.125rem);\n }\n }\n\n &__body {\n width: 100%;\n margin-top: 0;\n\n flex: 1;\n\n align-self: center;\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-fieldset {\n @include spacing.space-above;\n\n &__inner {\n border: none;\n }\n\n &__legend {\n }\n\n &__heading {\n margin: 0;\n padding: 0;\n\n display: block;\n }\n\n & &__hint {\n margin-top: spacing.space(0.5);\n margin-bottom: spacing.space(1);\n }\n\n & &__error {\n margin-top: spacing.space(0.25);\n\n @include colour.colour-font(\"form-error-text\");\n @include typography.main-font-weight-bold;\n }\n\n &__body {\n margin-top: spacing.space(0.5);\n\n display: flex;\n flex-direction: column;\n gap: spacing.space(1);\n\n > * {\n margin-top: 0;\n }\n }\n\n &--error {\n padding-left: spacing.space(1);\n\n @include colour.thick-keyline-error(left);\n }\n\n &--small-hint &__hint {\n margin-top: spacing.space(0.125);\n margin-bottom: 0;\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-checkboxes {\n align-self: stretch;\n\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: spacing.space(1);\n\n &__item {\n padding-left: spacing.space(3);\n\n position: relative;\n\n input {\n width: 1px;\n height: 1px;\n margin: 0;\n padding: 0;\n\n position: absolute;\n top: -1px;\n left: -1px;\n\n opacity: 0;\n }\n\n &-label {\n display: block;\n\n line-height: 2rem;\n\n cursor: pointer;\n\n &::before,\n &::after {\n content: \"\";\n\n width: 2rem;\n\n position: absolute;\n top: 0;\n left: 0;\n }\n\n &::before {\n height: 2rem;\n\n display: block;\n box-sizing: border-box;\n\n z-index: 1;\n\n @include colour.colour-input;\n\n border-radius: 0.1px;\n @include borders.rounded-border;\n }\n\n &::after {\n width: 1.25rem;\n height: 0.5rem;\n margin-top: -0.1875rem;\n\n display: none;\n\n top: 1rem;\n left: 1rem;\n z-index: 2;\n\n @include colour.colour-border(\"input-background\", 0, solid);\n border-width: 0 0 formsVars.$checkbox-checkmark-width\n formsVars.$checkbox-checkmark-width;\n\n transform: translateX(-50%) translateY(-50%) rotate(-45deg);\n }\n }\n\n &-hint {\n display: block;\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n line-height: 1.25;\n }\n }\n\n &--small {\n gap: spacing.space(0.5);\n }\n\n &--small &__item {\n padding-left: spacing.space(2.25);\n\n &-label {\n line-height: 1.5rem;\n\n &::before {\n width: 1.5rem;\n height: 1.5rem;\n }\n\n &::after {\n width: 0.825rem;\n height: 0.375rem;\n margin-top: -0.125rem;\n\n top: 0.75rem;\n left: 0.75rem;\n }\n }\n }\n\n &--inline {\n flex-flow: row wrap;\n\n align-items: flex-start;\n gap: spacing.space(1) spacing.space(2);\n\n @include media.on-tiny {\n flex-direction: column;\n align-items: flex-start;\n }\n }\n\n &__item-label:active {\n &::before {\n @include a11y.active-outline;\n }\n }\n\n input:focus + &__item-label {\n &::before {\n @include a11y.focus-outline;\n }\n }\n\n input:checked + &__item-label {\n &::before {\n @include colour.colour-background(\"input-foreground\");\n }\n\n &::after {\n display: block;\n }\n }\n\n input:focus + &__item-label,\n &__item:hover &__item-label {\n &::before {\n box-shadow: 0 0 0 0.125rem var(--input-border);\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-date-input {\n display: flex;\n gap: spacing.space(1);\n\n &__item {\n &-label {\n padding-bottom: spacing.space(0.5);\n\n display: block;\n\n line-height: 1;\n\n @include typography.font-size(16);\n }\n\n &-input {\n width: 3rem;\n padding: 0 spacing.space(0.375);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n &--wider {\n width: 4.5rem;\n }\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n }\n }\n\n &--inline {\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-date-search {\n max-width: 100%;\n padding: 0 spacing.space(0.375);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--max-width {\n width: 100%;\n }\n}\n","@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-error-summary {\n @include spacing.space-above;\n padding: spacing.space(1);\n\n @include colour.colour-background(\"background\");\n\n @include colour.colour-border(\"form-error-border\", 0.3125rem, solid);\n @include borders.rounded-border;\n\n &:focus {\n @include a11y.focus-outline;\n }\n\n &__list {\n margin: spacing.space(0.5) 0 0;\n\n list-style: none;\n }\n\n &__item {\n }\n\n &__link {\n @include typography.main-font-weight-bold;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"form-error-text\");\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-file-input {\n width: 100%;\n\n display: block;\n\n box-sizing: border-box;\n\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &::file-selector-button {\n margin-right: spacing.space(0.5);\n\n cursor: inherit;\n }\n\n &__droppable {\n width: 100%;\n padding: spacing.space(0.5) spacing.space(1) spacing.space(1);\n\n box-sizing: border-box;\n\n position: relative;\n\n @include colour.colour-border(\n \"keyline\",\n formsVars.$form-field-border-width,\n dashed\n );\n @include borders.rounded-border;\n }\n\n &__droppable:has(&:focus-visible) {\n @include a11y.focus-outline;\n }\n\n &__droppable & {\n padding: spacing.space(1);\n\n position: absolute;\n inset: 0;\n z-index: 1;\n\n opacity: 0;\n }\n\n &__droppable-buttons {\n @include typography.font-size(14);\n line-height: 1.5rem;\n\n @include media.on-tiny {\n flex-direction: row;\n align-items: center;\n }\n }\n\n &__droppable-status {\n display: block;\n overflow: hidden;\n\n line-height: 2;\n text-overflow: ellipsis;\n\n white-space: nowrap;\n }\n\n &__droppable &:hover ~ &__droppable-buttons {\n .tna-button {\n &:not(.tna-button--plain) {\n @include colour.colour-font(\"button-hover-text\");\n text-decoration: none;\n\n background: transparent;\n }\n }\n }\n\n &__droppable--over,\n &__droppable--over-multiple {\n @include colour.colour-border(\"keyline-dark\");\n\n &::before {\n display: flex;\n align-items: center;\n justify-content: center;\n\n position: absolute;\n inset: spacing.space(0.5);\n z-index: 2;\n\n pointer-events: none;\n\n @include colour.green-accent;\n\n @include colour.colour-font(\"accent-font-base\");\n @include typography.main-font-weight-bold;\n\n @include colour.colour-background(\"accent-background\");\n }\n }\n\n &__droppable--over {\n &::before {\n content: \"Drop file here\";\n }\n }\n\n &__droppable--over-multiple {\n &::before {\n content: \"Drop files here\";\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-radios {\n align-self: stretch;\n\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: spacing.space(1);\n\n &__item {\n padding-left: spacing.space(3);\n\n position: relative;\n\n input {\n width: 1px;\n height: 1px;\n margin: 0;\n padding: 0;\n\n position: absolute;\n top: -1px;\n left: -1px;\n\n opacity: 0;\n }\n\n &-label {\n display: block;\n\n line-height: 2rem;\n\n cursor: pointer;\n\n &::before,\n &::after {\n content: \"\";\n\n position: absolute;\n top: 0;\n left: 0;\n\n border-radius: 100%;\n }\n\n &::before {\n width: 2rem;\n height: 2rem;\n\n display: block;\n box-sizing: border-box;\n\n z-index: 1;\n\n @include colour.colour-input;\n }\n\n &::after {\n margin: 0.5rem;\n\n display: none;\n\n z-index: 2;\n\n @include colour.colour-background(\"input-foreground\");\n\n @include colour.colour-border(\"input-foreground\", 0.5rem);\n }\n }\n\n &-hint {\n display: block;\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n line-height: 1.25;\n }\n }\n\n &--small {\n gap: spacing.space(0.5);\n }\n\n &--small &__item {\n padding-left: spacing.space(2.25);\n\n &-label {\n line-height: 1.5rem;\n\n &::before {\n width: 1.5rem;\n height: 1.5rem;\n }\n\n &::after {\n margin: 0.3125rem;\n\n @include colour.colour-border(\"input-foreground\", 0.4375rem);\n }\n }\n }\n\n &--inline {\n flex-flow: row wrap;\n\n align-items: flex-start;\n gap: spacing.space(1) spacing.space(2);\n\n @include media.on-tiny {\n flex-direction: column;\n align-items: flex-start;\n }\n }\n\n &__item-label:active {\n &::before {\n @include a11y.active-outline;\n }\n }\n\n input:focus + &__item-label {\n &::before {\n @include a11y.focus-outline;\n }\n }\n\n input:checked + &__item-label {\n &::after {\n display: block;\n }\n }\n\n input:focus + &__item-label,\n &__item:hover &__item-label {\n &::before {\n box-shadow: 0 0 0 0.125rem var(--input-border);\n }\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n.tna-search-field {\n align-self: stretch;\n\n display: flex;\n gap: formsVars.$form-field-border-width;\n\n &__input {\n min-width: 8rem;\n width: 0;\n padding: 0 spacing.space(0.375);\n\n display: block;\n\n line-height: 2rem;\n\n flex: 1;\n\n @include colour.colour-input;\n @include borders.rounded-border;\n }\n\n &__button {\n padding-top: 0;\n padding-bottom: 0;\n }\n}\n","$form-field-border-width: 2px !default;\n$checkbox-checkmark-width: 0.1875rem !default;\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n.tna-select {\n max-width: 100%;\n height: calc(2rem + 6px);\n padding: 0 spacing.space(1) 0 spacing.space(0.5);\n\n display: block;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n // &--styled {\n // padding: 0 spacing.space(2.5) 0 spacing.space(0.75);\n\n // appearance: none;\n\n // background-image: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjUwMHB4IiBoZWlnaHQ9IjUwMHB4IiB2aWV3Qm94PSIwIDAgNTAwIDUwMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNTAwIDUwMCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHBvbHlnb24gcG9pbnRzPSIyNTAsNDAwIDUwLDEwMCA0NTAsMTAwIiBmaWxsPSIjMDAwIi8+PC9zdmc+\");\n // background-position: center right 0.5rem;\n // background-size: 0.75rem 0.75rem;\n // background-repeat: no-repeat;\n // }\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--s {\n width: 10rem;\n }\n\n &--m {\n width: 20rem;\n }\n\n &--l {\n width: 40rem;\n }\n\n &--xl {\n width: 80rem;\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n.tna-text-input {\n padding: 0 spacing.space(0.375);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n &,\n &-wrapper {\n width: 100%;\n }\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--xs {\n max-width: 5rem;\n }\n\n &--s {\n max-width: 10rem;\n }\n\n &--m {\n max-width: 20rem;\n }\n\n &--l {\n max-width: 40rem;\n }\n\n &--xl {\n max-width: 80rem;\n }\n\n &-wrapper & {\n flex: 1;\n }\n\n &-wrapper {\n display: flex;\n align-items: stretch;\n gap: formsVars.$form-field-border-width;\n\n .tna-button {\n white-space: nowrap;\n\n svg {\n width: 28px;\n margin: 0;\n }\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n$textarea-minimum-lines-visible: 5.5 !default;\n$textarea-line-height: 1.5rem !default;\n$textarea-vertical-padding: 0.25 !default;\n\n.tna-textarea {\n width: 100%;\n min-height: #{($textarea-line-height * $textarea-minimum-lines-visible) +\n (spacing.space($textarea-vertical-padding * 2))};\n padding: spacing.space($textarea-vertical-padding) spacing.space(0.5);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 1.5rem;\n\n resize: vertical;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--m {\n max-width: 20rem;\n }\n\n &--l {\n max-width: 40rem;\n }\n\n &--xl {\n max-width: 80rem;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["../../src/nationalarchives/all.scss","../../src/nationalarchives/tools/_colour.scss","../../src/nationalarchives/tools/_media.scss","../../src/nationalarchives/tools/_a11y.scss","../../src/nationalarchives/tools/_borders.scss","../../src/nationalarchives/variables/_borders.scss","../../src/nationalarchives/tools/_spacing.scss","../../src/nationalarchives/utilities/a11y/_index.scss","../../src/nationalarchives/utilities/animations/_index.scss","../../src/nationalarchives/utilities/areas/_index.scss","../../src/nationalarchives/utilities/colour/_index.scss","../../src/nationalarchives/utilities/columns/_index.scss","../../src/nationalarchives/utilities/forms/_index.scss","../../src/nationalarchives/tools/_typography.scss","../../src/nationalarchives/variables/_typography.scss","../../src/nationalarchives/utilities/global/_index.scss","../../src/nationalarchives/utilities/grid/_index.scss","../../src/nationalarchives/variables/_grid.scss","../../src/nationalarchives/tools/_grid.scss","../../src/nationalarchives/utilities/typography/_index.scss","../../src/nationalarchives/utilities/lists/_index.scss","../../src/nationalarchives/utilities/logo/_index.scss","../../src/nationalarchives/utilities/overrides/_index.scss","../../src/nationalarchives/utilities/reset/_index.scss","../../src/nationalarchives/utilities/tables/_index.scss","../../src/nationalarchives/components/accordion/accordion.scss","../../src/nationalarchives/components/back-link/back-link.scss","../../src/nationalarchives/components/breadcrumbs/breadcrumbs.scss","../../src/nationalarchives/components/button/_button-group.scss","../../src/nationalarchives/components/button/button.scss","../../src/nationalarchives/components/card/card.scss","../../src/nationalarchives/variables/_a11y.scss","../../src/nationalarchives/components/compound-filters/compound-filters.scss","../../src/nationalarchives/components/cookie-banner/cookie-banner.scss","../../src/nationalarchives/components/details/details.scss","../../src/nationalarchives/components/files-list/files-list.scss","../../src/nationalarchives/components/footer/footer.scss","../../src/nationalarchives/components/gallery/gallery.scss","../../src/nationalarchives/components/global-header/global-header.scss","../../src/nationalarchives/components/header/header.scss","../../src/nationalarchives/components/hero/hero.scss","../../src/nationalarchives/components/index-grid/index-grid.scss","../../src/nationalarchives/components/pagination/pagination.scss","../../src/nationalarchives/components/panel/panel.scss","../../src/nationalarchives/components/phase-banner/phase-banner.scss","../../src/nationalarchives/components/picture/picture.scss","../../src/nationalarchives/tools/_shadows.scss","../../src/nationalarchives/components/quick-filters/quick-filters.scss","../../src/nationalarchives/components/secondary-navigation/secondary-navigation.scss","../../src/nationalarchives/components/sidebar/sidebar.scss","../../src/nationalarchives/components/skip-link/skip-link.scss","../../src/nationalarchives/components/tabs/tabs.scss","../../src/nationalarchives/components/warning/warning.scss","../../src/nationalarchives/components/fieldset/fieldset.scss","../../src/nationalarchives/components/checkboxes/checkboxes.scss","../../src/nationalarchives/components/date-input/date-input.scss","../../src/nationalarchives/components/date-search/date-search.scss","../../src/nationalarchives/components/error-summary/error-summary.scss","../../src/nationalarchives/components/file-input/file-input.scss","../../src/nationalarchives/components/radios/radios.scss","../../src/nationalarchives/components/search-field/search-field.scss","../../src/nationalarchives/variables/_forms.scss","../../src/nationalarchives/components/select/select.scss","../../src/nationalarchives/components/text-input/text-input.scss","../../src/nationalarchives/components/textarea/textarea.scss"],"names":[],"mappings":"CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GCsJA,oLA9DE,4CAIA,6DA4BI,mDAsHN,2BAvMM,sBAEE,2BAFF,2DAEE,0BAFF,0BAEE,+BAFF,kCAEE,uCAFF,kCAEE,uCAFF,gBAEE,qBAFF,wBAEE,6BAFF,oEAEE,uCAFF,gCAEE,qCAFF,+/CA2MJ,+BAJF,2BAjLM,iCAEE,sCAFF,kDAEE,+BAFF,0BAEE,+BAFF,2BAEE,gCAFF,iCAEE,sCAFF,gBAEE,qBAFF,wBAEE,6BAFF,+DAEE,mCAFF,6BAEE,kCAFF,0+CAkMN,2UACE,yCACA,uCACA,uCACA,yCACA,yCACA,6BACA,6CACA,mCACA,6CACA,2CACA,uDACA,uDACA,mEAhLA,4CAJA,gCCNA,wBDqMF,0DAEI,yCACA,uCACA,uCACA,yCACA,yCACA,6BACA,6CACA,mCACA,6CACA,2CACA,uDACA,uDACA,mEAzMF,4CAJA,iCAyNF,qCAEI,4OAvNF,4CAJA,gCAuOF,2eACE,qCApOA,4CA6OF,wZACE,uCACA,qCACA,qCACA,uCACA,uCACA,2BACA,mCACA,iCACA,2CACA,yCACA,yCACA,qDACA,qDACA,iEA3PA,4CAJA,gCA0QF,qGACE,6CACA,qBACA,0BACA,kCACA,kCACA,kCACA,gCACA,kCACA,kCAIA,kCAIA,8CAIA,0CA3RA,4CAJA,gCAqSE,mCADF,qNAKI,uCACA,qCACA,qCACA,uCACA,uCACA,2BACA,mCACA,iCACA,2CACA,yCACA,yCACA,qDACA,qDACA,kEAIJ,6MAIE,uCACA,qCACA,qCACA,uCACA,uCACA,2BACA,mCACA,iCACA,2CACA,yCACA,yCACA,qDACA,qDACA,iEAQJ,kEACE,iDACA,yDACA,6CACA,4CACA,4CACA,mDACA,mDACA,uCACA,+CACA,gDACA,qDACA,sDACA,0DAOF,icACE,kDACA,kDACA,yDACA,yDACA,6CACA,qDACA,sDACA,2DACA,sDAGF,+DACE,6CACA,yDACA,yCACA,gDACA,4DAQF,4DACE,iDACA,yDACA,6CACA,0DAQF,kEACE,iDACA,yDACA,4CACA,0DAQF,qKACE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CA,yBAIE,YCwBiB,IDpEnB,mBAmDA,gBACA,yBMgCA,cACA,kBACA,wBfzFA,cCDsB,Ic8Fb,yDACP,0BAEA,2EACE,0BACA,kCACA,8BAEA,yGACE,cAKN,oFlBtBA,6CAibA,+BkB3ZA,oFlBtBA,qBkB+BF,uGACE,UAEA,gBAEA,+BAEA,YACA,mBAGE,mIN/DF,0BACA,0BCpCsC,QDqCtC,sBCvCoC,OKwGlC,mJACE,cAKN,wJlBpBM,mDkByBJ,iCACA,yBAEA,guBlB5DA,oDAIA,qDAiCI,iDkB+BF,gzBlBpEF,2DkB0EE,mCADF,wblBzEA,oDAIA,qDAiCI,iDkB4CA,gelBjFJ,4DkB4HF,eAGE,aACA,eACA,kBAEA,gBAEA,qBACE,aACA,mBAIJ,kNlB3IE,qCkB6IA,iBAEA,oOACE,qBAEA,mBAEA,mSACE,WAEA,cACA,eACA,mBACA,mBAEA,qBAEA,sBAEA,wBlB1IA,4FkBiJA,opBlBlIA,0CkBwIJ,iRACE,oBAIJ,kDNnOE,YCmBA,gDDlBA,YCqBoB,IDuBpB,YCDuB,ID7EvB,eXwCA,kDiB4NF,kDNpQE,gBX4EA,wBiBwLF,kDNpQE,mBMiRF,gDNhPE,YCmBA,gDDlBA,YCqBoB,IDuBpB,YCKsB,KDnFtB,kBXwCA,kDiByOF,gDNjRE,gBX4EA,wBiBqMF,gDNjRE,qBM8RE,kEACE,aACA,cACA,gBACA,kBAEA,sBACA,wBAKN,gDNzRE,YCiBsB,ID4CtB,YCWsB,IDzFtB,mBXwCA,kDiBkQF,gDN1SE,oBX4EA,wBiB8NF,gDN1SE,qBMuTF,gDNtSE,YCiBsB,ID4CtB,YCiBsB,ID/FtB,oBMoUF,gBN3TE,YCuBiB,IKySjB,cACA,YL3OsB,IK8OxB,sIAEE,gBACA,iBAEA,kPACE,cAGF,mwBAGE,gBAgCE,qCACE,aAcN,wBACE,mBAaF,mBACE,SAEA,cAoBJ,gBAEE,eACA,gBACA,cACA,4BlB1UI,+DkByVJ,uBNpbA,YCoBwB,IKkatB,YACA,eAEA,uCACE,YAGF,4CACE,mBAGF,0CACE,oBAIJ,0BACE,gBNpdF,eMwdE,kCACE,gBACA,mBjBtaJ,wBiByXF,gBAkDI,mCAKJ,qBNp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","file":"all.css","sourcesContent":["/*!\n * ==========================================\n * TNA Frontend\n * ------------------------------------------\n * www.nationalarchives.gov.uk\n * github.com/nationalarchives/tna-frontend\n * ==========================================\n */\n\n@use \"variables\";\n@use \"tools\";\n@use \"utilities\";\n@use \"components\";\n","@use \"sass:list\";\n@use \"sass:map\";\n@use \"sass:meta\";\n@use \"../variables/borders\";\n@use \"../variables/forms\";\n@use \"../variables/colour\";\n@use \"../variables/features\";\n@use \"../tools/media\";\n\n$base-colours: (\n \"background\",\n // \"background-tint\",\n \"font-base\",\n \"font-dark\",\n \"font-light\",\n \"icon-light\",\n \"link\",\n \"link-visited\",\n // \"focus-outline\",\n \"keyline\",\n \"keyline-dark\",\n // \"input-foreground\",\n // \"input-background\",\n // \"input-border\",\n // \"form-error-border\",\n // \"form-error-text\",\n // \"button-text\",\n // \"button-background\",\n // \"button-hover-text\",\n // \"button-hover-background\",\n);\n\n@function brand-colour($colour, $opacity: 1) {\n @return colour.brand-colour($colour, $opacity);\n}\n\n@mixin colour-css-vars($excludes...) {\n @each $name, $value in colour.$colour-palette-default {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index($base-colours, $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@mixin colour-css-vars-dark($excludes...) {\n @each $name, $value in colour.$colour-palette-dark {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index($base-colours, $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@mixin colour-css-vars-high-contrast($excludes...) {\n @each $name, $value in colour.$colour-palette-high-contrast {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index($base-colours, $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@mixin colour-css-vars-high-contrast-dark($excludes...) {\n @each $name, $value in colour.$colour-palette-high-contrast-dark {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n @if list.index((\"keyline\", \"keyline-dark\"), $name) {\n --base-#{$name}: #{$value};\n }\n }\n }\n}\n\n@function colour-var($colour) {\n @return var(\n --#{$colour},\n #{map.get(colour.$colour-palette-default, $colour)}\n );\n}\n\n@mixin colour-font($colour, $important: false) {\n color: colour-var($colour) if(sass($important): !important; else: null);\n}\n\n@mixin colour-background($colour, $important: false) {\n background-color: colour-var($colour)\n if(sass($important): !important; else: null);\n}\n\n@mixin colour-background-brand($brandColour, $important: false) {\n background-color: #{brand-colour($brandColour)}\n if(sass($important): !important; else: null);\n}\n\n@mixin colour-border(\n $colour,\n $width: \"\",\n $style: solid,\n $direction: \"\",\n $important: false\n) {\n @if $direction != \"\" {\n @if $width != \"\" {\n border-#{$direction}: $width\n colour-var($colour)\n $style\n if(sass($important): !important; else: null);\n } @else {\n border-#{$direction}-color: colour-var($colour)\n if(sass($important): !important; else: null);\n }\n } @else {\n @if $width != \"\" {\n border: $width\n colour-var($colour)\n $style\n if(sass($important): !important; else: null);\n } @else {\n border-color: var(\n --#{$colour},\n #{map.get(colour.$colour-palette-default, $colour)}\n )\n if(sass($important): !important; else: null);\n }\n }\n}\n\n@mixin colour-outline($colour, $width: \"\", $style: solid, $important: false) {\n @if $width != \"\" {\n outline: $width\n colour-var($colour)\n $style\n if(sass($important): !important; else: null);\n } @else {\n outline-color: colour-var($colour)\n if(sass($important): !important; else: null);\n }\n}\n\n@mixin colour-fill($colour, $important: false) {\n fill: colour-var($colour) if(sass($important): !important; else: null);\n}\n\n%colour-input {\n @include colour-font(\"input-foreground\");\n @include colour-background(\"input-background\");\n @include colour-border(\"input-border\", forms.$form-field-border-width);\n}\n\n@mixin colour-input() {\n @extend %colour-input;\n}\n\n@mixin thick-keyline($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\"keyline\", $border-width, solid, $direction);\n } @else {\n @include colour-border(\"keyline\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-dark($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\"keyline-dark\", $border-width, solid, $direction);\n } @else {\n @include colour-border(\"keyline-dark\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-accent($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\"accent-border\", $border-width, solid, $direction);\n } @else {\n @include colour-border(\"accent-border\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-error($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n @include colour-border(\n \"form-error-border\",\n $border-width,\n solid,\n $direction\n );\n } @else {\n @include colour-border(\"form-error-border\", $border-width, solid);\n }\n}\n\n@mixin thick-keyline-brand($direction: \"\", $brandColour, $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n border-#{$direction}: $border-width #{brand-colour($brandColour)} solid;\n } @else {\n border: $border-width #{brand-colour($brandColour)} solid;\n }\n}\n\n@mixin thick-keyline-transparent($direction: \"\", $veryThick: false) {\n $border-width: borders.$thick-border-width;\n @if $veryThick {\n $border-width: borders.$very-thick-border-width;\n }\n @if $direction != \"\" {\n border-#{$direction}: $border-width transparent solid;\n } @else {\n border: $border-width transparent solid;\n }\n}\n\n// Use light theme colours (except for \"form-error-border\")\n%always-light {\n // @include colour-css-vars(\"form-error-border\", \"focus-outline\");\n @include colour-css-vars;\n\n @media (prefers-contrast: more) {\n // @include colour-css-vars-high-contrast(\n // \"form-error-border\",\n // \"focus-outline\"\n // );\n @include colour-css-vars-high-contrast;\n }\n}\n\n@mixin always-light {\n @extend %always-light;\n}\n\n%contrast {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n}\n\n@mixin contrast {\n @extend %contrast;\n}\n\n%contrast-on-mobile {\n @include media.on-mobile {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n }\n}\n\n@mixin contrast-on-mobile {\n @extend %contrast-on-mobile;\n}\n\n%base {\n @each $name, $value in $base-colours {\n --#{$name}: var(--base-#{$value});\n }\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n}\n\n@mixin base {\n @extend %base;\n}\n\n%tint {\n --background: var(--background-tint);\n\n @include colour-background(\"background\");\n}\n\n@mixin tint {\n @extend %tint;\n}\n\n%accent {\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n --accent-border: var(--accent-font-dark);\n --button-text: var(--accent-button-text);\n --button-background: var(--accent-button-background);\n --button-hover-text: var(--accent-button-hover-text);\n --button-hover-background: var(--accent-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\");\n}\n\n@mixin accent {\n @extend %accent;\n}\n\n%accent-light {\n --background: var(--accent-background-light);\n --font-base: #{map.get(colour.$colour-palette-default, \"font-base\")};\n --font-dark: #{map.get(colour.$colour-palette-default, \"font-dark\")};\n --font-light: #{map.get(colour.$colour-palette-default, \"font-light\")};\n --icon-light: #{map.get(colour.$colour-palette-default, \"icon-light\")};\n --keyline: #{map.get(colour.$colour-palette-default, \"keyline\")};\n --keyline-dark: #{map.get(colour.$colour-palette-default, \"keyline-dark\")};\n --button-text: #{map.get(colour.$colour-palette-default, \"button-text\")};\n --button-background: #{map.get(\n colour.$colour-palette-default,\n \"button-background\"\n )};\n --button-hover-text: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-text\"\n )};\n --button-hover-background: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-background\"\n )};\n --accent-border: var(--accent-background);\n\n @include colour-background(\"background\");\n @include colour-font(\"font-base\");\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n // --link: #{map.get(colour.$colour-palette-default, \"link\")};\n // --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n --accent-border: var(--accent-font-dark);\n --button-text: var(--accent-button-text);\n --button-background: var(--accent-button-background);\n --button-hover-text: var(--accent-button-hover-text);\n --button-hover-background: var(--accent-button-hover-background);\n }\n }\n\n .tna-template--dark-theme & {\n // --link: #{map.get(colour.$colour-palette-default, \"link\")};\n // --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n --accent-border: var(--accent-font-dark);\n --button-text: var(--accent-button-text);\n --button-background: var(--accent-button-background);\n --button-hover-text: var(--accent-button-hover-text);\n --button-hover-background: var(--accent-button-hover-background);\n }\n}\n\n@mixin accent-light {\n @extend %accent-light;\n}\n\n%yellow-accent {\n --accent-background: #{colour.brand-colour(\"yellow\")} !important;\n --accent-background-light: #{colour.brand-colour(\"cream\")} !important;\n --accent-border: #{colour.brand-colour(\"yellow\")} !important;\n --accent-font-base: #{colour.brand-colour(\"black\")} !important;\n --accent-font-dark: #{colour.brand-colour(\"black\")} !important;\n --accent-font-light: #{colour.brand-colour(\"black\", 0.7)} !important;\n --accent-icon-light: #{colour.brand-colour(\"black\", 0.7)} !important;\n --accent-link: #{colour.brand-colour(\"black\")} !important;\n --accent-link-visited: #{colour.brand-colour(\"black\")} !important;\n --accent-keyline: #{colour.brand-colour(\"black\", 0.5)} !important;\n --accent-keyline-dark: #{colour.brand-colour(\"black\", 0.8)} !important;\n --button-accented-text: #{colour.brand-colour(\"white\")} !important;\n --button-accented-background: #{colour.brand-colour(\"brown\")} !important;\n}\n\n@mixin yellow-accent {\n @extend %yellow-accent;\n}\n\n%accent-lighter-text {\n --accent-font-base: #{colour.brand-colour(\"white\")} !important;\n --accent-font-dark: #{colour.brand-colour(\"white\")} !important;\n --accent-font-light: #{colour.brand-colour(\"white\", 0.7)} !important;\n --accent-icon-light: #{colour.brand-colour(\"white\", 0.7)} !important;\n --accent-link: #{colour.brand-colour(\"white\")} !important;\n --accent-link-visited: #{colour.brand-colour(\"white\")} !important;\n --accent-keyline: #{colour.brand-colour(\"white\", 0.5)} !important;\n --accent-keyline-dark: #{colour.brand-colour(\"white\", 0.8)} !important;\n --button-accented-text: #{colour.brand-colour(\"white\")} !important;\n}\n\n%black-accent {\n --accent-background: #{colour.brand-colour(\"black\")} !important;\n --accent-background-light: #{colour.brand-colour(\"light-grey\")} !important;\n --accent-border: #{colour.brand-colour(\"black\")} !important;\n --button-accented-text: #{colour.brand-colour(\"black\")} !important;\n --button-accented-background: #{colour.brand-colour(\"grey\")} !important;\n}\n\n@mixin black-accent {\n @extend %accent-lighter-text;\n @extend %black-accent;\n}\n\n%pink-accent {\n --accent-background: #{colour.brand-colour(\"maroon\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-pink\")} !important;\n --accent-border: #{colour.brand-colour(\"pink\")} !important;\n --button-accented-background: #{colour.brand-colour(\"maroon\")} !important;\n}\n\n@mixin pink-accent {\n @extend %accent-lighter-text;\n @extend %pink-accent;\n}\n\n%orange-accent {\n --accent-background: #{colour.brand-colour(\"chestnut\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-orange\")} !important;\n --accent-border: #{colour.brand-colour(\"orange\")} !important;\n --button-accented-background: #{colour.brand-colour(\"chestnut\")} !important;\n}\n\n@mixin orange-accent {\n @extend %accent-lighter-text;\n @extend %orange-accent;\n}\n\n%green-accent {\n --accent-background: #{colour.brand-colour(\"forest\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-green\")} !important;\n --accent-border: #{colour.brand-colour(\"green\")} !important;\n --button-accented-background: #{colour.brand-colour(\"forest\")} !important;\n}\n\n@mixin green-accent {\n @extend %accent-lighter-text;\n @extend %green-accent;\n}\n\n%blue-accent {\n --accent-background: #{colour.brand-colour(\"navy\")} !important;\n --accent-background-light: #{colour.brand-colour(\"pastel-blue\")} !important;\n --accent-border: #{colour.brand-colour(\"blue\")} !important;\n --button-accented-background: #{colour.brand-colour(\"navy\")} !important;\n}\n\n@mixin blue-accent {\n @extend %accent-lighter-text;\n @extend %blue-accent;\n}\n\n@mixin on-high-contrast {\n @media (prefers-contrast: more) {\n @content;\n }\n}\n\n@mixin on-forced-colours {\n @media (forced-colors: active) {\n @content;\n }\n}\n\n@mixin on-high-contrast-and-forced-colours {\n @include on-forced-colours {\n @content;\n }\n\n @include on-high-contrast {\n @content;\n }\n}\n\n%image-loader-background {\n background: linear-gradient(\n -45deg,\n rgb(0 0 0 / 25%),\n rgb(255 255 255 / 25%),\n rgb(0 0 0 / 25%)\n );\n background-size: 500% 500%;\n background-position: 0 50%;\n\n animation: image-loader-background ease-in-out 1.2s infinite;\n\n @media (prefers-reduced-motion) {\n animation: none !important;\n }\n}\n\n@mixin image-loader-background {\n @if features.$image-loader-animations {\n @extend %image-loader-background;\n }\n}\n","@use \"sass:math\";\n@use \"../variables/media\";\n@use \"../variables/typography\";\n\n$smallest-large-device-em: #{math.div(\n media.$largest-medium-device-px + 1,\n typography.$relative-1rem-px\n )}em;\n$largest-medium-device-em: #{math.div(\n media.$largest-medium-device-px,\n typography.$relative-1rem-px\n )}em;\n$smallest-medium-device-em: #{math.div(\n media.$largest-small-device-px + 1,\n typography.$relative-1rem-px\n )}em;\n$largest-small-device-em: #{math.div(\n media.$largest-small-device-px,\n typography.$relative-1rem-px\n )}em;\n$smallest-small-device-em: #{math.div(\n media.$largest-tiny-device-px + 1,\n typography.$relative-1rem-px\n )}em;\n$largest-tiny-device-em: #{math.div(\n media.$largest-tiny-device-px,\n typography.$relative-1rem-px\n )}em;\n\n$media-large: \"(min-width: #{$smallest-large-device-em})\";\n$media-lt-large: \"(max-width: #{$largest-medium-device-em})\";\n$media-medium: \"(min-width: #{$smallest-medium-device-em}) and (max-width: #{$largest-medium-device-em})\";\n$media-gt-mobile: \"(min-width: #{$smallest-medium-device-em})\";\n$media-mobile: \"(max-width: #{$largest-small-device-em})\";\n$media-small: \"(min-width: #{$smallest-small-device-em}) and (max-width: #{$largest-small-device-em})\";\n$media-gt-tiny: \"(min-width: #{$smallest-small-device-em})\";\n$media-tiny: \"(max-width: #{$largest-tiny-device-em})\";\n\n// https://nationalarchives.github.io/design-system/styles/media/#media-queries\n@mixin on-large() {\n @media #{$media-large} {\n @content;\n }\n}\n\n@mixin on-medium() {\n @media #{$media-medium} {\n @content;\n }\n}\n\n@mixin on-small() {\n @media #{$media-small} {\n @content;\n }\n}\n\n@mixin on-tiny() {\n @media #{$media-tiny} {\n @content;\n }\n}\n\n@mixin on-larger-than-mobile() {\n @media #{$media-gt-mobile} {\n @content;\n }\n}\n\n@mixin on-larger-than-tiny() {\n @media #{$media-gt-tiny} {\n @content;\n }\n}\n\n@mixin on-smaller-than-large() {\n @media #{$media-lt-large} {\n @content;\n }\n}\n\n@mixin on-mobile() {\n @media #{$media-mobile} {\n @content;\n }\n}\n\n@mixin on-print() {\n @media print {\n @content;\n }\n}\n","@use \"../variables/a11y\";\n@use \"colour\";\n@use \"borders\";\n\n@mixin visually-hidden {\n width: 1px !important;\n height: 1px !important;\n margin: 0 !important;\n padding: 0 !important;\n\n overflow: hidden !important;\n\n position: absolute !important;\n top: -9999px !important;\n left: -9999px !important;\n z-index: -1 !important;\n\n background-color: transparent !important;\n\n border: 0 !important;\n\n -webkit-clip-path: inset(50%) !important;\n clip-path: inset(50%) !important;\n}\n\n%focus-outline {\n outline: a11y.$focus-outline-outer-width #000 solid !important;\n outline-offset: a11y.$focus-outline-inner-width !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-inner-width\n colour.brand-colour(\"yellow\") !important;\n\n transition:\n outline-offset 0.1s,\n box-shadow 0.1s;\n\n .tna-template--dark-theme & {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-inner-width #000 !important;\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-inner-width #000 !important;\n }\n }\n}\n\n@mixin focus-outline {\n @extend %focus-outline;\n}\n\n@mixin no-focus-outline {\n outline: none !important;\n\n box-shadow: none !important;\n}\n\n%active-outline {\n outline: a11y.$focus-outline-active-outer-width #000 solid !important;\n outline-offset: a11y.$focus-outline-active-inner-width !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-active-inner-width\n colour.brand-colour(\"yellow\") !important;\n\n transition: none;\n\n .tna-template--dark-theme & {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-active-inner-width #000 !important;\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n outline-color: colour.brand-colour(\"yellow\") !important;\n\n box-shadow: 0 0 0 a11y.$focus-outline-active-inner-width #000 !important;\n }\n }\n}\n\n@mixin active-outline {\n @extend %active-outline;\n}\n\n%faux-full-outline {\n position: relative;\n}\n\n%faux-full-outline-anchor {\n &::before {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: 9;\n\n @include borders.rounded-border;\n }\n\n &:focus,\n &:active {\n @include no-focus-outline;\n }\n\n &:focus {\n &::before {\n @include focus-outline;\n }\n }\n\n &:active {\n &::before {\n @include active-outline;\n }\n }\n}\n\n@mixin faux-full-outline($anchor_selector) {\n @extend %faux-full-outline;\n\n #{$anchor_selector} {\n @extend %faux-full-outline-anchor;\n }\n}\n","@use \"../variables/borders\";\n\n@mixin rounded-border {\n border-radius: borders.$rounded-border-radius;\n}\n","$thick-border-width: 5px !default;\n$very-thick-border-width: 8px !default;\n$rounded-border-radius: 2px !default;\n","@use \"sass:map\";\n@use \"sass:math\";\n@use \"../variables/spacing\";\n@use \"../variables/typography\";\n@use \"../tools/media\";\n\n/*\n * ------------------------------------------\n * Spacing is created with rem rather than px\n * units as when users use a custom font size\n * some browsers handle the resize of rem and\n * em separately from px which causes spacing\n * and layout issues, so to ensure everything\n * remaians consistent we use rem for spacing\n * and typography. The original intention was\n * separation so that we could scale the type\n * without affecting spacing, but in practice\n * there are too many ways to change the font\n * size in various browsers and devices\n * ------------------------------------------\n */\n@function space($size) {\n // @return #{$size * spacing.$spacing-unit-px}px;\n @return #{$size}rem;\n}\n\n%space-above {\n margin-top: space(2);\n @extend %no-space-above-for-first-children;\n}\n\n%space-only-above {\n margin: #{space(2)} 0 0;\n @extend %no-space-above-for-first-children;\n}\n\n%no-space-above-for-first-children {\n &:first-child {\n margin-top: 0;\n }\n}\n\n@mixin space-above($zero-other-margins: false) {\n @if $zero-other-margins {\n @extend %space-only-above;\n } @else {\n @extend %space-above;\n }\n}\n\n@mixin no-spacing-generator($suffix: \"\") {\n @if $suffix != \"\" {\n $suffix: \"-\" + $suffix;\n }\n @each $property in margin, padding {\n @each $direction in top, bottom {\n $combined-direction: \"\";\n @if $direction == top or $direction == bottom {\n $combined-direction: vertical;\n } @else if $direction == right or $direction == left {\n $combined-direction: horizontal;\n }\n @if $combined-direction {\n .tna-\\!--no-#{$property}-#{$direction}#{$suffix},\n .tna-\\!--no-#{$property}-#{$combined-direction}#{$suffix} {\n #{$property}-#{$direction}: 0 !important;\n }\n } @else {\n .tna-\\!--no-#{$property}-#{$direction}#{$suffix} {\n #{$property}-#{$direction}: 0 !important;\n }\n }\n }\n }\n}\n\n@mixin spacing-generator($suffix: \"\") {\n @each $property in margin, padding {\n @each $direction in top, bottom {\n @each $size, $amount in spacing.$spacing {\n @if $direction == all {\n .tna-\\!--#{$property}-#{$size} {\n #{$property}: #{space($amount)} !important;\n }\n } @else {\n $combined-direction: \"\";\n @if $direction == top or $direction == bottom {\n $combined-direction: vertical;\n } @else if $direction == right or $direction == left {\n $combined-direction: horizontal;\n }\n @if $combined-direction {\n .tna-\\!--#{$property}-#{$direction}-#{$size},\n .tna-\\!--#{$property}-#{$combined-direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n } @else {\n .tna-\\!--#{$property}-#{$direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n }\n }\n }\n }\n }\n\n @include media.on-mobile {\n @each $property in margin, padding {\n @each $direction in top, bottom {\n @each $size, $amount in spacing.$spacing-mobile {\n @if $direction == all {\n .tna-\\!--#{$property}-#{$size} {\n #{$property}: #{space($amount)} !important;\n }\n } @else {\n $combined-direction: \"\";\n @if $direction == top or $direction == bottom {\n $combined-direction: vertical;\n } @else if $direction == right or $direction == left {\n $combined-direction: horizontal;\n }\n @if $combined-direction {\n .tna-\\!--#{$property}-#{$direction}-#{$size},\n .tna-\\!--#{$property}-#{$combined-direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n } @else {\n .tna-\\!--#{$property}-#{$direction}-#{$size} {\n #{$property}-#{$direction}: #{space($amount)} !important;\n }\n }\n }\n }\n }\n }\n }\n}\n","@use \"../../tools/a11y\";\n\n.tna-visually-hidden,\n.tna-\\!--visually-hidden {\n @include a11y.visually-hidden;\n}\n\n*:focus,\n*:focus-visible,\n*:active {\n z-index: 9;\n}\n\n*:focus-visible {\n @include a11y.focus-outline;\n}\n\n@supports not selector(:focus-visible) {\n *:focus {\n z-index: 9;\n\n @include a11y.focus-outline;\n }\n}\n\na,\nbutton,\ninput,\ntextarea,\nselect,\nsummary {\n &:active {\n @include a11y.active-outline;\n }\n}\n\n[tabindex=\"-1\"] *:focus-visible,\n[tabindex=\"-1\"] *:focus,\n.tna-\\!--no-focus-style:focus-visible,\n.tna-\\!--no-focus-style:focus {\n @include a11y.no-focus-outline;\n}\n","@keyframes image-loader-background {\n 0%,\n 100% {\n background-position: 0 50%;\n }\n\n 50% {\n background-position: 100% 50%;\n }\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n\n.tna-section {\n padding-top: spacing.space(3);\n padding-bottom: spacing.space(3);\n}\n\n.tna-aside {\n @include spacing.space-above;\n padding: spacing.space(2);\n\n @include borders.rounded-border;\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n\n &--tight {\n padding: spacing.space(1);\n }\n}\n\n@include media.on-mobile {\n .tna-section {\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n }\n\n .tna-aside {\n padding: spacing.space(1);\n }\n}\n","@use \"../../tools/colour\";\n\n.tna-template {\n @include colour.always-light;\n\n @include colour.colour-background(\"background\");\n\n &--system-theme {\n @media (prefers-color-scheme: dark) {\n @include colour.colour-css-vars-dark;\n }\n\n @media (prefers-contrast: more) and (prefers-color-scheme: dark) {\n @include colour.colour-css-vars-high-contrast-dark;\n }\n }\n\n &--dark-theme {\n @include colour.colour-css-vars-dark;\n\n @media (prefers-contrast: more) {\n @include colour.colour-css-vars-high-contrast-dark;\n }\n }\n\n &--black-accent {\n @include colour.black-accent;\n }\n\n &--pink-accent {\n @include colour.pink-accent;\n }\n\n &--orange-accent {\n @include colour.orange-accent;\n }\n\n &--yellow-accent {\n @include colour.yellow-accent;\n }\n\n &--green-accent {\n @include colour.green-accent;\n }\n\n &--blue-accent {\n @include colour.blue-accent;\n }\n}\n\n.tna-background,\n.tna-block {\n &-tint {\n @include colour.tint;\n }\n\n &-contrast {\n @include colour.contrast;\n }\n\n &-accent {\n @include colour.accent;\n }\n\n &-accent-light {\n @include colour.accent-light;\n }\n\n &-base {\n @include colour.base;\n }\n}\n\n.tna-border {\n &-keyline {\n @include colour.colour-border(\"keyline\", 1px);\n }\n\n &-keyline-dark {\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n}\n\n.tna-accent {\n &-black {\n @include colour.black-accent;\n }\n\n &-pink {\n @include colour.pink-accent;\n }\n\n &-orange {\n @include colour.orange-accent;\n }\n\n &-yellow {\n @include colour.yellow-accent;\n }\n\n &-green {\n @include colour.green-accent;\n }\n\n &-blue {\n @include colour.blue-accent;\n }\n}\n","@use \"../../tools/media\";\n@use \"../../tools/grid\";\n\n.tna-columns {\n column-gap: grid.gutter-width();\n\n &--2 {\n column-count: 2;\n }\n\n &--3 {\n column-count: 3;\n }\n\n @include media.on-tiny {\n column-gap: grid.gutter-width-tiny();\n }\n\n @include media.on-small {\n @for $i from 1 through 4 {\n &--#{$i}-small {\n column-count: $i;\n }\n }\n }\n\n @include media.on-tiny {\n @for $i from 1 through 4 {\n &--#{$i}-tiny {\n column-count: $i;\n }\n }\n }\n\n &__block {\n break-inside: avoid;\n }\n\n &:has(&__block:only-of-type) {\n column-count: 1;\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-form-item {\n @include spacing.space-above;\n\n &__header {\n }\n\n &__label {\n display: block;\n }\n\n &__hint {\n margin-top: spacing.space(0.125);\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n }\n\n &__error {\n margin-top: spacing.space(0.25);\n\n @include colour.colour-font(\"form-error-text\");\n @include typography.main-font-weight-bold;\n }\n\n &__body {\n margin-top: spacing.space(0.5);\n\n &:first-child {\n margin-top: 0;\n }\n }\n\n &--error {\n padding-left: spacing.space(1);\n\n @include colour.thick-keyline-error(left);\n }\n}\n","@use \"sass:math\";\n@use \"../variables/typography\";\n@use \"colour\";\n@use \"media\";\n\n@mixin font-size($font-size-px) {\n font-size: #{math.div($font-size-px, typography.$relative-1rem-px)}rem;\n}\n\n@mixin relative-font-size($font-size-px) {\n @warn \"relative-font-size() will soon be deprecated in favour of font-size().\";\n @include font-size($font-size-px);\n}\n\n@mixin main-font-weight {\n font-weight: typography.$main-font-weight;\n}\n\n@mixin main-font-weight-medium {\n font-weight: typography.$main-font-weight-medium;\n}\n\n@mixin main-font-weight-bold {\n font-weight: typography.$main-font-weight-bold;\n}\n\n@mixin main-font($bold: false) {\n font-family: typography.$main-font-family;\n font-style: normal;\n font-optical-sizing: auto;\n font-variation-settings: \"wdth\" 100;\n @if $bold {\n @include main-font-weight-bold;\n } @else {\n @include main-font-weight;\n }\n}\n\n@mixin heading-font {\n font-family: typography.$heading-font-family;\n font-weight: typography.$heading-font-weight;\n}\n\n@mixin detail-font($bold: false) {\n font-family: typography.$detail-font-family;\n font-style: normal;\n font-optical-sizing: auto;\n @if $bold {\n font-weight: typography.$detail-font-weight-bold;\n } @else {\n font-weight: typography.$detail-font-weight;\n }\n}\n\n@mixin detail-font-small {\n @include detail-font;\n @include font-size(14);\n line-height: 1.1;\n text-transform: uppercase;\n}\n\n@mixin interactable-text-decoration {\n text-decoration-thickness: typography.$interactable-text-decoration-thickness;\n text-underline-offset: typography.$interactable-text-decoration-offset;\n}\n\n@mixin interacted-text-decoration {\n text-decoration: underline;\n text-decoration-thickness: typography.$interactive-text-decoration-thickness;\n text-underline-offset: typography.$interactable-text-decoration-offset;\n}\n\n@mixin heading-generator(\n $font-size-default,\n $font-size-medium,\n $font-size-small,\n $font-size-tiny,\n $line-height\n) {\n $small-and-tiny-identical: $font-size-small == $font-size-tiny;\n $medium-small-and-tiny-identical: $font-size-medium == $font-size-small and\n $small-and-tiny-identical;\n $all-identical: $font-size-default == $font-size-medium and\n $medium-small-and-tiny-identical and $small-and-tiny-identical;\n line-height: $line-height;\n @include font-size($font-size-default);\n\n @if $all-identical != true {\n @if $medium-small-and-tiny-identical != true {\n @include media.on-medium {\n @include font-size($font-size-medium);\n }\n\n @if $small-and-tiny-identical != true {\n @include media.on-small {\n @include font-size($font-size-small);\n }\n\n @include media.on-tiny {\n @include font-size($font-size-tiny);\n }\n } @else {\n @include media.on-mobile {\n @include font-size($font-size-small);\n }\n }\n } @else {\n @include media.on-smaller-than-large {\n @include font-size($font-size-medium);\n }\n }\n }\n}\n","@use \"sass:math\";\n\n/*\n * ------------------------------------------\n * The typefaces, sizes and spacings that are\n * defined in this file have been selected to\n * ensure 100% match with the latest National\n * Archives brand guidelines - avoid changing\n * or overwriting any of these values without\n * signing off with the Digital Services team\n * first\n * ------------------------------------------\n */\n\n$relative-1rem-px: 16; // 16px = 1rem\n\n/*\n * ------------------------------------------\n * When true, use the included font files for\n * Open Sans and Roboto Mono, rather than the\n * versions hosted by Google Fonts\n * ------------------------------------------\n */\n$use-local-fonts: false !default;\n\n$body-font-size-px: 19 !default;\n$body-font-size-px-medium: 18 !default;\n$body-font-size-px-mobile: 17 !default;\n$body-line-height: 1.75 !default;\n\n$interactable-text-decoration-offset: 0.125em !default;\n$interactable-text-decoration-thickness: #{math.div(1.5, $relative-1rem-px)}rem !default;\n$interactive-text-decoration-thickness: #{math.div(4, $relative-1rem-px)}rem !default;\n\n$main-font-family-name: \"Open Sans\" !default;\n$main-font-family:\n #{$main-font-family-name},\n sans-serif;\n$main-font-weight: 400 !default;\n$main-font-weight-medium: 600 !default;\n$main-font-weight-bold: 700 !default;\n$main-font-file: \"OpenSans-Regular.ttf\" !default;\n$main-font-file-medium: \"OpenSans-SemiBold.ttf\" !default;\n$main-font-file-bold: \"OpenSans-Bold.ttf\" !default;\n\n/*\n * ------------------------------------------\n * To use Supria Sans Condensed (which is the\n * approved heading typeface for The National\n * Archives), you need to obtain a licence to\n * properly embed the CSS files with the font\n * definitions in your service - check with a\n * member of the Digital Services team on how\n * to get a licence\n * ------------------------------------------\n */\n$heading-font-family-name: \"supria-sans-condensed\" !default;\n$heading-font-family:\n #{$heading-font-family-name},\n \"Arial Narrow\",\n sans-serif;\n$heading-font-weight: 500 !default;\n\n/*\n * ------------------------------------------\n * The detail font should be a monospace font\n * and is used for chips, supertitles as well\n * as the date search component\n * ------------------------------------------\n */\n$detail-font-family-name: \"Roboto Mono\" !default;\n$detail-font-family:\n #{$detail-font-family-name},\n monospace;\n$detail-font-weight: 400 !default;\n$detail-font-weight-bold: 500 !default;\n$detail-font-file: \"RobotoMono-Regular.ttf\" !default;\n$detail-font-file-bold: \"RobotoMono-Medium.ttf\" !default;\n\n$heading-xl-font-size-default: 64 !default;\n$heading-xl-font-size-medium: 48 !default;\n$heading-xl-font-size-small: 36 !default;\n$heading-xl-font-size-tiny: $heading-xl-font-size-small !default;\n$heading-xl-line-height: 1.1 !default;\n\n$heading-l-font-size-default: 36 !default;\n$heading-l-font-size-medium: 32 !default;\n$heading-l-font-size-small: 29 !default;\n$heading-l-font-size-tiny: $heading-l-font-size-small !default;\n$heading-l-line-height: 1.15 !default;\n\n$heading-m-font-size-default: 22 !default;\n$heading-m-font-size-medium: $heading-m-font-size-default !default;\n$heading-m-font-size-small: 21 !default;\n$heading-m-font-size-tiny: $heading-m-font-size-small !default;\n$heading-m-line-height: 1.4 !default;\n\n$heading-s-font-size-default: 19 !default;\n$heading-s-font-size-medium: $heading-s-font-size-default !default;\n$heading-s-font-size-small: $heading-s-font-size-default !default;\n$heading-s-font-size-tiny: $heading-s-font-size-default !default;\n$heading-s-line-height: 1.5 !default;\n",".tna-template {\n /*\n * ------------------------------------------\n * A minimum page width of 320px is needed in\n * order to meet the WCAG AA success criteria\n * for 1.4.10 (Reflow)\n * https://www.w3.org/WAI/WCAG21/Understanding/reflow.html\n * ------------------------------------------\n */\n min-width: 320px;\n width: 100%;\n height: 100%;\n\n /*\n * ------------------------------------------\n * Support ended with iOS 13 released on 19th\n * September 2019. Deprecate in the future if\n * iOS <13 share drops low enough.\n * https://caniuse.com/mdn-css_properties_-webkit-overflow-scrolling\n * ------------------------------------------\n */\n -webkit-overflow-scrolling: touch;\n}\n\n.tna-template__body {\n min-height: 100%;\n margin: 0;\n padding: 0;\n\n &:has(:is(.tna-global-header, .tna-header)):has(.tna-main):has(.tna-footer) {\n display: flex;\n flex-direction: column;\n }\n}\n\n.tna-main {\n flex: 1;\n}\n","@use \"sass:math\";\n@use \"sass:selector\";\n@use \"../../variables/grid\" as gridVars;\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n\n.tna-container {\n width: 100%;\n max-width: gridVars.$largest-container-width;\n margin-right: auto;\n margin-left: auto;\n padding-right: grid.gutter-width-half();\n padding-left: grid.gutter-width-half();\n\n display: flex;\n flex-wrap: wrap;\n align-items: stretch;\n justify-content: flex-start;\n\n box-sizing: border-box;\n\n & &--no-padding {\n max-width: calc(\n #{gridVars.$largest-container-width} - #{grid.gutter-width-double()}\n );\n padding-right: 0;\n padding-left: 0;\n }\n\n &--max {\n max-width: none;\n }\n\n &--centred,\n &--align-centre {\n justify-content: center;\n }\n\n &--align-right {\n justify-content: flex-end;\n }\n\n & &--nested {\n width: auto;\n margin-right: -#{grid.gutter-width()};\n margin-left: -#{grid.gutter-width()};\n }\n\n @at-root #{selector.unify(\"ul, ol\", &)} {\n list-style: none;\n }\n}\n\n.tna-column {\n padding-right: grid.gutter-width-half();\n padding-left: grid.gutter-width-half();\n\n box-sizing: border-box;\n\n & &--no-padding {\n padding-right: 0;\n padding-left: 0;\n }\n\n &--align-top {\n align-self: flex-start;\n }\n\n &--align-centre {\n align-self: center;\n }\n\n &--align-bottom {\n align-self: flex-end;\n }\n}\n\n@include grid.columns-generator(gridVars.$column-count);\n\n@include media.on-medium {\n @include grid.columns-generator(gridVars.$column-count-medium, \"medium\");\n}\n\n@include media.on-small {\n @include grid.columns-generator(gridVars.$column-count-small, \"small\");\n}\n\n@include media.on-tiny {\n .tna-container {\n padding-right: grid.gutter-width-tiny-half();\n padding-left: grid.gutter-width-tiny-half();\n\n & &--nested {\n width: auto;\n margin-right: -#{grid.gutter-width-tiny()};\n margin-left: -#{grid.gutter-width-tiny()};\n }\n }\n\n .tna-column {\n padding-right: grid.gutter-width-tiny-half();\n padding-left: grid.gutter-width-tiny-half();\n }\n\n @include grid.columns-generator(gridVars.$column-count-tiny, \"tiny\");\n}\n","$largest-container-width: 1280px !default;\n\n$gutter-width: 2 !default;\n$gutter-width-tiny: 1 !default;\n\n$column-count: 12;\n$column-count-medium: 6;\n$column-count-small: 4;\n$column-count-tiny: 2;\n","@use \"sass:math\";\n@use \"../variables/grid\";\n@use \"spacing\";\n\n@function gutter-width() {\n @return spacing.space(grid.$gutter-width);\n}\n\n@function gutter-width-half() {\n @return spacing.space(math.div(grid.$gutter-width, 2));\n}\n\n@function gutter-width-double() {\n @return spacing.space(grid.$gutter-width * 2);\n}\n\n@function gutter-width-tiny() {\n @return spacing.space(grid.$gutter-width-tiny);\n}\n\n@function gutter-width-tiny-half() {\n @return spacing.space(math.div(grid.$gutter-width-tiny, 2));\n}\n\n@function gutter-width-tiny-double() {\n @return spacing.space(grid.$gutter-width-tiny * 2);\n}\n\n@mixin columns-generator($count, $suffix: \"\") {\n @if $suffix != \"\" {\n $suffix: \"-\" + $suffix;\n }\n\n .tna-column {\n &--full#{$suffix} {\n width: 100%;\n flex: none;\n }\n\n @for $i from 1 through $count - 1 {\n $simplest-fraction-found: false;\n\n @for $j from math.div($count, 2) through 1 {\n @if (\n $count % $j == 0 and $i % $j == 0 and $simplest-fraction-found != true\n ) {\n &--width-#{math.div($i, $j)}-#{math.div($count, $j)}#{$suffix} {\n width: math.div(100%, $count) * $i;\n flex: none;\n }\n\n &--margin-right-#{math.div($i, $j)}-#{math.div($count, $j)}#{$suffix} {\n margin-right: math.div(100%, $count) * $i;\n }\n\n &--margin-left-#{math.div($i, $j)}-#{math.div($count, $j)}#{$suffix} {\n margin-left: math.div(100%, $count) * $i;\n }\n\n $simplest-fraction-found: true;\n }\n }\n\n @if $simplest-fraction-found != true {\n &--width-#{$i}-#{$count}#{$suffix} {\n width: math.div(100%, $count) * $i;\n flex: none;\n }\n\n &--margin-right-#{$i}-#{$count}#{$suffix} {\n margin-right: math.div(100%, $count) * $i;\n }\n\n &--margin-left-#{$i}-#{$count}#{$suffix} {\n margin-left: math.div(100%, $count) * $i;\n }\n }\n }\n\n @if $suffix != \"\" {\n &--no-margin-right#{$suffix} {\n margin-right: 0;\n }\n\n &--no-margin-left#{$suffix} {\n margin-left: 0;\n }\n }\n\n @for $i from 1 through 3 {\n &--flex-#{$i}#{$suffix} {\n width: auto;\n\n flex: $i 0;\n }\n }\n\n @for $i from 1 through 4 {\n &--order-#{$i}#{$suffix} {\n order: $i;\n }\n }\n }\n}\n","@use \"sass:math\";\n@use \"sass:selector\";\n@use \"../../variables/typography\" as typographyVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-template {\n @include colour.colour-font(\"font-base\");\n @include typography.main-font;\n direction: ltr;\n text-rendering: optimizeLegibility;\n -webkit-text-size-adjust: none;\n text-size-adjust: none;\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n\n @include colour.on-high-contrast {\n @include typography.main-font-weight-medium;\n }\n}\n\n.tna-template__body {\n color: inherit;\n @include typography.font-size(typographyVars.$body-font-size-px);\n line-height: typographyVars.$body-line-height;\n\n @include media.on-medium {\n @include typography.font-size(typographyVars.$body-font-size-px-medium);\n }\n\n @include media.on-mobile {\n @include typography.font-size(typographyVars.$body-font-size-px-mobile);\n }\n}\n\nstrong {\n @include typography.main-font-weight-bold;\n}\n\np {\n @include spacing.space-above;\n\n + p {\n margin-top: spacing.space(1);\n }\n}\n\na {\n @include typography.interactable-text-decoration;\n\n border-radius: 0.1px;\n\n &,\n &:link {\n @include colour.colour-font(\"link\");\n }\n\n &:visited {\n @include colour.colour-font(\"link-visited\");\n }\n\n &:hover,\n &:active {\n @include typography.interacted-text-decoration;\n }\n\n &.tna-link--no-visited-state {\n &:visited {\n @include colour.colour-font(\"link\");\n }\n }\n}\n\nsmall {\n @include typography.font-size(typographyVars.$body-font-size-px * 0.85);\n}\n\n%chip {\n max-width: max-content;\n padding: spacing.space(0.125) spacing.space(0.25);\n\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n @include colour.colour-font(\"font-base\");\n @include typography.detail-font-small;\n line-height: 1;\n text-align: center;\n text-wrap-style: balance;\n\n @include borders.rounded-border;\n\n @at-root #{selector.unify(\"a\", &)} {\n text-decoration: underline;\n\n &:hover {\n text-decoration: underline;\n text-decoration-thickness: 0.1875em;\n text-underline-offset: 0.0625em;\n\n .fa-solid {\n color: inherit;\n }\n }\n }\n\n .fa-solid {\n @include colour.colour-font(\"icon-light\");\n\n @include colour.on-high-contrast {\n @include colour.colour-font(\"icon\");\n }\n }\n}\n\n%chip-plain {\n padding: 0;\n\n text-align: left;\n\n background-color: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n @at-root #{selector.unify(\"a\", &)} {\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n .fa-solid {\n color: inherit;\n }\n }\n}\n\n%chip-accent {\n @include colour.accent;\n\n @include colour.colour-border(\"accent-background\", 2px);\n\n -webkit-print-color-adjust: exact;\n print-color-adjust: exact;\n\n .tna-background-accent &,\n .tna-template--dark-theme .tna-background-accent-light & {\n @include colour.colour-font(\"contrast-font-base\");\n\n @include colour.colour-background(\"contrast-background\");\n\n @include colour.colour-border(\"contrast-background\");\n\n .fa-solid {\n @include colour.colour-font(\"contrast-icon-light\");\n }\n }\n\n .tna-template--system-theme .tna-background-accent-light & {\n @media (prefers-color-scheme: dark) {\n @include colour.colour-font(\"contrast-font-base\");\n\n @include colour.colour-background(\"contrast-background\");\n\n @include colour.colour-border(\"contrast-background\");\n\n .fa-solid {\n @include colour.colour-font(\"contrast-icon-light\");\n }\n }\n }\n}\n\n.tna-chip {\n @extend %chip;\n\n &--plain {\n @extend %chip-plain;\n }\n\n &--black {\n @include colour.black-accent;\n }\n\n &--pink {\n @include colour.pink-accent;\n }\n\n &--orange {\n @include colour.orange-accent;\n }\n\n &--yellow {\n @include colour.yellow-accent;\n }\n\n &--green {\n @include colour.green-accent;\n }\n\n &--blue {\n @include colour.blue-accent;\n }\n\n &:not(&--plain) {\n @extend %chip-accent;\n }\n}\n\n.tna-chip-list {\n @include spacing.space-above;\n\n display: flex;\n flex-wrap: wrap;\n gap: spacing.space(0.5) spacing.space(1.5);\n\n list-style: none;\n\n &__item {\n display: flex;\n align-items: center;\n }\n}\n\n%heading {\n @include colour.colour-font(\"font-dark\");\n text-wrap: pretty;\n\n a {\n display: inline-block;\n\n vertical-align: top;\n\n &::after {\n content: \"\";\n\n width: 0.3125em;\n height: 0.3125em;\n margin-bottom: 0.1em;\n margin-left: 0.375em;\n\n display: inline-block;\n\n vertical-align: middle;\n\n transform: rotate(45deg);\n\n @include colour.colour-border(\"link\", 0.125em, solid, top);\n @include colour.colour-border(\"link\", 0.125em, solid, right);\n }\n\n &:not(.tna-link--no-visited-state):visited {\n &::after {\n @include colour.colour-border(\"link-visited\");\n }\n }\n }\n\n strong {\n font-weight: inherit;\n }\n}\n\n%heading-xl {\n @extend %heading;\n\n @include typography.heading-font;\n @include typography.heading-generator(\n typographyVars.$heading-xl-font-size-default,\n typographyVars.$heading-xl-font-size-medium,\n typographyVars.$heading-xl-font-size-small,\n typographyVars.$heading-xl-font-size-tiny,\n typographyVars.$heading-xl-line-height\n );\n}\n\n%heading-l {\n @extend %heading;\n\n @include typography.heading-font;\n @include typography.heading-generator(\n typographyVars.$heading-l-font-size-default,\n typographyVars.$heading-l-font-size-medium,\n typographyVars.$heading-l-font-size-small,\n typographyVars.$heading-l-font-size-tiny,\n typographyVars.$heading-l-line-height\n );\n\n a {\n &::after {\n width: 0.275em;\n height: 0.275em;\n margin-bottom: 0;\n margin-left: 0.25em;\n\n border-top-width: 0.1em;\n border-right-width: 0.1em;\n }\n }\n}\n\n%heading-m {\n @extend %heading;\n\n @include typography.main-font-weight-bold;\n @include typography.heading-generator(\n typographyVars.$heading-m-font-size-default,\n typographyVars.$heading-m-font-size-medium,\n typographyVars.$heading-m-font-size-small,\n typographyVars.$heading-m-font-size-tiny,\n typographyVars.$heading-m-line-height\n );\n}\n\n%heading-s {\n @extend %heading;\n\n @include typography.main-font-weight-bold;\n @include typography.heading-generator(\n typographyVars.$heading-s-font-size-default,\n typographyVars.$heading-s-font-size-medium,\n typographyVars.$heading-s-font-size-small,\n typographyVars.$heading-s-font-size-tiny,\n typographyVars.$heading-s-line-height\n );\n}\n\n%heading-xs {\n @extend %heading;\n\n @include typography.main-font-weight;\n\n font-size: 1em;\n line-height: typographyVars.$heading-s-line-height;\n}\n\n%headings-and-heading-groups {\n @include spacing.space-above;\n margin-bottom: 0;\n padding: spacing.space(1) 0 0;\n\n &:first-child {\n padding-top: 0;\n }\n\n + p,\n + .tna-large-paragraph,\n + .tna-scene-setter {\n margin-top: spacing.space(1);\n }\n}\n\n.tna-heading {\n &-xl {\n @extend %heading-xl;\n @extend %headings-and-heading-groups;\n }\n\n &-l {\n @extend %heading-l;\n @extend %headings-and-heading-groups;\n }\n\n &-m {\n @extend %heading-m;\n @extend %headings-and-heading-groups;\n }\n\n &-s {\n @extend %heading-s;\n @extend %headings-and-heading-groups;\n }\n\n &-xs {\n @extend %heading-xs;\n @extend %headings-and-heading-groups;\n }\n\n &--no-link-arrow {\n a {\n &::after {\n display: none;\n }\n }\n }\n}\n\n.tna-hgroup {\n &-xl,\n &-l,\n &-m,\n &-s {\n @extend %headings-and-heading-groups;\n }\n\n &__supertitle {\n margin: 0 0 spacing.space(0.25);\n\n @extend %chip;\n\n &--plain {\n @extend %chip-plain;\n }\n\n &:not(&--plain) {\n @extend %chip-accent;\n }\n }\n\n &__title {\n margin: 0;\n\n display: block;\n }\n\n &-xl &__title {\n @extend %heading-xl;\n }\n\n &-l &__title {\n @extend %heading-l;\n }\n\n &-m &__title {\n @extend %heading-m;\n }\n\n &-s &__title {\n @extend %heading-s;\n }\n}\n\n.tna-blockquote {\n @include spacing.space-above;\n margin-right: 0;\n margin-bottom: 0;\n margin-left: 0;\n padding: spacing.space(1) spacing.space(1) spacing.space(1) spacing.space(2);\n\n @include colour.thick-keyline-accent(left);\n\n // &::before {\n // content: \"\\201C\";\n\n // display: block;\n\n // font-family: Georgia, \"Times New Roman\", Times, serif;\n // font-size: 3em;\n // line-height: 1;\n // @include colour.colour-font(\"font-light\");\n // }\n\n &__quote {\n @include typography.main-font-weight-medium;\n quotes: auto;\n quotes: \"‘\" \"’\";\n\n &:has(:is(ul, ol)) {\n quotes: none;\n }\n\n > :first-child::before {\n content: open-quote;\n }\n\n > :last-child::after {\n content: close-quote;\n }\n }\n\n &__citation {\n margin-top: spacing.space(1);\n\n @include typography.font-size(16);\n\n &::before {\n content: \"\\2014\" \" \";\n content: \"\\2014\" \" \" / \"\";\n }\n }\n\n @include media.on-tiny {\n padding: spacing.space(0.5) spacing.space(0.5) spacing.space(0.5)\n #{spacing.space(1)};\n }\n}\n\n.tna-large-paragraph {\n @include spacing.space-above;\n\n @include typography.font-size(22);\n @include colour.colour-font(\"font-dark\");\n\n @include media.on-mobile {\n @include typography.font-size(20);\n }\n\n &--bold {\n @include colour.colour-font(\"font-base\");\n @include typography.main-font-weight-medium;\n }\n}\n\n.tna-scene-setter {\n @include spacing.space-above;\n\n @include typography.detail-font;\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(22);\n line-height: 1.7;\n\n @include media.on-mobile {\n @include typography.font-size(20);\n }\n}\n\naddress {\n line-height: 1.375;\n font-style: inherit;\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n@use \"../../utilities/typography\" as typographyUtils;\n\nul {\n list-style-type: disc;\n\n & & {\n list-style-type: circle;\n }\n\n & & & {\n list-style-type: square;\n }\n\n & & & & {\n list-style-type: disc;\n }\n}\n\nol {\n list-style-type: decimal;\n\n & & {\n list-style-type: lower-alpha;\n }\n\n & & & {\n list-style-type: lower-roman;\n }\n\n & & & & {\n list-style-type: decimal;\n }\n}\n\n.tna-ul,\n.tna-ol {\n margin-top: spacing.space(1);\n padding-left: spacing.space(2.5);\n\n &:first-child {\n margin-top: 0;\n }\n\n &--plain {\n padding-left: 0;\n\n list-style: none !important;\n\n > li::marker {\n content: \"\";\n }\n }\n\n > li {\n &::marker {\n @include typography.main-font-weight-medium;\n }\n }\n\n &--dashed {\n > li::marker {\n content: \"— \";\n @include typography.main-font-weight;\n }\n }\n\n &--spaced > li + li {\n margin-top: spacing.space(0.5);\n }\n}\n\n.tna-ul:not(.tna-ul--plain) > li > .tna-ul,\n.tna-ol:not(.tna-ol--plain) > li > .tna-ol {\n margin-bottom: spacing.space(1);\n padding-left: spacing.space(1.25);\n}\n\n.tna-dl-chips {\n @include spacing.space-above(true);\n\n display: flex;\n flex-wrap: wrap;\n gap: spacing.space(0.75) spacing.space(1.5);\n\n @extend %chip-plain;\n\n > dt {\n position: absolute;\n\n font-size: 0;\n }\n\n &__item {\n @extend %chip;\n }\n\n a#{&}__item {\n cursor: pointer;\n }\n\n &:not(&--plain) {\n gap: spacing.space(0.5) spacing.space(1);\n }\n\n &--plain &__item {\n @extend %chip-plain;\n }\n\n &:not(&--plain) &__item {\n @extend %chip-accent;\n }\n\n &--plain a#{&}__item {\n @include colour.colour-font(\"link\");\n }\n\n &--stacked {\n flex-direction: column;\n }\n}\n\n@mixin stacked-dl {\n display: block;\n\n &--lined {\n padding-bottom: 0;\n\n > dd {\n border-top: none;\n\n padding-top: 0;\n padding-bottom: spacing.space(0.5);\n }\n }\n\n &--zebra {\n > dt {\n --background: var(--background-tint);\n\n @include colour.colour-background(\"background\");\n }\n\n > dd:nth-child(1n) {\n background: none;\n }\n }\n}\n\n.tna-dl {\n @include spacing.space-above;\n\n display: grid;\n grid-template-columns: auto;\n gap: spacing.space(0.5) 0;\n\n &--left-weighted {\n grid-template-columns: 2fr 1fr;\n }\n\n &--right-weighted {\n grid-template-columns: 1fr 2fr;\n }\n\n > dt,\n > dd {\n margin: 0;\n\n overflow-wrap: break-word;\n }\n\n > dt {\n @include typography.main-font-weight-bold;\n position: relative;\n\n .fa-solid,\n .fa-brands {\n display: block;\n\n position: absolute;\n top: 0;\n left: 0;\n\n line-height: inherit;\n @include colour.colour-font(\"icon-light\");\n }\n }\n\n &:has(> dt > .fa-solid, > dt > .fa-brands) {\n > dt {\n padding-left: spacing.space(2);\n }\n }\n\n > dd {\n padding-left: spacing.space(2);\n\n grid-column-start: 2;\n }\n\n &--lined {\n padding-bottom: spacing.space(0.5);\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n /* stylelint-disable-next-line no-descending-specificity */\n > dt,\n > dd {\n padding-top: spacing.space(0.5);\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n\n .fa-solid,\n .fa-brands {\n top: spacing.space(0.5);\n }\n }\n }\n\n &--zebra {\n gap: 0;\n\n /* stylelint-disable-next-line no-descending-specificity */\n > dt,\n > dd {\n padding: spacing.space(0.5) spacing.space(1) spacing.space(0.5)\n spacing.space(1);\n }\n\n > dt {\n .fa-solid,\n .fa-brands {\n top: spacing.space(0.5);\n left: spacing.space(1);\n }\n }\n\n > dt:first-child,\n > dd:nth-of-type(2n) + dt,\n > dd:nth-of-type(2n + 1) {\n @include colour.tint;\n }\n\n &:has(> dt > .fa-solid, > dt > .fa-brands) {\n > dt {\n padding-left: spacing.space(3);\n }\n }\n }\n\n &--stacked#{&} {\n @include stacked-dl;\n }\n\n @include media.on-mobile {\n @include stacked-dl;\n }\n}\n\nli,\ndd {\n p {\n margin-top: spacing.space(0.25);\n\n &:first-child {\n margin-top: 0;\n }\n }\n}\n",".tna-logo {\n width: 6rem;\n aspect-ratio: 1;\n\n display: block;\n\n svg {\n width: 100%;\n height: 100%;\n }\n\n &__background {\n fill: transparent;\n }\n\n &__foreground {\n fill: currentColor;\n }\n\n &--solid &__background {\n fill: #fff;\n }\n\n &--solid &__foreground {\n fill: #010101;\n }\n}\n","@use \"sass:map\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n\n@mixin hide-on($suffix) {\n .tna-\\!--hide-on-#{$suffix} {\n display: none !important;\n }\n}\n\n@include spacing.no-spacing-generator;\n@include spacing.spacing-generator;\n\n@include media.on-large {\n @include spacing.no-spacing-generator(\"large\");\n @include hide-on(\"large\");\n}\n\n@include media.on-medium {\n @include spacing.no-spacing-generator(\"medium\");\n @include hide-on(\"medium\");\n}\n\n@include media.on-small {\n @include spacing.no-spacing-generator(\"small\");\n @include hide-on(\"small\");\n}\n\n@include media.on-tiny {\n @include spacing.no-spacing-generator(\"tiny\");\n @include hide-on(\"tiny\");\n}\n\n.tna-\\!--hide-on-print {\n @media print {\n display: none;\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/typography\";\n\n* {\n margin: 0;\n padding: 0;\n\n @media (prefers-contrast: more) {\n background-image: none;\n }\n}\n\n/*\n * ------------------------------------------\n * Disable the \"Auto dark mode\" feature as we\n * have our own dark theme\n * ------------------------------------------\n */\n:root {\n color-scheme: only light;\n}\n\n/*\n * ------------------------------------------\n * If the browser supports -apple-system-body\n * which at the moment is just iOS then using\n * the system body font we can respond to the\n * Dynamic Type setting in iOS, however we do\n * disable it for any non-touch Apple devices\n * such as Mac OS, because the default system\n * font size is set to 13px rather than 16px\n * ------------------------------------------\n */\n@supports (font: -apple-system-body) and (-webkit-touch-callout: default) {\n html {\n /* stylelint-disable-next-line font-family-no-missing-generic-family-keyword */\n font: -apple-system-body;\n }\n}\n\nimg,\nsvg,\npicture,\nvideo,\ncanvas {\n max-width: 100%;\n height: auto;\n\n display: block;\n}\n\nbutton,\ninput,\nselect,\ntextarea {\n font-family: inherit;\n font-size: inherit;\n}\n\n[hidden] {\n display: none !important;\n}\n\nhr {\n @include colour.colour-border(\"keyline\", 0, solid);\n border-top-width: 1px;\n\n &.tna-hr-dark {\n @include colour.colour-border(\"keyline-dark\");\n }\n}\n","@use \"sass:math\";\n@use \"sass:selector\";\n@use \"../../variables/a11y\" as a11yVariables;\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n$table-overflow-shadow-width: 1.25rem;\n$table-overflow-shadow-colour: rgb(0 0 0 / 40%);\n$table-overflow-shadow-colour-hidden: rgb(0 0 0 / 0%);\n\n@property --overflow-shadow-start {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #{$table-overflow-shadow-colour-hidden};\n}\n\n@property --overflow-shadow-end {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #{$table-overflow-shadow-colour-hidden};\n}\n\n@keyframes overflow-shadows {\n 0% {\n --overflow-shadow-start: #{$table-overflow-shadow-colour-hidden};\n --overflow-shadow-end: #{$table-overflow-shadow-colour};\n }\n\n 5% {\n --overflow-shadow-start: #{$table-overflow-shadow-colour};\n }\n\n 95% {\n --overflow-shadow-end: #{$table-overflow-shadow-colour};\n }\n\n 100% {\n --overflow-shadow-start: #{$table-overflow-shadow-colour};\n --overflow-shadow-end: #{$table-overflow-shadow-colour-hidden};\n }\n}\n\n.tna-table {\n @include spacing.space-above;\n max-width: 100%;\n margin-bottom: spacing.space(4);\n\n position: relative;\n z-index: 1;\n\n text-align: left;\n\n border-collapse: collapse;\n\n &:last-child {\n margin-bottom: 0;\n }\n\n &__caption {\n width: 100%;\n padding: spacing.space(1) 0 0;\n\n caption-side: bottom;\n\n @include typography.font-size(16);\n }\n\n &__head {\n vertical-align: bottom;\n }\n\n &__body {\n vertical-align: top;\n }\n\n &__foot {\n @include typography.main-font-weight-bold;\n vertical-align: top;\n }\n\n &__row {\n }\n\n &__header {\n }\n\n &__cell {\n }\n\n &__header,\n &__cell {\n padding: spacing.space(0.25) spacing.space(1);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &:first-child {\n padding-left: 0;\n }\n\n &:last-child {\n padding-right: 0;\n }\n\n &--numeric {\n text-align: right;\n }\n\n &--align-left {\n text-align: left;\n }\n\n &--align-centre {\n text-align: center;\n }\n\n &--align-right {\n text-align: right;\n }\n\n &--align-justify {\n text-align: justify;\n }\n\n &--align-top {\n vertical-align: top;\n }\n\n &--align-middle {\n vertical-align: middle;\n }\n\n &--align-bottom {\n vertical-align: bottom;\n }\n }\n\n &__head &__header {\n @include colour.thick-keyline-dark(bottom);\n }\n\n &__foot &__header,\n &__foot &__cell {\n @include colour.thick-keyline-dark(top);\n }\n\n p {\n + p {\n margin-top: spacing.space(0.25);\n }\n }\n\n &--full {\n width: 100%;\n }\n}\n\n.tna-table-wrapper {\n @include spacing.space-above;\n margin-bottom: spacing.space(4);\n\n overflow: auto;\n\n background:\n linear-gradient(\n to right,\n colour.colour-var(\"background\") 50%,\n rgb(255 255 255 / 0%)\n ),\n linear-gradient(\n to right,\n rgb(255 255 255 / 0%),\n colour.colour-var(\"background\") 50%\n )\n 0 100%,\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at left center,\n #{$table-overflow-shadow-colour},\n #{$table-overflow-shadow-colour-hidden}\n ),\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at right center,\n #{$table-overflow-shadow-colour},\n #{$table-overflow-shadow-colour-hidden}\n )\n 0 100% transparent;\n background-size:\n #{$table-overflow-shadow-width * 2} 100%,\n #{$table-overflow-shadow-width * 2} 100%,\n 100% 100%,\n 100% 100%;\n background-repeat: no-repeat;\n background-position:\n 0 0,\n 100%,\n 0 0,\n 100%;\n background-attachment: local, local, scroll, scroll;\n\n border-radius: 0.1px;\n\n container-type: inline-size;\n\n contain: paint;\n\n /*\n * ------------------------------------------\n * Can remove the @supports rule when support\n * for the scroll-driven animations below has\n * been enabled by default in Firefox and the\n * documented scroll-timeline syntax (x and y\n * as opposed to vertical and horizontal) can\n * be used\n * https://caniuse.com/mdn-css_properties_animation-timeline_view\n * ------------------------------------------\n */\n @supports (scroll-timeline: --overflow-shadows x) {\n background:\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at left center,\n var(--overflow-shadow-start),\n #{$table-overflow-shadow-colour-hidden}\n ),\n radial-gradient(\n ellipse #{$table-overflow-shadow-width} 50% at right center,\n var(--overflow-shadow-end),\n #{$table-overflow-shadow-colour-hidden}\n )\n transparent;\n background-position: 0;\n\n animation: overflow-shadows 1ms linear;\n animation-timeline: --overflow-shadows;\n scroll-timeline: --overflow-shadows x;\n }\n\n &:last-child {\n margin-bottom: 0;\n }\n\n &:focus:not(:focus-visible) {\n @include a11y.no-focus-outline;\n }\n\n .tna-table {\n &__caption {\n max-width: calc(100vw - #{grid.gutter-width-double()});\n max-width: 100cqw;\n\n position: sticky;\n left: 0;\n\n @include media.on-tiny {\n max-width: calc(100vw - #{grid.gutter-width-tiny-double()});\n max-width: 100cqw;\n }\n }\n }\n\n // &--sticky-first-column {\n // background: radial-gradient(\n // ellipse #{$table-overflow-shadow-width} 50% at right center,\n // var(--overflow-shadow-end),\n // #{$table-overflow-shadow-colour-hidden}\n // )\n // transparent;\n\n // .tna-table {\n // &__header,\n // &__cell {\n // &:first-child {\n // max-width: 50vw;\n // max-width: 50cqw;\n\n // position: sticky;\n // left: 0;\n // z-index: 1;\n\n // overflow-wrap: break-word;\n\n // hyphens: auto;\n // @include colour.colour-background(\"background\");\n\n // &::after {\n // content: \"\";\n\n // width: 0.75rem;\n\n // position: absolute;\n // top: 0;\n // bottom: -1px;\n // left: 100%;\n\n // background: linear-gradient(\n // 90deg,\n // var(--overflow-shadow-start) 0%,\n // #{$table-overflow-shadow-colour-hidden} 100%\n // );\n // animation: overflow-shadows linear;\n // animation-timeline: --overflow-shadows;\n // }\n // }\n // }\n // }\n // }\n\n &--scroll {\n .tna-table {\n &__caption {\n &::after {\n content: \" (scroll to see more)\";\n }\n }\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-accordion {\n @include spacing.space-above;\n\n // NON INTERACTIVE\n &__item {\n @include spacing.space-above;\n }\n\n &__heading {\n padding-top: spacing.space(1);\n }\n\n &__body {\n padding-top: spacing.space(1);\n }\n\n // INTERACTIVE\n &__toggle-all {\n margin-bottom: spacing.space(1);\n padding: 0;\n\n background: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n @include colour.colour-font(\"link\");\n @include typography.font-size(16);\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__details {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n position: relative;\n z-index: 1;\n\n &:first-of-type {\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n }\n }\n\n &__summary {\n width: 100%;\n margin: 0;\n padding: spacing.space(0.5) spacing.space(3) spacing.space(0.5)\n spacing.space(1);\n\n display: block;\n\n position: relative;\n\n line-height: inherit;\n text-align: left;\n\n list-style: none;\n\n background: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(18);\n @include typography.main-font(true);\n\n * {\n font-size: inherit;\n }\n\n &::before {\n content: \"\";\n\n width: 0;\n height: 0;\n\n position: absolute;\n top: calc(50% - #{math.div(math.sqrt(3), 4)}rem);\n right: 0.75rem;\n\n border-width: #{math.div(math.sqrt(3), 2)}rem 0.5rem 0 0.5rem;\n border-color: colour.colour-var(\"font-light\") transparent;\n border-style: solid;\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n @include colour.colour-background(\"background-tint\");\n\n &::before {\n border-color: colour.colour-var(\"font-dark\") transparent;\n }\n }\n\n &[aria-expanded=\"true\"] {\n &::before {\n border-width: 0 0.5rem #{math.div(math.sqrt(3), 2)}rem 0.5rem;\n }\n }\n\n &:active {\n z-index: 1;\n }\n }\n\n &__content {\n padding: spacing.space(1);\n\n position: relative;\n\n border-radius: 0.1px;\n }\n\n @include colour.on-forced-colours {\n &__summary {\n &::before {\n content: \"\\2193\";\n\n width: auto;\n height: auto;\n\n top: calc(50% - 0.5rem);\n\n line-height: 1rem;\n\n border: none;\n }\n\n &[aria-expanded=\"true\"] {\n &::before {\n content: \"\\2191\";\n\n border: none;\n }\n }\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-back-link {\n display: inline-flex;\n gap: spacing.space(0.5);\n\n &,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n\n &,\n &:hover,\n &:focus-visible {\n text-decoration: none;\n }\n\n &__inner {\n text-decoration: underline;\n @include typography.interactable-text-decoration;\n }\n\n &:hover &__inner {\n @include typography.interacted-text-decoration;\n }\n\n &::before {\n content: \"\\2039\";\n content: \"\\2039\" / \"\";\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-breadcrumbs {\n border-radius: 0.1px;\n\n &__list {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-wrap: wrap;\n\n list-style: none;\n }\n\n &__item {\n display: flex;\n\n + .tna-breadcrumbs__item {\n &::before {\n content: \"\\203A\";\n content: \"\\203A\" / \"\";\n\n margin: 0 spacing.space(0.75);\n\n display: inline-block;\n\n vertical-align: baseline;\n }\n }\n\n &--expandable {\n display: none;\n\n @include media.on-mobile {\n display: inline-block !important;\n }\n }\n }\n\n &__link {\n display: inline-block;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n }\n\n button#{&}__link {\n height: 100%;\n margin: 0;\n padding: 0;\n\n appearance: none;\n\n line-height: inherit;\n\n background-color: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &:hover {\n color: inherit;\n @include typography.interacted-text-decoration;\n\n background-color: transparent;\n }\n }\n\n @include media.on-mobile {\n &--collapsed &__item:not(:first-child, &__item--expandable, :last-child) {\n display: none;\n }\n }\n\n @include colour.on-high-contrast {\n &__link {\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"link\");\n }\n }\n }\n}\n","@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n\n.tna-button-group {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: spacing.space(1);\n\n @include spacing.space-above;\n\n @include media.on-tiny {\n flex-direction: column;\n align-items: stretch;\n }\n\n &--small {\n gap: spacing.space(0.5);\n }\n\n &--centred {\n justify-content: center;\n }\n\n &--full {\n justify-content: stretch;\n\n @include media.on-mobile {\n flex-direction: column;\n\n align-items: stretch;\n }\n\n .tna-button {\n margin: 0;\n\n flex: 1;\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n@use \"button-group\";\n\n$button-border-width: 4px !default;\n\n.tna-button {\n padding: spacing.space(0.25) spacing.space(1);\n\n display: inline-flex;\n align-items: baseline;\n justify-content: center;\n gap: spacing.space(0.75);\n\n line-height: 2rem;\n text-align: center;\n text-decoration: none;\n text-wrap: balance;\n\n cursor: pointer;\n\n -webkit-print-color-adjust: exact;\n print-color-adjust: exact;\n\n @include typography.font-size(18);\n @include typography.main-font-weight-bold;\n\n @include colour.colour-background(\"button-background\");\n\n @include colour.colour-border(\"button-background\", $button-border-width);\n @include borders.rounded-border;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"button-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"button-hover-text\");\n text-decoration: none;\n\n background: transparent;\n }\n\n .fa-solid {\n display: block;\n }\n\n svg {\n height: 1.1em;\n flex-shrink: 0;\n\n align-self: center;\n\n fill: currentColor;\n }\n\n &--plain {\n @include typography.main-font-weight;\n text-decoration: underline;\n\n background-color: transparent;\n\n border-color: transparent;\n border-radius: 0.1px;\n\n &,\n &:link,\n &:visited,\n &:hover {\n @include colour.colour-font(\"link\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &--accent {\n @include colour.colour-background(\"button-accented-background\");\n\n @include colour.colour-border(\"button-accented-background\");\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"button-accented-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n &--icon-right {\n flex-direction: row-reverse;\n\n &:has(.fa-solid) {\n align-items: center;\n // justify-content: space-between;\n }\n }\n\n &--small,\n &-group--small & {\n padding: 0 spacing.space(0.5);\n\n @include typography.font-size(14);\n line-height: 1.5rem;\n }\n\n @mixin icon-only {\n padding-right: 0;\n padding-left: 0;\n\n gap: 0;\n\n font-size: 0 !important;\n line-height: 0 !important;\n\n .fa-solid {\n width: 2.5rem;\n\n line-height: 2rem;\n\n @include typography.font-size(18);\n }\n\n svg {\n height: 1.5rem;\n margin: 0.5rem;\n }\n }\n\n @mixin icon-only-small {\n padding-right: 0;\n padding-left: 0;\n\n .fa-solid {\n width: 1.5rem;\n\n line-height: 1.5rem;\n }\n\n svg {\n height: 1.2rem;\n margin: 0.5rem;\n }\n }\n\n &--icon-only {\n @include icon-only;\n }\n\n &--small#{&}--icon-only,\n &-group--small &--icon-only {\n @include icon-only-small;\n }\n\n @include media.on-mobile {\n &--icon-only-mobile {\n @include icon-only;\n }\n\n &--small#{&}--icon-only-mobile,\n &-group--small &--icon-only-mobile {\n @include icon-only-small;\n }\n }\n\n &--solid-hover {\n &:not(.tna-button--plain):hover {\n @include colour.colour-font(\"font-dark\");\n\n @include colour.colour-background(\"background\");\n }\n }\n\n .tna-background-accent &,\n .tna-template--dark-theme .tna-background-accent-light & {\n &:hover {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n .tna-background-accent &--accent,\n .tna-template--dark-theme .tna-background-accent-light &--accent {\n @include colour.colour-background(\"contrast-button-background\");\n\n @include colour.colour-border(\"contrast-button-background\");\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"contrast-button-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"contrast-font-dark\");\n\n @include colour.colour-background(\"contrast-background\");\n }\n }\n\n @media (prefers-color-scheme: dark) {\n .tna-template--system-theme .tna-background-accent-light & {\n &:hover {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n .tna-template--system-theme .tna-background-accent-light &--accent {\n @include colour.colour-background(\"contrast-button-background\");\n\n @include colour.colour-border(\"contrast-button-background\");\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"contrast-button-text\");\n }\n\n &:hover {\n @include colour.colour-font(\"contrast-font-dark\");\n\n @include colour.colour-background(\"contrast-background\");\n }\n }\n }\n\n @include colour.on-forced-colours {\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../variables/a11y\" as a11yVars;\n@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n@mixin horizontal-card-layout($modifierClass, $innerPaddingAmount) {\n &#{$modifierClass} {\n padding-bottom: 0;\n\n display: grid;\n grid-template: min-content 1fr / 50% 50%;\n grid-template-areas:\n \"image header\"\n \"image body\";\n gap: 0;\n\n > * + * {\n margin-top: spacing.space(0.5);\n }\n\n > :first-child {\n padding-top: spacing.space($innerPaddingAmount - 0.25);\n }\n\n > :last-child {\n padding-bottom: spacing.space($innerPaddingAmount);\n }\n }\n\n &#{$modifierClass}:not(:has(&__image-container)) {\n grid-template-columns: 0 100%;\n }\n\n &#{$modifierClass}#{&}--flipped {\n grid-template-areas:\n \"header image\"\n \"body image\"\n \"footer image\";\n }\n\n &#{$modifierClass}#{&}--flipped:not(:has(&__image-container)) {\n grid-template-columns: 100% 0;\n }\n\n &#{$modifierClass} &__heading,\n &#{$modifierClass} &__body {\n padding-right: spacing.space($innerPaddingAmount);\n padding-left: spacing.space($innerPaddingAmount);\n }\n\n &#{$modifierClass} &__heading {\n grid-area: header;\n }\n\n &#{$modifierClass} &__image-container {\n width: 100%;\n height: 100%;\n margin: 0;\n padding: 0;\n\n grid-area: image;\n\n border-radius: bordersVars.$rounded-border-radius 0 0\n bordersVars.$rounded-border-radius;\n }\n\n &#{$modifierClass}#{&}--flipped &__image-container {\n border-radius: 0 bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0;\n }\n\n &#{$modifierClass} &__body {\n grid-area: body;\n }\n}\n\n.tna-card {\n @include spacing.space-above;\n\n display: flex;\n flex-direction: column;\n gap: spacing.space(0.5);\n\n position: relative;\n z-index: 1;\n\n @include borders.rounded-border;\n\n &:not(:has(&__image-container)) {\n padding-top: spacing.space(0.5);\n\n @include colour.thick-keyline-dark(top);\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &__heading {\n order: 2;\n\n .tna-hgroup__supertitle {\n margin-top: spacing.space(0.25);\n }\n }\n\n &:not(:has(&__image-container)) &__heading {\n .tna-hgroup__supertitle {\n margin-top: spacing.space(0.5);\n }\n }\n\n &--full-click {\n &:hover {\n @include colour.colour-outline(\n \"base-keyline\",\n a11yVars.$focus-outline-active-outer-width,\n solid\n );\n outline-offset: a11yVars.$focus-outline-active-inner-width;\n }\n }\n\n @include a11y.faux-full-outline(\"&--full-click &__heading-link\");\n\n &--full-click#{&}:not(:has(&__image-container)) &__heading-link::before {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--full-click#{&}--padded#{&}:not(:has(&__image-container))\n &__heading-link::before {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--full-click:not(:has(&__image-container)) &__heading-link {\n &::before {\n top: -#{bordersVars.$thick-border-width};\n }\n }\n\n &--full-height {\n height: 100%;\n\n box-sizing: border-box;\n }\n\n &__image-container {\n aspect-ratio: 3/2;\n margin-bottom: spacing.space(0.25);\n\n overflow: hidden;\n\n position: relative;\n\n order: 1;\n\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n\n @include colour.image-loader-background;\n }\n\n &__image {\n position: absolute;\n inset: 0;\n z-index: 1;\n\n img {\n width: 100%;\n height: 100%;\n\n object-fit: cover;\n }\n }\n\n &__image-label {\n position: absolute;\n top: spacing.space(0.5);\n left: spacing.space(0.5);\n z-index: 2;\n }\n\n &__body {\n order: 3;\n\n display: flex;\n flex-direction: column;\n\n gap: spacing.space(1);\n\n > * {\n margin-top: 0;\n }\n }\n\n &__meta {\n padding-top: spacing.space(0.5);\n }\n\n &__actions {\n margin-top: spacing.space(0.5);\n\n display: flex;\n gap: spacing.space(1) spacing.space(2);\n }\n\n &__action {\n @include typography.main-font-weight-bold;\n }\n\n &--padded {\n padding-bottom: spacing.space(1);\n }\n\n &--padded:not(:has(&__image-container)) {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--padded &__heading,\n &--padded &__body {\n padding-right: spacing.space(1);\n padding-left: spacing.space(1);\n }\n\n &--plain {\n &::after {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: -1;\n\n border-radius: inherit;\n @include colour.colour-border(\"keyline\", 1px, solid);\n }\n }\n\n &--plain:not(:has(&__image-container)) {\n &::after {\n border-top-width: 0;\n }\n }\n\n @include colour.on-high-contrast {\n padding-bottom: spacing.space(1);\n @include borders.rounded-border;\n\n &:not(&--padded),\n &--plain {\n @include colour.colour-border(\"keyline-dark\", 1px, solid);\n }\n\n &--full-click:not(:has(&__image-container)) {\n @include colour.thick-keyline-dark(top);\n }\n\n &__heading,\n &__body {\n padding-right: spacing.space(1);\n padding-left: spacing.space(1);\n }\n\n &__image-container {\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n }\n\n &:not(:has(&__image-container)) {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--full-click:not(&--padded) &__heading-link::before {\n @include borders.rounded-border;\n }\n\n &--full-click:not(:has(&__image-container), &--padded)\n &__heading-link::before {\n border-radius: 0.1px 0.1px bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--padded {\n &::after {\n display: none;\n }\n }\n }\n\n @include colour.on-forced-colours {\n padding-bottom: spacing.space(1);\n @include colour.colour-border(\"keyline-dark\", 1px, solid);\n @include borders.rounded-border;\n\n &__heading,\n &__body {\n padding-right: spacing.space(1);\n padding-left: spacing.space(1);\n }\n\n &--full-click:not(:has(&__image-container)) &__heading-link {\n &::before {\n top: -#{bordersVars.$thick-border-width - 1px};\n }\n }\n }\n\n @include media.on-larger-than-mobile {\n @include horizontal-card-layout(\"--horizontal\", 1.25);\n\n &--horizontal-small-image {\n grid-template-columns: max(10rem, 25%) 1fr;\n }\n\n &--horizontal-small-image#{&}--flipped {\n grid-template-columns: 1fr max(10rem, 25%);\n }\n }\n\n @include media.on-small {\n @include horizontal-card-layout(\"--horizontal-on-small\", 1);\n\n &--horizontal-small-image {\n grid-template-columns: max(10rem, 25%) 1fr;\n }\n\n &--horizontal-small-image#{&}--flipped {\n grid-template-columns: 1fr max(10rem, 25%);\n }\n }\n}\n","$focus-outline-inner-width: 3px !default;\n$focus-outline-outer-width: 3px !default;\n$focus-outline-total-width: $focus-outline-inner-width +\n $focus-outline-outer-width;\n$focus-outline-active-inner-width: $focus-outline-inner-width - 1px !default;\n$focus-outline-active-outer-width: $focus-outline-outer-width - 1px !default;\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-compound-filters {\n @include spacing.space-above;\n\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: spacing.space(0.5) spacing.space(0.75);\n\n list-style: none;\n\n &__item {\n padding: 0 spacing.space(0.125) 0 spacing.space(0.75);\n\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n line-height: 1.75;\n\n @include borders.rounded-border;\n\n @include typography.font-size(16);\n\n @include colour.colour-border(\"keyline\", 1px);\n\n &--remove {\n padding-right: 0;\n padding-left: 0;\n\n background: none;\n\n border: none;\n border-radius: 0;\n }\n }\n\n &__link {\n width: 1.5rem;\n height: 1.5rem;\n\n position: relative;\n\n flex-shrink: 0;\n\n font-size: 0;\n line-height: 0;\n\n text-decoration: none;\n\n @include borders.rounded-border;\n\n &::before,\n &::after {\n content: \"\";\n\n height: 1rem;\n margin-left: -1px;\n\n display: block;\n\n position: absolute;\n top: 0.25rem;\n left: 50%;\n\n @include colour.colour-border(\"font-base\", 2px, solid, left);\n }\n\n &::before {\n transform: rotate(45deg);\n }\n\n &::after {\n transform: rotate(-45deg);\n }\n\n &:hover {\n @include colour.contrast;\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-cookie-banner {\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n\n @include media.on-tiny {\n padding-top: 1rem;\n padding-bottom: 1rem;\n\n @include typography.font-size(16);\n }\n\n &__message {\n &--prompt {\n }\n\n &--accepted {\n }\n\n &--rejected {\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../variables/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-details {\n margin-top: spacing.space(1);\n\n &:first-child {\n margin-top: 0;\n }\n\n &__details {\n }\n\n &__summary {\n width: fit-content;\n padding: spacing.space(0.5) spacing.space(1) spacing.space(0.5)\n spacing.space(2.75);\n\n display: block;\n\n position: relative;\n z-index: 2;\n\n @include colour.colour-font(\"link\");\n text-decoration: underline;\n text-decoration-thickness: 1.5px;\n\n list-style: none;\n\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &::-webkit-details-marker {\n display: none;\n }\n\n &::before {\n content: \"\";\n\n width: 0;\n height: 0;\n\n position: absolute;\n top: calc(50% - 0.5rem);\n left: 0.75rem;\n\n border-width: 0.5rem 0 0.5rem #{math.div(math.sqrt(3), 2)}rem;\n border-color: transparent transparent transparent\n colour.colour-var(\"link\");\n border-style: solid;\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__content {\n padding: 0 0 0 spacing.space(2.75);\n }\n\n &__details[open] &__summary {\n &::before {\n top: calc(50% - #{math.div(math.sqrt(3), 4)}rem);\n\n border-width: #{math.div(math.sqrt(3), 2)}rem 0.5rem 0 0.5rem;\n border-color: colour.colour-var(\"link\") transparent transparent\n transparent;\n }\n }\n\n &__details[open] &__content {\n position: relative;\n z-index: 1;\n\n &::before {\n content: \"\";\n\n display: block;\n\n position: absolute;\n inset: 0 auto 0 calc(1.5rem - #{math.div(borders.$thick-border-width, 2)});\n\n @include colour.thick-keyline(left);\n }\n }\n\n @include colour.on-forced-colours {\n &__summary {\n &::before {\n content: \"\\2192\";\n\n width: auto;\n height: auto;\n\n top: calc(50% - 0.5rem);\n\n line-height: 1rem;\n\n border: none;\n }\n }\n\n &__details[open] &__summary {\n &::before {\n content: \"\\2193\";\n\n border: none;\n }\n }\n }\n}\n","@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-files-list {\n @include spacing.space-above;\n padding: spacing.space(1);\n\n @include colour.tint;\n\n @include borders.rounded-border;\n\n &__items {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-direction: column;\n gap: spacing.space(1);\n flex: 1;\n\n list-style: none;\n\n @include colour.colour-border(\"keyline\", 0, solid);\n border-left-width: 1px;\n }\n\n &__item {\n padding: 0 0 0 spacing.space(0.5);\n\n display: grid;\n grid-template-columns: auto 1fr;\n gap: spacing.space(0.25) spacing.space(1);\n\n position: relative;\n }\n\n &__link {\n }\n\n &__item-title {\n grid-column: 2;\n grid-row: 1;\n }\n\n &__item-icon {\n margin: spacing.space(0.5) 0;\n\n grid-column: 1;\n grid-row: 1/3;\n @include typography.font-size(36);\n }\n\n &__item-body {\n grid-column: 2;\n grid-row: 2;\n }\n\n &__item-meta {\n padding-bottom: spacing.space(0.25);\n }\n\n &__item-description {\n margin-top: 0;\n\n @include typography.font-size(16);\n }\n\n &--full-click {\n }\n\n @include a11y.faux-full-outline(\"&--full-click &__link\");\n\n &--full-click &__link {\n &:hover {\n &::before {\n @include colour.thick-keyline(left);\n }\n }\n }\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-footer {\n &__inner {\n @include colour.contrast;\n\n padding-top: spacing.space(1);\n padding-bottom: spacing.space(3);\n }\n\n &__theme-selector {\n .tna-button-group {\n justify-content: flex-end;\n }\n\n @include colour.on-forced-colours {\n display: none;\n }\n }\n\n &__theme-selector-button {\n @include typography.main-font-weight-bold;\n }\n\n &__theme-selector-notice {\n margin-top: spacing.space(0.5);\n margin-bottom: spacing.space(0.25);\n padding: spacing.space(0.5) spacing.space(0.75);\n\n @include typography.font-size(16);\n line-height: 1.5;\n\n @include colour.blue-accent;\n @include colour.accent-light;\n\n @include borders.rounded-border;\n @include colour.thick-keyline-accent(left);\n }\n\n &__theme-selector-enable-settings-cookies {\n appearance: none;\n\n line-height: inherit;\n text-decoration: underline;\n\n background: none;\n\n border: none;\n border-radius: 0.1px;\n\n cursor: pointer;\n @include colour.colour-font(\"link\");\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n .tna-logo {\n margin-top: spacing.space(2);\n }\n\n &__title {\n margin-top: spacing.space(1);\n margin-bottom: 0;\n padding-top: 0;\n }\n\n &__address {\n }\n\n &__meta {\n margin-top: spacing.space(1);\n\n @include typography.font-size(16);\n }\n\n &__social {\n margin-top: spacing.space(2);\n\n &-items {\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n gap: spacing.space(1) spacing.space(2);\n }\n\n &-item {\n &-link {\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n @include typography.font-size(16);\n line-height: 1.25;\n text-decoration: none;\n\n svg {\n height: 1.5em;\n\n path {\n fill: currentColor;\n }\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n &-text {\n }\n }\n }\n }\n\n &__mailing-list {\n margin-top: spacing.space(2);\n padding: spacing.space(1);\n\n @include typography.font-size(16);\n\n background-color: rgb(255 255 255 / 14%);\n\n @include borders.rounded-border;\n }\n\n &__navigation {\n &-block {\n padding-top: spacing.space(2);\n\n &-heading {\n }\n\n &-items {\n }\n\n &-item {\n padding-top: spacing.space(0.375);\n padding-bottom: spacing.space(0.375);\n\n @include typography.font-size(16);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &-link {\n display: inline-block;\n\n text-decoration: none;\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n .fa-solid {\n margin-left: spacing.space(0.75);\n }\n }\n }\n }\n }\n\n &__legal {\n padding-top: spacing.space(3);\n\n @include typography.font-size(16);\n\n &-items {\n margin-bottom: 0;\n\n text-align: center;\n\n @include media.on-tiny {\n text-align: inherit;\n }\n }\n\n &-item {\n padding: spacing.space(0.5);\n\n display: inline-block;\n\n @include media.on-tiny {\n display: block;\n }\n\n &-link {\n }\n }\n }\n\n hr {\n margin-top: spacing.space(1.5);\n margin-bottom: spacing.space(0.5);\n }\n\n &__licence {\n @include typography.font-size(16);\n\n &.tna-container {\n align-items: center;\n }\n\n .tna-column {\n margin-top: spacing.space(1);\n }\n }\n\n &__licence-logo {\n display: block;\n }\n\n &__govuk {\n text-align: center;\n\n &-link {\n display: inline-block;\n }\n\n &-logotype-crown {\n margin: 0 auto spacing.space(0.125);\n\n display: block;\n }\n }\n\n @include media.on-mobile {\n &__inner {\n padding-top: 0;\n padding-bottom: spacing.space(2);\n }\n }\n\n @include media.on-tiny {\n &__social-items {\n flex-direction: column;\n }\n\n &__social-item-link {\n @include typography.font-size(14);\n }\n }\n\n @include colour.on-high-contrast {\n &__theme-selector {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.thick-keyline-dark(top);\n\n &__navigation {\n &-block {\n &-items {\n @include colour.thick-keyline-dark(top);\n }\n }\n }\n\n &__mailing-list {\n background-color: transparent;\n\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-gallery {\n @include spacing.space-above;\n\n display: grid;\n grid-template: min-content min-content 1fr / 2fr 1fr;\n gap: 0 spacing.space(1);\n\n border-radius: 0.1px;\n\n &__header {\n padding-bottom: spacing.space(1);\n\n grid-column: 1 / 3;\n grid-row: 1;\n\n display: flex;\n gap: spacing.space(2);\n }\n\n &__header-inner {\n flex: 1;\n }\n\n &__items,\n &__navigation-buttons {\n grid-column: 1 / 3;\n grid-row: 2;\n }\n\n &__items {\n position: relative;\n z-index: 1;\n\n border-radius: 0.1px;\n\n .tna-template--clicked &:focus {\n @include a11y.no-focus-outline;\n }\n }\n\n &__item {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n justify-content: center;\n }\n\n &__item-header {\n padding: 0 spacing.space(1) spacing.space(1);\n\n line-height: 1;\n text-align: center;\n\n @include typography.main-font-weight-bold;\n @include typography.font-size(16);\n }\n\n &__item-figure {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n gap: spacing.space(1);\n }\n\n &__item-figure-inner {\n width: 100%;\n\n position: relative;\n\n @include colour.contrast;\n\n @include borders.rounded-border;\n }\n\n &__item-image {\n margin: 0 auto;\n }\n\n &__item-description {\n margin-bottom: spacing.space(1);\n padding: spacing.space(0.5) spacing.space(1);\n\n align-self: flex-start;\n\n @include colour.thick-keyline-dark(left);\n }\n\n &__navigation-buttons {\n width: 100%;\n max-height: 50vh;\n aspect-ratio: 3 / 2;\n\n position: relative;\n top: spacing.space(2);\n z-index: 2;\n\n pointer-events: none;\n\n .tna-template--touched & {\n display: none;\n }\n }\n\n &__navigation-button {\n width: 35%;\n\n display: flex;\n align-items: center;\n\n position: absolute;\n top: 0;\n bottom: 0;\n\n background: transparent;\n\n border: none;\n border-radius: 0.1px;\n\n opacity: 0;\n\n cursor: pointer;\n pointer-events: auto;\n @include typography.main-font-weight-bold;\n\n &:hover,\n &:focus-visible {\n opacity: 1;\n }\n }\n\n &__navigation-prev {\n padding-left: 1rem;\n\n justify-content: flex-start;\n\n left: 0;\n }\n\n &__navigation-next {\n padding-right: 1rem;\n\n justify-content: flex-end;\n\n right: 0;\n }\n\n &__navigation-button-label {\n @include colour.accent;\n\n &,\n &:hover {\n @include colour.colour-font(\"button-accented-text\");\n @include colour.colour-background(\"button-accented-background\");\n @include colour.colour-border(\"button-accented-background\");\n }\n }\n\n &__navigation-button-icon {\n content: \"\";\n\n width: 0.75rem;\n height: 0.75rem;\n\n display: block;\n flex: none;\n\n @include colour.colour-border(\"font-dark\", 4px, solid, top);\n @include colour.colour-border(\"font-dark\", 4px, solid, right);\n\n transform-origin: 50% 50%;\n }\n\n &__navigation-prev &__navigation-button-icon {\n transform: rotate(-135deg);\n }\n\n &__navigation-next &__navigation-button-icon {\n transform: rotate(45deg);\n }\n\n &__navigation {\n max-height: 40rem;\n max-height: clamp(15rem, calc(100vh - #{spacing.space(2)}), 40rem);\n padding: spacing.space(1);\n\n grid-column: 1 / 3;\n grid-row: 3;\n\n display: grid;\n grid-template-columns: repeat(6, 1fr);\n grid-auto-rows: min-content;\n gap: spacing.space(1);\n\n overflow: auto;\n }\n\n &__navigation-item {\n min-width: 0;\n min-height: 0;\n aspect-ratio: 1;\n\n position: relative;\n\n border: none;\n @include borders.rounded-border;\n\n cursor: pointer;\n\n @include colour.contrast;\n\n @include colour.image-loader-background;\n\n &:hover {\n &::after {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: 2;\n\n @include colour.thick-keyline-accent;\n }\n }\n\n &[aria-current=\"true\"] {\n @include colour.accent;\n\n &::after {\n content: \"\";\n\n position: absolute;\n inset: 0;\n z-index: 2;\n\n @include colour.thick-keyline-brand(\"\", \"black\");\n }\n }\n }\n\n &__navigation-item-image {\n width: 100%;\n height: 100%;\n\n position: absolute;\n inset: 0;\n object-fit: cover;\n }\n\n &__navigation-item-label {\n padding: spacing.space(0.25) spacing.space(0.75);\n\n display: inline-block;\n\n position: absolute;\n top: 0;\n left: 0;\n z-index: 4;\n\n text-transform: capitalize;\n\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(24);\n @include typography.main-font-weight-bold;\n\n @include colour.colour-background(\"background\");\n\n border-radius: 0 0 bordersVars.$rounded-border-radius 0;\n }\n\n &--interactive &__item-figure-inner {\n max-height: 50vh;\n aspect-ratio: 3 / 2;\n }\n\n &--interactive &__item-image {\n width: 100%;\n height: 100%;\n\n position: absolute;\n inset: 0;\n z-index: 1;\n object-fit: contain;\n }\n\n @include media.on-medium {\n &__navigation {\n grid-template-columns: repeat(4, 1fr);\n }\n }\n\n @include media.on-mobile {\n &__navigation {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n\n @include media.on-tiny {\n &__navigation-item-label {\n @include typography.font-size(18);\n }\n }\n\n &--bounded {\n @include borders.rounded-border;\n @include colour.tint;\n }\n\n &--bounded &__header {\n padding: spacing.space(1);\n }\n\n &--bounded &__navigation-buttons {\n top: spacing.space(3);\n }\n\n &--bounded &__item-header {\n padding-top: spacing.space(1);\n }\n\n &--bounded &__item-figure-inner {\n border-radius: 0.1px;\n }\n\n &--bounded &__item-description {\n margin-right: spacing.space(1);\n margin-left: spacing.space(1);\n }\n\n &__items--hide-item-titles &__item &__item-header {\n display: none;\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-global-header {\n @include colour.contrast;\n background: linear-gradient(\n 0deg,\n rgb(34 34 34 / 100%) 0%,\n rgb(0 0 0 / 100%) 100%\n );\n\n @include colour.colour-font(\"font-base\");\n\n .tna-template--dark-theme & {\n background: colour.brand-colour(\"black\");\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n background: colour.brand-colour(\"black\");\n }\n }\n\n @include colour.on-high-contrast {\n background: colour.brand-colour(\"black\");\n }\n\n &__main {\n padding-top: spacing.space(1);\n padding-bottom: spacing.space(1.5);\n }\n\n &__logo-wrapper {\n margin-top: spacing.space(0.5);\n\n display: flex;\n }\n\n &__logo {\n display: flex;\n align-items: flex-end;\n gap: spacing.space(1);\n\n text-decoration: none;\n\n &--link {\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n\n &:hover {\n @include colour.colour-outline(\"font-dark\", 0.3125rem, solid);\n outline-offset: 2px;\n }\n }\n }\n\n &__logo-strapline {\n padding-right: spacing.space(0.625);\n\n line-height: math.div(6.75rem, 3);\n text-transform: uppercase;\n\n @include typography.heading-font;\n @include typography.font-size(20);\n }\n\n &__navigation-button-wrapper {\n display: none;\n }\n\n &__hamburger {\n width: 2rem;\n height: 0.25rem;\n\n display: inline-block;\n\n @include colour.colour-background(\"font-dark\");\n\n &::before,\n &::after {\n content: \"\";\n\n width: 2rem;\n height: 0.25rem;\n\n display: block;\n\n position: absolute;\n right: 0;\n\n background-color: inherit;\n }\n\n &::before {\n top: 0;\n }\n\n &::after {\n bottom: 0;\n }\n }\n\n &__navigation-button {\n height: 2rem;\n padding: 0;\n\n appearance: none;\n display: flex;\n align-items: center;\n gap: 0.75rem;\n\n position: relative;\n\n color: inherit;\n\n background: none;\n\n border: 0 transparent solid;\n border-width: 0.25rem 0;\n border-radius: 0.1px;\n\n cursor: pointer;\n @include typography.main-font-weight-bold;\n @include typography.font-size(16);\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n &--opened {\n .tna-global-header__hamburger {\n height: 0;\n\n &::before {\n top: 0.625rem;\n\n transform: rotate(-135deg);\n }\n\n &::after {\n bottom: 0.625rem;\n\n transform: rotate(135deg);\n }\n }\n }\n }\n\n &__navigation-wrapper {\n }\n\n &__navigation {\n height: 100%;\n margin: spacing.space(0.5) 0 0;\n\n position: relative;\n\n columns: 2;\n column-gap: spacing.space(2);\n\n list-style: none;\n }\n\n &__navigation-item {\n break-inside: avoid;\n }\n\n &__navigation-item-link {\n min-width: 15rem;\n height: math.div(6.75rem, 3);\n\n display: block;\n box-sizing: border-box;\n\n line-height: math.div(6.75rem, 3);\n text-decoration: none;\n\n @include typography.font-size(17);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__top-navigation {\n padding: 0 0 spacing.space(0.5);\n\n display: flex;\n justify-content: flex-end;\n gap: spacing.space(1.5);\n\n @include typography.font-size(15);\n list-style: none;\n }\n\n &__top-navigation-item {\n }\n\n &__top-navigation-link {\n display: flex;\n align-items: center;\n gap: spacing.space(0.5);\n\n text-decoration: none;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-light\");\n }\n\n &:hover,\n &:focus-visible {\n @include colour.colour-font(\"font-base\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n svg {\n height: 1em;\n\n display: inline-block;\n\n path {\n fill: currentColor;\n }\n }\n }\n\n .tna-logo {\n width: 6.75rem;\n\n flex-shrink: 0;\n }\n\n @include media.on-medium {\n &__navigation {\n column-gap: spacing.space(1);\n }\n\n &__navigation-item-link {\n @include typography.font-size(16);\n }\n\n &--collapse-on-medium &__navigation-wrapper {\n width: 100%;\n }\n\n &--collapse-on-medium &__top-navigation-wrapper {\n flex: 1;\n order: 2;\n }\n\n &--collapse-on-medium &__main {\n padding-bottom: spacing.space(1);\n }\n\n &--collapse-on-medium &__logo {\n gap: spacing.space(0.75);\n }\n\n &--collapse-on-medium &__logo-wrapper {\n margin-top: spacing.space(0.5);\n margin-bottom: spacing.space(0.5);\n }\n\n &--collapse-on-medium .tna-logo {\n width: 5rem;\n }\n\n &--collapse-on-medium &__logo-strapline {\n line-height: math.div(5rem, 3);\n }\n\n &--collapse-on-medium &__navigation {\n margin-bottom: spacing.space(0.5);\n }\n\n &--collapse-on-medium &__navigation,\n &--collapse-on-medium &__navigation-item,\n &--collapse-on-medium &__navigation-item-link {\n height: auto;\n }\n }\n\n @include media.on-mobile {\n &__main {\n padding-bottom: 0;\n }\n\n &__logo-wrapper,\n &__navigation-button-wrapper {\n margin-top: 0;\n margin-bottom: spacing.space(1);\n }\n\n &__logo {\n gap: spacing.space(0.75);\n }\n\n &__navigation-button-wrapper {\n display: flex;\n align-items: center;\n }\n\n &__navigation,\n &__navigation-item,\n &__navigation-item-link {\n height: auto;\n }\n\n &__navigation {\n margin-top: 0;\n\n columns: 1;\n\n background-color: rgb(255 255 255 / 10%);\n\n @include colour.colour-border(\"keyline-dark\", 2px, solid, top);\n @include colour.colour-border(\"keyline-dark\", 2px, solid, bottom);\n }\n\n &__navigation-item {\n flex-direction: column;\n align-items: flex-start;\n }\n\n &__navigation-item-link {\n line-height: 1.75rem;\n @include typography.main-font-weight-medium;\n }\n\n &__navigation-item:last-child &__navigation-item-link {\n border-bottom: none;\n }\n\n &__navigation-item-contents {\n display: block;\n }\n\n &__navigation-item-children {\n margin-bottom: spacing.space(1);\n margin-left: spacing.space(1.5);\n }\n\n &__top-navigation {\n padding-top: spacing.space(0.5);\n padding-bottom: spacing.space(0.5);\n\n justify-content: flex-start;\n\n gap: spacing.space(1.5);\n }\n\n &__top-navigation-link {\n padding: spacing.space(0.25) 0;\n }\n }\n\n @include media.on-small {\n .tna-logo {\n width: 4rem;\n }\n\n &__logo-strapline {\n line-height: 1.25rem;\n }\n\n &__navigation {\n width: calc(100% + #{grid.gutter-width-double()});\n\n left: -#{grid.gutter-width()};\n }\n\n &__navigation-item-link {\n padding: spacing.space(0.5) grid.gutter-width();\n }\n }\n\n @include media.on-tiny {\n .tna-logo {\n width: 3.5rem;\n }\n\n &__logo-strapline {\n line-height: 1;\n }\n\n &__navigation-button {\n @include typography.font-size(14);\n }\n\n &__navigation {\n width: calc(100% + #{grid.gutter-width-tiny-double()});\n\n left: -#{grid.gutter-width-tiny()};\n }\n\n &__navigation-item-link {\n padding: spacing.space(0.5) grid.gutter-width-tiny();\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n @include colour.on-forced-colours {\n &__navigation-button {\n height: auto;\n\n line-height: 2;\n @include typography.font-size(18);\n @include typography.main-font-weight-bold;\n\n border: none;\n }\n\n &__hamburger {\n display: none;\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-header {\n @include colour.contrast;\n\n position: relative;\n\n background: linear-gradient(\n 0deg,\n rgb(34 34 34 / 100%) 0%,\n rgb(0 0 0 / 100%) 100%\n );\n\n .tna-template--dark-theme & {\n background: colour.brand-colour(\"black\");\n }\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n background: colour.brand-colour(\"black\");\n }\n }\n\n @include colour.on-high-contrast {\n background: colour.brand-colour(\"black\");\n }\n\n &__contents {\n &.tna-container {\n justify-content: space-between;\n }\n }\n\n &__logo-wrapper {\n padding-top: spacing.space(1.25);\n padding-bottom: spacing.space(1.25);\n }\n\n &__logo {\n display: flex;\n align-items: flex-end;\n\n color: inherit;\n text-decoration: none;\n\n &--link {\n &,\n &:link,\n &:visited {\n color: inherit;\n }\n\n &:hover:not(:focus) {\n text-decoration: none;\n\n @include colour.colour-outline(\"font-dark\", 0.3125rem, solid);\n outline-offset: 1px;\n }\n }\n }\n\n &__logo-strapline {\n margin: 0 spacing.space(0.75);\n\n display: inline-block;\n\n line-height: 1.625rem;\n @include typography.heading-font;\n @include typography.font-size(20);\n text-transform: uppercase;\n }\n\n &__navigation-button-wrapper {\n align-self: center;\n\n display: none;\n }\n\n &__hamburger {\n width: 2rem;\n height: 0.25rem;\n\n display: inline-block;\n\n @include colour.colour-background(\"font-dark\");\n\n &::before,\n &::after {\n content: \"\";\n\n width: 2rem;\n height: 0.25rem;\n\n display: block;\n\n position: absolute;\n right: 0;\n\n background-color: inherit;\n }\n\n &::before {\n top: 0;\n }\n\n &::after {\n bottom: 0;\n }\n }\n\n &__navigation-button {\n height: 2rem;\n padding: 0;\n\n appearance: none;\n\n display: flex;\n align-items: center;\n gap: 0.75rem;\n\n position: relative;\n\n color: inherit;\n @include typography.main-font-weight-bold;\n @include typography.font-size(16);\n\n background: none;\n\n border: 0 transparent solid;\n border-width: 0.25rem 0;\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n\n &--opened {\n .tna-header__hamburger {\n height: 0;\n\n &::before {\n top: 0.625rem;\n\n transform: rotate(-135deg);\n }\n\n &::after {\n bottom: 0.625rem;\n\n transform: rotate(135deg);\n }\n }\n }\n }\n\n &__navigation {\n display: flex;\n flex-direction: column-reverse;\n align-items: flex-end;\n justify-content: space-between;\n\n position: relative;\n z-index: 2;\n }\n\n &__top-navigation-items {\n margin: 0;\n padding: spacing.space(1.25) 0;\n\n display: flex;\n justify-content: flex-end;\n gap: spacing.space(0.5) spacing.space(1.5);\n\n line-height: 1;\n\n list-style: none;\n\n @include typography.font-size(15);\n }\n\n &__top-navigation-item {\n display: block;\n }\n\n &__top-navigation-item-link {\n display: flex;\n align-items: center;\n\n text-decoration: none;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-light\");\n }\n\n &:hover,\n &:focus-visible,\n &--selected {\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-base\");\n }\n }\n\n &:hover,\n &--selected {\n @include typography.interacted-text-decoration;\n }\n\n .fa-solid {\n margin-right: spacing.space(0.375);\n }\n }\n\n &__navigation-items {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-wrap: nowrap;\n gap: spacing.space(2);\n\n white-space: nowrap;\n\n list-style: none;\n }\n\n &__navigation-item {\n }\n\n &__navigation-item-link {\n padding: spacing.space(0.5) 0;\n\n display: inline-block;\n\n position: relative;\n\n line-height: 2;\n text-decoration: none;\n\n @include typography.main-font-weight-medium;\n\n &::after {\n content: \"\";\n\n height: 0;\n\n position: absolute;\n right: 0;\n bottom: 0;\n left: 0;\n\n @include colour.colour-background(\"font-dark\");\n }\n\n &,\n &:link,\n &:visited {\n color: inherit;\n }\n\n &--selected {\n &::after {\n @include colour.thick-keyline-dark(top);\n }\n }\n }\n\n &.tna-background-accent {\n background: colour.colour-var(\"background\");\n }\n\n &.tna-background-accent &__navigation {\n @include colour.contrast-on-mobile;\n }\n\n .tna-logo {\n width: 5rem;\n\n flex-shrink: 0;\n }\n\n @include media.on-mobile {\n &__logo-wrapper {\n padding-top: spacing.space(1);\n padding-bottom: spacing.space(1);\n }\n\n &__contents {\n &.tna-container {\n padding-right: 0;\n padding-left: 0;\n }\n }\n\n &__navigation-button-wrapper {\n display: block;\n\n &.tna-column {\n padding-left: 0;\n }\n }\n\n &__navigation {\n flex-direction: column;\n align-items: stretch;\n\n &.tna-column {\n padding-right: 0;\n padding-left: 0;\n }\n }\n\n &__top-navigation-items {\n padding: spacing.space(0.5) spacing.space(1);\n\n justify-content: flex-start;\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &__top-navigation-item {\n margin: 0;\n }\n\n &__top-navigation-item-link {\n padding: spacing.space(0.5) 0;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"font-light\");\n }\n\n &:hover,\n &:focus-visible {\n @include colour.colour-font(\"font-dark\");\n }\n }\n\n &__navigation-items {\n width: 100%;\n\n flex-direction: column;\n gap: 0;\n\n background-color: rgb(255 255 255 / 10%);\n\n @include colour.colour-border(\"keyline-dark\", 2px, solid, top);\n @include colour.colour-border(\"keyline-dark\", 2px, solid, bottom);\n }\n\n &__navigation-item {\n margin: 0;\n\n display: block;\n\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n\n &:first-child {\n border-top: none;\n }\n }\n\n &__navigation-item-link {\n display: block;\n\n line-height: 1.75rem;\n\n &::after {\n width: 0;\n height: auto;\n\n top: 0;\n right: auto;\n }\n\n &--selected {\n &::after {\n @include colour.colour-border(\"keyline\", 0.5rem, solid, left);\n }\n }\n }\n }\n\n @include media.on-small {\n .tna-logo {\n width: 4rem;\n }\n\n &__logo-strapline {\n line-height: 1.25rem;\n }\n\n &__logo-wrapper,\n &__navigation-item-link,\n &__navigation-button-wrapper {\n padding-right: grid.gutter-width();\n }\n\n &__logo-wrapper,\n &__navigation-item-link {\n padding-left: grid.gutter-width();\n }\n\n &__top-navigation-items {\n padding-right: grid.gutter-width();\n padding-left: grid.gutter-width();\n }\n }\n\n @include media.on-tiny {\n &__navigation-button-wrapper,\n &__logo-wrapper {\n padding-right: grid.gutter-width-tiny();\n }\n\n &__logo-wrapper {\n padding-left: grid.gutter-width-tiny();\n }\n\n .tna-logo {\n width: 3.5rem;\n }\n\n &__logo-strapline {\n font-size: 0.9rem;\n line-height: 1.25;\n }\n\n &__navigation-button {\n @include typography.font-size(14);\n }\n\n &__top-navigation-items {\n gap: 0.5rem;\n }\n\n &__navigation-item-link {\n padding-right: grid.gutter-width-tiny();\n padding-left: calc(#{grid.gutter-width-tiny()} + 0.5rem);\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n @include colour.on-forced-colours {\n &__navigation-button {\n height: auto;\n\n line-height: 2;\n @include typography.font-size(18);\n @include typography.main-font-weight-bold;\n\n border: none;\n }\n\n &__hamburger {\n display: none;\n }\n }\n}\n","@use \"sass:math\";\n\n@use \"../../variables/borders\" as bordersVars;\n@use \"../../variables/grid\" as gridVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n$padding-units-top: 10 !default;\n$padding-units-bottom: 2 !default;\n$padding-units-narrow: 3 !default;\n$shift-units: 5 !default;\n\n.tna-hero {\n &__figure {\n min-height: clamp(\n #{spacing.space($padding-units-top + $padding-units-bottom)},\n calc(40vw - #{spacing.space($padding-units-top + $padding-units-bottom)}),\n 50rem\n );\n margin: 0;\n padding-top: spacing.space($padding-units-top);\n padding-bottom: spacing.space($padding-units-bottom);\n\n display: flex;\n align-items: flex-end;\n\n position: relative;\n }\n\n &__caption {\n width: 100%;\n\n overflow: visible;\n\n position: absolute;\n top: 0;\n right: 0;\n z-index: 5;\n }\n\n &__details {\n width: 100%;\n\n overflow: visible;\n }\n\n &__details-summary {\n position: absolute;\n top: spacing.space(0.5);\n right: spacing.space(0.5);\n z-index: 2;\n\n &:hover {\n @include colour.colour-font(\"font-dark\", true);\n\n @include colour.colour-background(\"background\", true);\n }\n }\n\n &__details-summary-icon {\n }\n\n &__information {\n width: 45rem;\n max-width: 75vw;\n padding: spacing.space(0.625) spacing.space(3.25) spacing.space(0.625)\n spacing.space(1);\n\n position: absolute;\n top: 0;\n right: 0;\n z-index: 1;\n\n @include colour.contrast;\n\n @include typography.font-size(16);\n\n border-bottom-left-radius: bordersVars.$rounded-border-radius;\n\n p + p {\n margin-top: spacing.space(0.5);\n }\n }\n\n &__image {\n position: absolute;\n inset: 0;\n z-index: 1;\n\n @include colour.image-loader-background;\n\n img {\n width: 100%;\n height: 100%;\n\n object-fit: cover;\n }\n }\n\n &__details[open] &__details-summary {\n width: 2rem;\n height: 2rem;\n padding: 0;\n\n font-size: 0;\n line-height: 2rem;\n text-align: center;\n\n border: none;\n\n @include colour.contrast;\n\n &::before,\n &::after {\n content: \"\";\n\n width: 1.5rem;\n height: 0.125rem;\n\n display: block;\n\n position: absolute;\n top: 50%;\n left: 50%;\n\n @include colour.colour-background(\"font-dark\");\n }\n\n &::before {\n transform: translate(-50%, -50%) rotate(45deg);\n }\n\n &::after {\n transform: translate(-50%, -50%) rotate(-45deg);\n }\n\n &:hover {\n &::before,\n &::after {\n height: 0.25rem;\n }\n }\n\n &-icon {\n font-size: 0;\n }\n }\n\n &__inner {\n position: relative;\n z-index: 4;\n }\n\n &:not(.tna-background-accent, .tna-background-tint) &__inner {\n // @include colour.contrast-on-mobile;\n }\n\n &__content {\n }\n\n &__content-inner {\n padding: spacing.space(2);\n\n @include colour.colour-background(\"background\");\n\n @include borders.rounded-border;\n }\n\n &__heading {\n }\n\n &__body {\n }\n\n &--split {\n }\n\n &--split &__figure {\n min-height: clamp(15rem, #{math.div(100vw, 3)}, 50rem);\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n\n align-items: center;\n\n box-sizing: border-box;\n }\n\n &--split &__information {\n max-width: 50%;\n\n box-sizing: border-box;\n }\n\n &--split &__image {\n left: 50%;\n }\n\n &--split &__content {\n width: 50%;\n padding-right: grid.gutter-width();\n }\n\n &--split &__content-inner {\n padding: 0;\n\n border-left: none;\n }\n\n @include media.on-larger-than-mobile {\n &--shift {\n margin-bottom: spacing.space($shift-units - $padding-units-bottom);\n }\n\n &--shift#{&}--narrow {\n margin-bottom: spacing.space($shift-units - $padding-units-narrow);\n }\n }\n\n &--shift &__content-inner {\n position: relative;\n top: spacing.space($shift-units);\n }\n\n &--narrow {\n }\n\n &--narrow &__figure {\n min-height: max(#{spacing.space($padding-units-narrow * 2)}, 20rem);\n padding-top: spacing.space($padding-units-narrow);\n padding-bottom: spacing.space($padding-units-narrow);\n }\n\n @include media.on-mobile {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n\n &.tna-background-tint,\n &.tna-background-contrast,\n &.tna-background-accent,\n &.tna-background-accent-light {\n border-bottom: none;\n }\n\n & &__figure {\n min-height: auto;\n padding: 0;\n\n flex-direction: column;\n }\n\n &__caption {\n order: 2;\n }\n\n &__details {\n }\n\n &__details-summary {\n top: spacing.space(0.25);\n right: spacing.space(0.25);\n }\n\n &__details[open] &__details-summary {\n top: spacing.space(0.5);\n right: spacing.space(0.5);\n }\n\n &__details-summary-icon {\n }\n\n &__information,\n &--split &__information {\n width: auto;\n max-width: none;\n\n left: 0;\n\n border-bottom-left-radius: 0;\n }\n\n &__image {\n width: 100%;\n\n position: static;\n\n order: 1;\n\n img {\n height: auto;\n }\n }\n\n &__inner {\n order: 3;\n }\n\n &__content {\n }\n\n &__content-inner {\n padding-right: 0;\n padding-left: 0;\n\n border-left: none;\n }\n\n &__heading {\n }\n\n &__body {\n margin-top: spacing.space(1);\n }\n\n &--shift {\n }\n\n &--split &__content {\n width: 100%;\n padding-right: grid.gutter-width-half();\n }\n\n &--shift &__content-inner {\n position: static;\n }\n\n &--split &__figure {\n min-height: auto;\n padding-top: 0;\n padding-bottom: 0;\n }\n\n &--split &__content-inner {\n padding-top: spacing.space(2);\n padding-bottom: spacing.space(2);\n }\n }\n}\n","@use \"sass:math\";\n@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-index-grid {\n @include spacing.space-above;\n\n &__heading {\n }\n\n &__items {\n @include spacing.space-above;\n\n margin-bottom: 0;\n\n display: flex;\n gap: spacing.space(2) 0;\n\n list-style: none;\n }\n\n &__item {\n @include colour.contrast;\n\n height: 100%;\n\n display: flex;\n flex-direction: column;\n\n position: relative;\n\n text-decoration: none;\n\n @include borders.rounded-border;\n\n .tna-background-contrast & {\n @include colour.accent;\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline-dark\", 1px);\n }\n }\n\n &__item-image {\n width: 100%;\n height: auto;\n\n @include colour.image-loader-background;\n\n pointer-events: none;\n\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n }\n\n &__item-content {\n padding: spacing.space(1);\n\n flex: 1;\n }\n\n &__item-label {\n position: absolute;\n top: spacing.space(0.5);\n left: spacing.space(0.5);\n }\n\n &__item-title {\n @include typography.main-font-weight-bold;\n text-decoration: underline;\n\n .tna-index-grid__item:hover & {\n &,\n &:link,\n &:visited {\n @include typography.interacted-text-decoration;\n }\n }\n }\n\n &__item-subtitle {\n @include colour.colour-font(\"font-light\");\n @include typography.font-size(16);\n }\n}\n","@use \"sass:math\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-pagination {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n justify-content: center;\n gap: spacing.space(1);\n\n @include spacing.space-above;\n\n &:not(:has(&__list)) {\n flex-wrap: nowrap;\n align-items: flex-start;\n justify-content: space-between;\n gap: spacing.space(2);\n }\n\n &__prev-next {\n &--prev {\n text-align: left;\n }\n\n &--next {\n text-align: right;\n }\n\n &-button {\n text-align: inherit;\n text-wrap: wrap;\n\n &--prev {\n }\n\n &--next {\n }\n\n &-text {\n display: block;\n }\n\n &-title {\n display: block;\n }\n\n &-description {\n padding-bottom: spacing.space(0.25);\n\n display: block;\n\n line-height: 1.25;\n @include typography.font-size(16);\n }\n\n &:has(&-description) {\n svg {\n margin-top: 0.35em;\n\n align-self: flex-start;\n }\n }\n }\n }\n\n :has(&__prev-next-button-description) &__prev-next-button-title {\n @include typography.main-font-weight-bold;\n }\n\n &:not(:has(&__list)) &__prev-next {\n flex: 1;\n\n &-button {\n padding: 0;\n\n border-width: 0;\n\n &-title {\n @include typography.main-font-weight-bold;\n }\n }\n }\n\n &__link {\n min-width: 1.5rem;\n padding-right: spacing.space(0.5);\n padding-left: spacing.space(0.5);\n }\n\n &__list {\n margin: 0;\n padding: 0;\n\n display: flex;\n align-items: center;\n gap: spacing.space(0.25);\n\n list-style: none;\n }\n\n &__item {\n &--ellipses {\n min-width: 2rem;\n padding: spacing.space(0.5);\n\n text-align: center;\n }\n\n &--current {\n }\n }\n\n @include media.on-mobile {\n flex-direction: column;\n gap: spacing.space(0.5);\n\n &:not(:has(&__list)) {\n align-items: flex-start;\n gap: spacing.space(1);\n }\n\n &:not(:has(&__list)) &__prev-next {\n &--next {\n text-align: left;\n }\n\n &-button {\n &--next {\n flex-direction: row;\n }\n }\n }\n }\n\n @include media.on-tiny {\n &:has(&__list) &__item {\n &:not(:is(&:first-child, &:last-child, &--current, &--ellipses)) {\n display: none;\n }\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-panel {\n padding: spacing.space(2);\n\n @include colour.green-accent;\n @include colour.accent;\n\n text-align: center;\n\n &__heading {\n }\n\n &__content {\n margin-top: spacing.space(1);\n\n @include typography.font-size(22);\n\n p + p {\n margin-top: spacing.space(0.5);\n }\n }\n\n @include media.on-mobile {\n padding: spacing.space(1);\n\n &__content {\n @include typography.font-size(18);\n }\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-phase-banner {\n @include colour.contrast;\n\n padding-top: spacing.space(0.5);\n padding-bottom: spacing.space(0.5);\n\n @include typography.font-size(16);\n\n .tna-container {\n align-items: center;\n }\n\n &__phase {\n @include typography.main-font-weight-bold;\n text-transform: uppercase;\n }\n\n &__message {\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/shadows\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-picture {\n @include spacing.space-above;\n margin-right: 0;\n margin-bottom: 0;\n margin-left: 0;\n padding: 0;\n\n &__image-wrapper {\n padding: spacing.space(1.5);\n\n position: relative;\n\n @include borders.rounded-border;\n }\n\n &__image-wrapper:has(+ #{&}__transcript:not([hidden])) {\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n }\n\n &__image {\n width: auto;\n height: auto;\n max-height: 40rem;\n margin: 0 auto;\n\n @include shadows.drop-shadow;\n\n @include colour.image-loader-background;\n }\n\n &__toggle-transcript {\n position: absolute;\n right: spacing.space(1);\n bottom: spacing.space(1);\n }\n\n &__transcript {\n @include colour.contrast;\n\n max-height: 25rem;\n\n padding: spacing.space(1.5);\n\n overflow: auto;\n\n border-radius: 0 0 bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &__caption {\n margin: 0 spacing.space(1);\n padding: spacing.space(1);\n\n @include typography.font-size(16);\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &--plain &__image-wrapper {\n padding: 0;\n }\n\n &--plain &__image {\n box-shadow: none;\n }\n\n @include media.on-tiny {\n &__image-wrapper {\n padding: 0;\n }\n\n .tna-column & {\n width: calc(100% + #{grid.gutter-width-tiny-double()});\n\n position: relative;\n left: -#{grid.gutter-width-tiny()};\n }\n\n &__image {\n max-height: 60rem;\n\n box-shadow: none;\n }\n\n &__caption {\n margin-right: 0;\n margin-left: 0;\n\n @include typography.font-size(14);\n }\n }\n\n @include colour.on-high-contrast-and-forced-colours {\n @include colour.colour-border(\"keyline-dark\", 1px);\n\n &__caption {\n margin: 0;\n\n border: none;\n }\n }\n}\n","@mixin drop-shadow {\n box-shadow:\n 0 0.25rem 1rem -0.25rem rgb(0 0 0 / 25%),\n 0 0.125rem 0.5rem -0.25rem rgb(0 0 0 / 75%);\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-quick-filters {\n @include spacing.space-above;\n\n display: flex;\n flex-wrap: wrap;\n gap: spacing.space(0.25) spacing.space(1.25);\n\n @include typography.font-size(16);\n list-style: none;\n\n &--stacked {\n flex-direction: column;\n align-items: flex-start;\n }\n\n &--filled {\n align-items: flex-start;\n }\n\n &--stacked#{&}--filled {\n align-items: stretch;\n }\n\n &__item {\n }\n\n &--filled &__item {\n flex: 1 1 auto;\n\n text-align: center;\n }\n\n &__link {\n display: block;\n\n position: relative;\n }\n\n &__item--selected &__link {\n @include typography.main-font-weight-bold;\n\n &::after {\n content: \"\";\n\n height: 0;\n\n position: absolute;\n top: 100%;\n right: 0;\n left: 0;\n @include colour.thick-keyline-accent(bottom);\n }\n }\n\n &--stacked &__item--selected &__link {\n padding-left: 0.75rem;\n\n border-bottom-width: 0;\n @include colour.thick-keyline-accent(left);\n\n &::after {\n display: none;\n }\n }\n}\n","@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/grid\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-secondary-navigation {\n display: flex;\n flex-flow: row wrap;\n\n gap: 0 spacing.space(2);\n\n line-height: 1.35;\n\n &__heading {\n padding-bottom: spacing.space(0.5);\n\n align-self: flex-end;\n\n line-height: inherit;\n\n @include colour.thick-keyline-transparent(bottom);\n }\n\n &__items {\n display: flex;\n align-items: flex-end;\n justify-content: flex-start;\n gap: spacing.space(2);\n\n list-style: none;\n }\n\n &__item {\n }\n\n &__link {\n width: 100%;\n padding: spacing.space(0.5) 0;\n\n display: block;\n\n box-sizing: border-box;\n\n line-height: inherit;\n\n text-align: left;\n text-decoration: underline;\n\n background: none;\n\n border: none;\n @include colour.thick-keyline-transparent(top);\n @include colour.thick-keyline-transparent(bottom);\n\n cursor: pointer;\n\n &,\n &:link {\n @include colour.colour-font(\"link\");\n }\n\n &:visited {\n @include colour.colour-font(\"link-visited\");\n }\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &__item--current &__link {\n @include colour.colour-font(\"font-base\");\n text-decoration: none;\n @include colour.thick-keyline-accent(bottom);\n\n &:hover {\n @include typography.interacted-text-decoration;\n }\n }\n\n &--overflow {\n overflow-x: auto;\n }\n\n &::after {\n content: \"\";\n\n width: 100%;\n\n @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &--no-bottom-border::after {\n display: none;\n }\n\n &--unindent::after {\n width: calc(100% + #{grid.gutter-width-double()});\n margin-right: -#{grid.gutter-width()};\n margin-left: -#{grid.gutter-width()};\n }\n\n @include media.on-smaller-than-large {\n flex-direction: column;\n gap: 0;\n\n &__heading {\n width: 100%;\n // padding-bottom: 0;\n border-bottom: none;\n\n align-self: flex-start;\n }\n }\n\n @include media.on-mobile {\n border-bottom: none;\n\n &__items {\n flex-direction: column;\n align-items: stretch;\n gap: 0;\n\n position: relative;\n // @include colour.colour-border(\"keyline\", 1px, solid, bottom);\n }\n\n &__item {\n position: relative;\n\n @include colour.colour-border(\"keyline\", 1px, solid, top);\n\n &--current {\n &::before {\n content: \"\";\n\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n @include colour.thick-keyline-accent(left);\n }\n }\n }\n\n &__link {\n padding: spacing.space(0.5) spacing.space(1);\n }\n\n &__link,\n &__item--current &__link {\n border-top: none;\n border-bottom: none;\n }\n\n &--overflow {\n overflow-x: visible;\n }\n }\n\n @include media.on-small {\n &--unindent &__items {\n margin-right: -#{grid.gutter-width()};\n margin-left: -#{grid.gutter-width()};\n }\n\n &--unindent &__link {\n padding: spacing.space(0.5) grid.gutter-width();\n }\n }\n\n @include media.on-tiny {\n &--unindent::after {\n width: calc(100% + #{grid.gutter-width-tiny-double()});\n }\n\n &--unindent::after,\n &--unindent &__items {\n margin-right: -#{grid.gutter-width-tiny()};\n margin-left: -#{grid.gutter-width-tiny()};\n }\n\n &--unindent &__link {\n padding: spacing.space(0.5) grid.gutter-width-tiny();\n }\n }\n}\n","@use \"../../variables/a11y\" as a11yVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-sidebar {\n width: 100%;\n\n @include typography.font-size(16);\n\n &__heading {\n }\n\n &__items,\n &__item-children {\n display: flex;\n flex-direction: column;\n gap: spacing.space(0.25);\n\n list-style: none;\n }\n\n &__items {\n padding-top: max(\n spacing.space(0.5),\n #{a11yVars.$focus-outline-total-width}\n );\n }\n\n &__item {\n }\n\n &__item-children {\n }\n\n &__item-child {\n }\n\n &__link {\n }\n\n /*\n * ------------------------------------------\n * Contents\n * ------------------------------------------\n */\n &--contents &__item-children {\n margin-top: spacing.space(0.25);\n padding-left: spacing.space(2);\n\n @include colour.thick-keyline(\"left\");\n }\n\n /*\n * ------------------------------------------\n * Sections\n * ------------------------------------------\n */\n &--sections &__items {\n line-height: 1.35;\n }\n\n &--sections &__link {\n padding: spacing.space(0.25) spacing.space(0.5);\n\n display: block;\n }\n\n &--sections &__item--current &__link {\n @include colour.accent;\n\n @include borders.rounded-border;\n }\n\n /*\n * ------------------------------------------\n * Pages\n * ------------------------------------------\n */\n &--pages &__item--current {\n padding-left: spacing.space(0.75);\n\n @include colour.thick-keyline-accent(left);\n }\n\n &--pages &__item--current > &__link {\n @include typography.main-font-weight-bold;\n }\n\n &--pages &__item-children {\n gap: 0;\n }\n\n /*\n * ------------------------------------------\n * Dashed items\n * ------------------------------------------\n */\n &--contents &__items,\n &--pages &__item-children {\n padding-left: spacing.space(1.5);\n }\n\n &--contents &__item,\n &--contents &__item-child,\n &--pages &__item-child {\n list-style: \"— \" outside;\n\n &::marker {\n @include colour.colour-font(\"font-light\");\n }\n }\n\n /*\n * ------------------------------------------\n * Sticky\n * ------------------------------------------\n */\n &--sticky {\n max-height: 100vh;\n max-height: 100dvh;\n\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n\n position: sticky;\n top: 0;\n }\n\n @include media.on-small {\n &--static-on-mobile,\n &--static-on-small {\n max-height: none;\n\n position: static;\n }\n }\n\n @include media.on-tiny {\n &--static-on-mobile,\n &--static-on-tiny {\n max-height: none;\n\n position: static;\n }\n }\n\n &--sticky &__items {\n margin: 0;\n padding-bottom: a11yVars.$focus-outline-total-width;\n\n overflow-y: auto;\n\n flex: 1;\n }\n\n &--sticky#{&}--contents &__items,\n &--sticky#{&}--pages &__items {\n padding-right: spacing.space(1);\n }\n\n &--sticky#{&}--sections &__items,\n &--sticky#{&}--pages &__items {\n width: calc(100% - #{a11yVars.$focus-outline-total-width});\n padding-right: a11yVars.$focus-outline-total-width;\n padding-left: a11yVars.$focus-outline-total-width;\n\n box-sizing: content-box;\n\n position: relative;\n left: -#{a11yVars.$focus-outline-total-width};\n }\n}\n","@use \"../../variables/a11y\" as a11yVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n@use \"../../components/button/button\" as button;\n\n.tna-skip-link {\n width: 1px !important;\n height: 1px !important;\n margin: 0 !important;\n padding: 0 !important;\n\n display: block !important;\n\n overflow: hidden !important;\n\n position: absolute !important;\n top: -100vh !important;\n left: -100vw !important;\n\n white-space: nowrap !important;\n\n background-color: colour.brand-colour(\"yellow\");\n\n border: a11yVars.$focus-outline-outer-width #000 solid;\n\n -webkit-clip-path: inset(50%) !important;\n clip-path: inset(50%) !important;\n\n &,\n &:link,\n &:visited {\n color: colour.brand-colour(\"black\");\n }\n\n &:active,\n &:focus {\n width: auto !important;\n height: auto !important;\n margin: inherit !important;\n padding: spacing.space(1) spacing.space(1.5) !important;\n\n overflow: visible !important;\n\n position: static !important;\n\n white-space: inherit !important;\n\n outline: none !important;\n\n box-shadow: inset 0 0 0 a11yVars.$focus-outline-inner-width #fff !important;\n\n -webkit-clip-path: none !important;\n clip-path: none !important;\n }\n\n &::after {\n content: \"\\203A\";\n content: \"\\203A\" / \"\";\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-tabs {\n @include spacing.space-above;\n\n &__list {\n margin: 0;\n padding: 0;\n\n display: flex;\n flex-wrap: nowrap;\n align-items: stretch;\n gap: spacing.space(0.5);\n\n position: relative;\n z-index: 2;\n\n list-style: none;\n }\n\n &--small &__list {\n gap: spacing.space(0.25);\n }\n\n &__button {\n padding: bordersVars.$thick-border-width 0;\n\n position: relative;\n\n text-align: center;\n\n background: transparent;\n\n border: none;\n\n border: 1px transparent solid;\n border-bottom: none;\n\n border-radius: bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius 0 0;\n\n cursor: pointer;\n\n &:active {\n @include a11y.focus-outline;\n }\n\n &[aria-selected=\"true\"] {\n padding-top: 0;\n\n @include colour.colour-border(\"keyline\");\n\n &::after {\n content: \"\";\n\n height: 1px;\n\n position: absolute;\n top: 100%;\n right: 0;\n left: 0;\n\n @include colour.colour-background(\"background\");\n }\n }\n }\n\n &__button-inner {\n padding: spacing.space(0.5) spacing.space(0.75);\n\n display: block;\n\n text-decoration: underline;\n\n @include colour.colour-font(\"font-dark\");\n }\n\n &--small &__button-inner {\n padding: spacing.space(0.25) spacing.space(0.5) spacing.space(0.125);\n\n @include typography.font-size(16);\n }\n\n &__button:hover &__button-inner,\n &__button:focus-visible &__button-inner {\n @include typography.interacted-text-decoration;\n }\n\n &__button[aria-selected=\"true\"] &__button-inner {\n text-decoration: none;\n\n @include colour.thick-keyline-accent(top);\n border-radius: #{bordersVars.$rounded-border-radius - 1px}\n #{bordersVars.$rounded-border-radius - 1px} 0 0;\n }\n\n &__items {\n display: flex;\n flex-direction: column;\n gap: spacing.space(2);\n\n position: relative;\n z-index: 1;\n }\n\n &__item {\n border-radius: 0 0 bordersVars.$rounded-border-radius\n bordersVars.$rounded-border-radius;\n }\n\n &--interactive &__item {\n padding: spacing.space(1);\n @include colour.colour-border(\"keyline\", 1px, solid);\n }\n\n &--tint#{&}--interactive &__button[aria-selected=\"true\"],\n &--tint#{&}--interactive &__button:hover &__button-inner,\n &--tint#{&}--interactive &__button:focus-visible &__button-inner,\n &--tint#{&}--interactive &__items {\n @include colour.tint;\n }\n}\n","@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-warning {\n @include spacing.space-above;\n padding: spacing.space(1);\n\n display: flex;\n align-items: flex-start;\n gap: spacing.space(1);\n\n @include colour.accent-light;\n @include colour.always-light;\n\n @include colour.colour-background-brand(\"cream\");\n\n @include colour.thick-keyline-brand(left, \"yellow\");\n @include borders.rounded-border;\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n\n @include media.on-tiny {\n flex-direction: column;\n gap: spacing.space(0.5);\n }\n\n &__heading {\n }\n\n &__heading-icon {\n width: 2rem;\n height: 2rem;\n\n display: block;\n\n line-height: 2rem;\n text-align: center;\n text-transform: lowercase;\n\n border-radius: 100%;\n\n @include colour.colour-font(\"font-dark\");\n @include typography.font-size(24);\n @include typography.main-font-weight-bold;\n\n @include colour.colour-border(\"font-dark\", 0.1875rem);\n\n @include media.on-mobile {\n width: 1.5rem;\n height: 1.5rem;\n\n @include typography.font-size(19);\n line-height: 1.5rem;\n\n @include colour.colour-border(\"font-dark\", 0.125rem);\n }\n }\n\n &__body {\n width: 100%;\n margin-top: 0;\n\n flex: 1;\n\n align-self: center;\n }\n}\n","@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-fieldset {\n @include spacing.space-above;\n\n &__inner {\n border: none;\n }\n\n &__legend {\n }\n\n &__heading {\n margin: 0;\n padding: 0;\n\n display: block;\n }\n\n & &__hint {\n margin-top: spacing.space(0.5);\n margin-bottom: spacing.space(1);\n }\n\n & &__error {\n margin-top: spacing.space(0.25);\n\n @include colour.colour-font(\"form-error-text\");\n @include typography.main-font-weight-bold;\n }\n\n &__body {\n margin-top: spacing.space(0.5);\n\n display: flex;\n flex-direction: column;\n gap: spacing.space(1);\n\n > * {\n margin-top: 0;\n }\n }\n\n &--error {\n padding-left: spacing.space(1);\n\n @include colour.thick-keyline-error(left);\n }\n\n &--small-hint &__hint {\n margin-top: spacing.space(0.125);\n margin-bottom: 0;\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-checkboxes {\n align-self: stretch;\n\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: spacing.space(1);\n\n &__item {\n padding-left: spacing.space(3);\n\n position: relative;\n\n input {\n width: 1px;\n height: 1px;\n margin: 0;\n padding: 0;\n\n position: absolute;\n top: -1px;\n left: -1px;\n\n opacity: 0;\n }\n\n &-label {\n display: block;\n\n line-height: 2rem;\n\n cursor: pointer;\n\n &::before,\n &::after {\n content: \"\";\n\n width: 2rem;\n\n position: absolute;\n top: 0;\n left: 0;\n }\n\n &::before {\n height: 2rem;\n\n display: block;\n box-sizing: border-box;\n\n z-index: 1;\n\n @include colour.colour-input;\n\n border-radius: 0.1px;\n @include borders.rounded-border;\n }\n\n &::after {\n width: 1.25rem;\n height: 0.5rem;\n margin-top: -0.1875rem;\n\n display: none;\n\n top: 1rem;\n left: 1rem;\n z-index: 2;\n\n @include colour.colour-border(\"input-background\", 0, solid);\n border-width: 0 0 formsVars.$checkbox-checkmark-width\n formsVars.$checkbox-checkmark-width;\n\n transform: translateX(-50%) translateY(-50%) rotate(-45deg);\n }\n }\n\n &-hint {\n display: block;\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n line-height: 1.25;\n }\n }\n\n &--small {\n gap: spacing.space(0.5);\n }\n\n &--small &__item {\n padding-left: spacing.space(2.25);\n\n &-label {\n line-height: 1.5rem;\n\n &::before {\n width: 1.5rem;\n height: 1.5rem;\n }\n\n &::after {\n width: 0.825rem;\n height: 0.375rem;\n margin-top: -0.125rem;\n\n top: 0.75rem;\n left: 0.75rem;\n }\n }\n }\n\n &--inline {\n flex-flow: row wrap;\n\n align-items: flex-start;\n gap: spacing.space(1) spacing.space(2);\n\n @include media.on-tiny {\n flex-direction: column;\n align-items: flex-start;\n }\n }\n\n &__item-label:active {\n &::before {\n @include a11y.active-outline;\n }\n }\n\n input:focus + &__item-label {\n &::before {\n @include a11y.focus-outline;\n }\n }\n\n input:checked + &__item-label {\n &::before {\n @include colour.colour-background(\"input-foreground\");\n }\n\n &::after {\n display: block;\n }\n }\n\n input:focus + &__item-label,\n &__item:hover &__item-label {\n &::before {\n box-shadow: 0 0 0 0.125rem var(--input-border);\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-date-input {\n display: flex;\n gap: spacing.space(1);\n\n &__item {\n &-label {\n padding-bottom: spacing.space(0.5);\n\n display: block;\n\n line-height: 1;\n\n @include typography.font-size(16);\n }\n\n &-input {\n width: 3rem;\n padding: 0 spacing.space(0.375);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n &--wider {\n width: 4.5rem;\n }\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n }\n }\n\n &--inline {\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-date-search {\n max-width: 100%;\n padding: 0 spacing.space(0.375);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--max-width {\n width: 100%;\n }\n}\n","@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-error-summary {\n @include spacing.space-above;\n padding: spacing.space(1);\n\n @include colour.colour-background(\"background\");\n\n @include colour.colour-border(\"form-error-border\", 0.3125rem, solid);\n @include borders.rounded-border;\n\n &:focus {\n @include a11y.focus-outline;\n }\n\n &__list {\n margin: spacing.space(0.5) 0 0;\n\n list-style: none;\n }\n\n &__item {\n }\n\n &__link {\n @include typography.main-font-weight-bold;\n\n &,\n &:link,\n &:visited {\n @include colour.colour-font(\"form-error-text\");\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-file-input {\n width: 100%;\n\n display: block;\n\n box-sizing: border-box;\n\n border-radius: 0.1px;\n\n cursor: pointer;\n\n &::file-selector-button {\n margin-right: spacing.space(0.5);\n\n cursor: inherit;\n }\n\n &__droppable {\n width: 100%;\n padding: spacing.space(0.5) spacing.space(1) spacing.space(1);\n\n box-sizing: border-box;\n\n position: relative;\n\n @include colour.colour-border(\n \"keyline\",\n formsVars.$form-field-border-width,\n dashed\n );\n @include borders.rounded-border;\n }\n\n &__droppable:has(&:focus-visible) {\n @include a11y.focus-outline;\n }\n\n &__droppable & {\n padding: spacing.space(1);\n\n position: absolute;\n inset: 0;\n z-index: 1;\n\n opacity: 0;\n }\n\n &__droppable-buttons {\n @include typography.font-size(14);\n line-height: 1.5rem;\n\n @include media.on-tiny {\n flex-direction: row;\n align-items: center;\n }\n }\n\n &__droppable-status {\n display: block;\n overflow: hidden;\n\n line-height: 2;\n text-overflow: ellipsis;\n\n white-space: nowrap;\n }\n\n &__droppable &:hover ~ &__droppable-buttons {\n .tna-button {\n &:not(.tna-button--plain) {\n @include colour.colour-font(\"button-hover-text\");\n text-decoration: none;\n\n background: transparent;\n }\n }\n }\n\n &__droppable--over,\n &__droppable--over-multiple {\n @include colour.colour-border(\"keyline-dark\");\n\n &::before {\n display: flex;\n align-items: center;\n justify-content: center;\n\n position: absolute;\n inset: spacing.space(0.5);\n z-index: 2;\n\n pointer-events: none;\n\n @include colour.green-accent;\n\n @include colour.colour-font(\"accent-font-base\");\n @include typography.main-font-weight-bold;\n\n @include colour.colour-background(\"accent-background\");\n }\n }\n\n &__droppable--over {\n &::before {\n content: \"Drop file here\";\n }\n }\n\n &__droppable--over-multiple {\n &::before {\n content: \"Drop files here\";\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/a11y\";\n@use \"../../tools/colour\";\n@use \"../../tools/media\";\n@use \"../../tools/spacing\";\n@use \"../../tools/typography\";\n\n.tna-radios {\n align-self: stretch;\n\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: spacing.space(1);\n\n &__item {\n padding-left: spacing.space(3);\n\n position: relative;\n\n input {\n width: 1px;\n height: 1px;\n margin: 0;\n padding: 0;\n\n position: absolute;\n top: -1px;\n left: -1px;\n\n opacity: 0;\n }\n\n &-label {\n display: block;\n\n line-height: 2rem;\n\n cursor: pointer;\n\n &::before,\n &::after {\n content: \"\";\n\n position: absolute;\n top: 0;\n left: 0;\n\n border-radius: 100%;\n }\n\n &::before {\n width: 2rem;\n height: 2rem;\n\n display: block;\n box-sizing: border-box;\n\n z-index: 1;\n\n @include colour.colour-input;\n }\n\n &::after {\n margin: 0.5rem;\n\n display: none;\n\n z-index: 2;\n\n @include colour.colour-background(\"input-foreground\");\n\n @include colour.colour-border(\"input-foreground\", 0.5rem);\n }\n }\n\n &-hint {\n display: block;\n\n @include typography.font-size(16);\n @include colour.colour-font(\"font-light\");\n line-height: 1.25;\n }\n }\n\n &--small {\n gap: spacing.space(0.5);\n }\n\n &--small &__item {\n padding-left: spacing.space(2.25);\n\n &-label {\n line-height: 1.5rem;\n\n &::before {\n width: 1.5rem;\n height: 1.5rem;\n }\n\n &::after {\n margin: 0.3125rem;\n\n @include colour.colour-border(\"input-foreground\", 0.4375rem);\n }\n }\n }\n\n &--inline {\n flex-flow: row wrap;\n\n align-items: flex-start;\n gap: spacing.space(1) spacing.space(2);\n\n @include media.on-tiny {\n flex-direction: column;\n align-items: flex-start;\n }\n }\n\n &__item-label:active {\n &::before {\n @include a11y.active-outline;\n }\n }\n\n input:focus + &__item-label {\n &::before {\n @include a11y.focus-outline;\n }\n }\n\n input:checked + &__item-label {\n &::after {\n display: block;\n }\n }\n\n input:focus + &__item-label,\n &__item:hover &__item-label {\n &::before {\n box-shadow: 0 0 0 0.125rem var(--input-border);\n }\n }\n}\n","@use \"../../variables/borders\" as bordersVars;\n@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n.tna-search-field {\n align-self: stretch;\n\n display: flex;\n gap: formsVars.$form-field-border-width;\n\n &__input {\n min-width: 8rem;\n width: 0;\n padding: 0 spacing.space(0.375);\n\n display: block;\n\n line-height: 2rem;\n\n flex: 1;\n\n @include colour.colour-input;\n @include borders.rounded-border;\n }\n\n &__button {\n padding-top: 0;\n padding-bottom: 0;\n }\n}\n","$form-field-border-width: 2px !default;\n$checkbox-checkmark-width: 0.1875rem !default;\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n.tna-select {\n max-width: 100%;\n height: calc(2rem + 6px);\n padding: 0 spacing.space(1) 0 spacing.space(0.5);\n\n display: block;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n // &--styled {\n // padding: 0 spacing.space(2.5) 0 spacing.space(0.75);\n\n // appearance: none;\n\n // background-image: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjUwMHB4IiBoZWlnaHQ9IjUwMHB4IiB2aWV3Qm94PSIwIDAgNTAwIDUwMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNTAwIDUwMCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHBvbHlnb24gcG9pbnRzPSIyNTAsNDAwIDUwLDEwMCA0NTAsMTAwIiBmaWxsPSIjMDAwIi8+PC9zdmc+\");\n // background-position: center right 0.5rem;\n // background-size: 0.75rem 0.75rem;\n // background-repeat: no-repeat;\n // }\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--s {\n width: 10rem;\n }\n\n &--m {\n width: 20rem;\n }\n\n &--l {\n width: 40rem;\n }\n\n &--xl {\n width: 80rem;\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n.tna-text-input {\n padding: 0 spacing.space(0.375);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 2rem;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n &,\n &-wrapper {\n width: 100%;\n }\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--xs {\n max-width: 5rem;\n }\n\n &--s {\n max-width: 10rem;\n }\n\n &--m {\n max-width: 20rem;\n }\n\n &--l {\n max-width: 40rem;\n }\n\n &--xl {\n max-width: 80rem;\n }\n\n &-wrapper & {\n flex: 1;\n }\n\n &-wrapper {\n display: flex;\n align-items: stretch;\n gap: formsVars.$form-field-border-width;\n\n .tna-button {\n white-space: nowrap;\n\n svg {\n width: 28px;\n margin: 0;\n }\n }\n }\n}\n","@use \"../../variables/forms\" as formsVars;\n@use \"../../tools/borders\";\n@use \"../../tools/colour\";\n@use \"../../tools/spacing\";\n\n$textarea-minimum-lines-visible: 5.5 !default;\n$textarea-line-height: 1.5rem !default;\n$textarea-vertical-padding: 0.25 !default;\n\n.tna-textarea {\n width: 100%;\n min-height: #{($textarea-line-height * $textarea-minimum-lines-visible) +\n (spacing.space($textarea-vertical-padding * 2))};\n padding: spacing.space($textarea-vertical-padding) spacing.space(0.5);\n\n display: block;\n box-sizing: border-box;\n\n line-height: 1.5rem;\n\n resize: vertical;\n\n @include colour.colour-input;\n\n @include borders.rounded-border;\n\n .tna-form-item--error & {\n @include colour.colour-border(\"form-error-border\");\n }\n\n &--m {\n max-width: 20rem;\n }\n\n &--l {\n max-width: 40rem;\n }\n\n &--xl {\n max-width: 80rem;\n }\n}\n"]}
|