[{"data":1,"prerenderedAt":765},["ShallowReactive",2],{"navigation":3,"\u002Fcore-concepts\u002Flayouts-and-pages":342,"\u002Fcore-concepts\u002Flayouts-and-pages-surround":760},[4,14,36,69,140,325],{"title":5,"path":6,"stem":7,"children":8},"Introduction","\u002Fgetting-started","1.getting-started\u002F1.index",[9,10],{"title":5,"path":6,"stem":7},{"title":11,"path":12,"stem":13},"Installation","\u002Fgetting-started\u002Finstallation","1.getting-started\u002F2.installation",{"title":15,"path":16,"stem":17,"children":18,"page":35},"Guides","\u002Fguides","2.guides",[19,23,27,31],{"title":20,"path":21,"stem":22},"Your First Layout","\u002Fguides\u002Fyour-first-layout","2.guides\u002F1.your-first-layout",{"title":24,"path":25,"stem":26},"Your First Page Template","\u002Fguides\u002Fyour-first-page-template","2.guides\u002F2.your-first-page-template",{"title":28,"path":29,"stem":30},"Your First Component","\u002Fguides\u002Fyour-first-component","2.guides\u002F3.your-first-component",{"title":32,"path":33,"stem":34},"Alternative UI Variants","\u002Fguides\u002Falternative-ui-variants","2.guides\u002F4.alternative-ui-variants",false,{"title":37,"path":38,"stem":39,"children":40,"page":35},"Core Concepts","\u002Fcore-concepts","3.core-concepts",[41,45,49,53,57,61,65],{"title":42,"path":43,"stem":44},"How It All Works","\u002Fcore-concepts\u002Farchitecture","3.core-concepts\u002F1.architecture",{"title":46,"path":47,"stem":48},"The Data Model","\u002Fcore-concepts\u002Fthe-data-model","3.core-concepts\u002F2.the-data-model",{"title":50,"path":51,"stem":52},"Layouts & Pages","\u002Fcore-concepts\u002Flayouts-and-pages","3.core-concepts\u002F3.layouts-and-pages",{"title":54,"path":55,"stem":56},"Dynamic Pages","\u002Fcore-concepts\u002Fdynamic-pages","3.core-concepts\u002F4.dynamic-pages",{"title":58,"path":59,"stem":60},"Components","\u002Fcore-concepts\u002Fcomponents","3.core-concepts\u002F5.components",{"title":62,"path":63,"stem":64},"Draft & Publish Workflow","\u002Fcore-concepts\u002Fdraft-and-publish","3.core-concepts\u002F6.draft-and-publish",{"title":66,"path":67,"stem":68},"The Admin Panel","\u002Fcore-concepts\u002Fadmin-panel","3.core-concepts\u002F7.admin-panel",{"title":70,"path":71,"stem":72,"children":73,"page":35},"Api","\u002Fapi","4.api",[74,78,116,120,124,128,132,136],{"title":75,"path":76,"stem":77},"Bundle Setup","\u002Fapi\u002Fbundle-setup","4.api\u002F1.bundle-setup",{"title":58,"path":79,"stem":80,"children":81,"page":35},"\u002Fapi\u002Fcomponents","4.api\u002F2.components",[82,86,103],{"title":83,"path":84,"stem":85},"Creating Components","\u002Fapi\u002Fcomponents\u002Fcreating-components","4.api\u002F2.components\u002F1.creating-components",{"title":87,"path":88,"stem":89,"children":90,"page":35},"Annotations","\u002Fapi\u002Fcomponents\u002Fannotations","4.api\u002F2.components\u002F2.annotations",[91,95,99],{"title":92,"path":93,"stem":94},"Publishable","\u002Fapi\u002Fcomponents\u002Fannotations\u002Fpublishable","4.api\u002F2.components\u002F2.annotations\u002F1.publishable",{"title":96,"path":97,"stem":98},"Uploadable","\u002Fapi\u002Fcomponents\u002Fannotations\u002Fuploadable","4.api\u002F2.components\u002F2.annotations\u002F2.uploadable",{"title":100,"path":101,"stem":102},"Timestamped","\u002Fapi\u002Fcomponents\u002Fannotations\u002Ftimestamped","4.api\u002F2.components\u002F2.annotations\u002F3.timestamped",{"title":104,"path":105,"stem":106,"children":107,"page":35},"Built Ins","\u002Fapi\u002Fcomponents\u002Fbuilt-ins","4.api\u002F2.components\u002F3.built-ins",[108,112],{"title":109,"path":110,"stem":111},"Collection Component","\u002Fapi\u002Fcomponents\u002Fbuilt-ins\u002Fcollection-component","4.api\u002F2.components\u002F3.built-ins\u002F1.collection-component",{"title":113,"path":114,"stem":115},"Form Component","\u002Fapi\u002Fcomponents\u002Fbuilt-ins\u002Fform-component","4.api\u002F2.components\u002F3.built-ins\u002F2.form-component",{"title":117,"path":118,"stem":119},"Dynamic & Nested Pages","\u002Fapi\u002Fdynamic-pages","4.api\u002F3.dynamic-pages",{"title":121,"path":122,"stem":123},"Users & Security","\u002Fapi\u002Fusers-and-security","4.api\u002F4.users-and-security",{"title":125,"path":126,"stem":127},"Data Fixtures","\u002Fapi\u002Fdata-fixtures","4.api\u002F5.data-fixtures",{"title":129,"path":130,"stem":131},"Configuration Reference","\u002Fapi\u002Fconfiguration","4.api\u002F6.configuration",{"title":133,"path":134,"stem":135},"Console Commands","\u002Fapi\u002Fconsole-commands","4.api\u002F7.console-commands",{"title":137,"path":138,"stem":139},"Debugging & Profiler","\u002Fapi\u002Fdebugging","4.api\u002F8.debugging",{"title":141,"path":142,"stem":143,"children":144,"page":35},"Nuxt Module","\u002Fnuxt-module","5.nuxt-module",[145,149,162,178,203,207,279,304,308],{"title":146,"path":147,"stem":148},"Module Setup","\u002Fnuxt-module\u002Fmodule-setup","5.nuxt-module\u002F1.module-setup",{"title":150,"path":151,"stem":152,"children":153,"page":35},"Configuration","\u002Fnuxt-module\u002Fconfiguration","5.nuxt-module\u002F2.configuration",[154,158],{"title":155,"path":156,"stem":157},"Nuxt Config","\u002Fnuxt-module\u002Fconfiguration\u002Fnuxt-config","5.nuxt-module\u002F2.configuration\u002F1.nuxt-config",{"title":159,"path":160,"stem":161},"Site Config & SEO","\u002Fnuxt-module\u002Fconfiguration\u002Fsite-config-and-seo","5.nuxt-module\u002F2.configuration\u002F2.site-config-and-seo",{"title":163,"path":164,"stem":165,"children":166,"page":35},"Building Your Ui","\u002Fnuxt-module\u002Fbuilding-your-ui","5.nuxt-module\u002F3.building-your-ui",[167,171,175],{"title":168,"path":169,"stem":170},"Layouts","\u002Fnuxt-module\u002Fbuilding-your-ui\u002Fcreating-layouts","5.nuxt-module\u002F3.building-your-ui\u002F1.creating-layouts",{"title":172,"path":173,"stem":174},"Page Templates","\u002Fnuxt-module\u002Fbuilding-your-ui\u002Fcreating-page-templates","5.nuxt-module\u002F3.building-your-ui\u002F2.creating-page-templates",{"title":83,"path":176,"stem":177},"\u002Fnuxt-module\u002Fbuilding-your-ui\u002Fcreating-components","5.nuxt-module\u002F3.building-your-ui\u002F3.creating-components",{"title":179,"path":180,"stem":181,"children":182,"page":35},"Cwa Components","\u002Fnuxt-module\u002Fcwa-components","5.nuxt-module\u002F4.cwa-components",[183,187,191,195,199],{"title":184,"path":185,"stem":186},"\u003CCwaComponentGroup \u002F>","\u002Fnuxt-module\u002Fcwa-components\u002Fcwa-component-group","5.nuxt-module\u002F4.cwa-components\u002F1.cwa-component-group",{"title":188,"path":189,"stem":190},"\u003CCwaPage \u002F>","\u002Fnuxt-module\u002Fcwa-components\u002Fcwa-page","5.nuxt-module\u002F4.cwa-components\u002F2.cwa-page",{"title":192,"path":193,"stem":194},"\u003CCwaLink \u002F>","\u002Fnuxt-module\u002Fcwa-components\u002Fcwa-link","5.nuxt-module\u002F4.cwa-components\u002F3.cwa-link",{"title":196,"path":197,"stem":198},"\u003CCwaImage \u002F>","\u002Fnuxt-module\u002Fcwa-components\u002Fcwa-image","5.nuxt-module\u002F4.cwa-components\u002F4.cwa-image",{"title":200,"path":201,"stem":202},"\u003CCwaDefaultLayout \u002F>","\u002Fnuxt-module\u002Fcwa-components\u002Fcwa-default-layout","5.nuxt-module\u002F4.cwa-components\u002F5.cwa-default-layout",{"title":204,"path":205,"stem":206},"The useCwa() API","\u002Fnuxt-module\u002Fcwa-api","5.nuxt-module\u002F5.cwa-api",{"title":208,"path":209,"stem":210,"children":211,"page":35},"Composables","\u002Fnuxt-module\u002Fcomposables","5.nuxt-module\u002F6.composables",[212,245,262],{"title":213,"path":214,"stem":215,"children":216,"page":35},"Component","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent","5.nuxt-module\u002F6.composables\u002F1.component",[217,221,225,229,233,237,241],{"title":218,"path":219,"stem":220},"Resource","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-resource","5.nuxt-module\u002F6.composables\u002F1.component\u002F1.use-cwa-resource",{"title":222,"path":223,"stem":224},"Collection Resource","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-collection-resource","5.nuxt-module\u002F6.composables\u002F1.component\u002F2.use-cwa-collection-resource",{"title":226,"path":227,"stem":228},"Image Resource","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-image-resource","5.nuxt-module\u002F6.composables\u002F1.component\u002F3.use-cwa-image-resource",{"title":230,"path":231,"stem":232},"Form","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-form","5.nuxt-module\u002F6.composables\u002F1.component\u002F4.use-cwa-form",{"title":234,"path":235,"stem":236},"Form Input","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-form-input","5.nuxt-module\u002F6.composables\u002F1.component\u002F5.use-cwa-form-input",{"title":238,"path":239,"stem":240},"Form Repeated","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-form-repeated","5.nuxt-module\u002F6.composables\u002F1.component\u002F6.use-cwa-form-repeated",{"title":242,"path":243,"stem":244},"Form Collection","\u002Fnuxt-module\u002Fcomposables\u002Fcomponent\u002Fuse-cwa-form-collection","5.nuxt-module\u002F6.composables\u002F1.component\u002F7.use-cwa-form-collection",{"title":246,"path":247,"stem":248,"children":249,"page":35},"Admin Manager","\u002Fnuxt-module\u002Fcomposables\u002Fadmin-manager","5.nuxt-module\u002F6.composables\u002F2.admin-manager",[250,254,258],{"title":251,"path":252,"stem":253},"Manager Tab","\u002Fnuxt-module\u002Fcomposables\u002Fadmin-manager\u002Fuse-cwa-resource-manager-tab","5.nuxt-module\u002F6.composables\u002F2.admin-manager\u002F1.use-cwa-resource-manager-tab",{"title":255,"path":256,"stem":257},"Resource Model","\u002Fnuxt-module\u002Fcomposables\u002Fadmin-manager\u002Fuse-cwa-resource-model","5.nuxt-module\u002F6.composables\u002F2.admin-manager\u002F2.use-cwa-resource-model",{"title":259,"path":260,"stem":261},"Resource Upload","\u002Fnuxt-module\u002Fcomposables\u002Fadmin-manager\u002Fuse-cwa-resource-upload","5.nuxt-module\u002F6.composables\u002F2.admin-manager\u002F3.use-cwa-resource-upload",{"title":263,"path":264,"stem":265,"children":266,"page":35},"Utilities","\u002Fnuxt-module\u002Fcomposables\u002Futilities","5.nuxt-module\u002F6.composables\u002F3.utilities",[267,271,275],{"title":268,"path":269,"stem":270},"Resource Endpoint","\u002Fnuxt-module\u002Fcomposables\u002Futilities\u002Fuse-cwa-resource-endpoint","5.nuxt-module\u002F6.composables\u002F3.utilities\u002F1.use-cwa-resource-endpoint",{"title":272,"path":273,"stem":274},"Query Model","\u002Fnuxt-module\u002Fcomposables\u002Futilities\u002Fuse-query-bound-model","5.nuxt-module\u002F6.composables\u002F3.utilities\u002F2.use-query-bound-model",{"title":276,"path":277,"stem":278},"Resource Route","\u002Fnuxt-module\u002Fcomposables\u002Futilities\u002Fuse-cwa-resource-route","5.nuxt-module\u002F6.composables\u002F3.utilities\u002F3.use-cwa-resource-route",{"title":280,"path":281,"stem":282,"children":283,"page":35},"Component Helpers","\u002Fnuxt-module\u002Fcomponent-helpers","5.nuxt-module\u002F7.component-helpers",[284,288,292,296,300],{"title":285,"path":286,"stem":287},"Images & Media","\u002Fnuxt-module\u002Fcomponent-helpers\u002Fimages-and-uploads","5.nuxt-module\u002F7.component-helpers\u002F1.images-and-uploads",{"title":289,"path":290,"stem":291},"Collections & Pagination","\u002Fnuxt-module\u002Fcomponent-helpers\u002Fcollections-and-pagination","5.nuxt-module\u002F7.component-helpers\u002F2.collections-and-pagination",{"title":293,"path":294,"stem":295},"HTML Content","\u002Fnuxt-module\u002Fcomponent-helpers\u002Fhtml-content","5.nuxt-module\u002F7.component-helpers\u002F3.html-content",{"title":297,"path":298,"stem":299},"Real-Time Updates","\u002Fnuxt-module\u002Fcomponent-helpers\u002Freal-time-updates","5.nuxt-module\u002F7.component-helpers\u002F4.real-time-updates",{"title":301,"path":302,"stem":303},"Forms","\u002Fnuxt-module\u002Fcomponent-helpers\u002Fforms","5.nuxt-module\u002F7.component-helpers\u002F5.forms",{"title":305,"path":306,"stem":307},"Authentication","\u002Fnuxt-module\u002Fauthentication","5.nuxt-module\u002F8.authentication",{"title":309,"path":310,"stem":311,"children":312,"page":35},"Cwa Layer","\u002Fnuxt-module\u002Fcwa-layer","5.nuxt-module\u002F9.cwa-layer",[313,317,321],{"title":314,"path":315,"stem":316},"Overview","\u002Fnuxt-module\u002Fcwa-layer\u002Foverview","5.nuxt-module\u002F9.cwa-layer\u002F1.overview",{"title":318,"path":319,"stem":320},"Auth Pages","\u002Fnuxt-module\u002Fcwa-layer\u002Fauth-pages","5.nuxt-module\u002F9.cwa-layer\u002F2.auth-pages",{"title":322,"path":323,"stem":324},"Admin Panel","\u002Fnuxt-module\u002Fcwa-layer\u002Fadmin-panel","5.nuxt-module\u002F9.cwa-layer\u002F3.admin-panel",{"title":326,"path":327,"stem":328,"children":329,"page":35},"Deployment","\u002Fdeployment","6.deployment",[330,334,338],{"title":331,"path":332,"stem":333},"Docker","\u002Fdeployment\u002Fdocker","6.deployment\u002F1.docker",{"title":335,"path":336,"stem":337},"Kubernetes & Helm","\u002Fdeployment\u002Fkubernetes","6.deployment\u002F2.kubernetes",{"title":339,"path":340,"stem":341},"CI\u002FCD","\u002Fdeployment\u002Fci-cd","6.deployment\u002F3.ci-cd",{"id":343,"title":50,"badge":344,"body":347,"description":753,"extension":754,"links":755,"meta":756,"navigation":757,"path":51,"seo":758,"stem":52,"__hash__":759},"docs\u002F3.core-concepts\u002F3.layouts-and-pages.md",{"label":345,"color":346},"Draft","amber",{"type":348,"value":349,"toc":742},"minimark",[350,354,363,366,402,409,414,417,602,621,624,628,641,649,653,656,659,666,673,676,679,685,688,699,701,705,708,727,738],[351,352,168],"h2",{"id":353},"layouts",[355,356,357,358,362],"p",{},"A layout is the ",[359,360,361],"strong",{},"outer shell"," every page shares: the header, navigation, footer. You create one (or a few) layouts and every page uses one.",[355,364,365],{},"In the API a Layout has:",[367,368,369,385,399],"ul",{},[370,371,372,376,377,380,381,384],"li",{},[373,374,375],"code",{},"uiComponent"," — the Vue file to render (",[373,378,379],{},"CwaLayoutPrimary"," → ",[373,382,383],{},"app\u002Fcwa\u002Flayouts\u002Fprimary.vue",")",[370,386,387,390,391,394,395,398],{},[373,388,389],{},"uiClassNames"," — CSS class options admins can choose (e.g. ",[373,392,393],{},"light"," or ",[373,396,397],{},"dark"," theme)",[370,400,401],{},"ComponentGroups — regions in the layout where components can live (e.g. a navigation region)",[355,403,404,405,408],{},"The module wraps your entire site in the current layout's Vue file. Your layout renders the header, then ",[373,406,407],{},"\u003Cslot \u002F>"," where the page content goes, then the footer.",[410,411,413],"h3",{"id":412},"componentgroups-in-layouts","ComponentGroups in Layouts",[355,415,416],{},"A layout can have its own regions. The most common: a navigation bar area.",[418,419,424],"pre",{"className":420,"code":421,"language":422,"meta":423,"style":423},"language-vue shiki shiki-themes github-light github-dark material-theme-palenight","\u003C!-- app\u002Fcwa\u002Flayouts\u002Fprimary.vue -->\n\u003Ctemplate>\n  \u003Cdiv>\n    \u003Cheader>\n      \u003CCwaComponentGroup\n        reference=\"navigation\"\n        :location=\"$cwa.resources.layoutIri.value\"\n        :allowed-components=\"['\u002Fcomponent\u002Fnavigation_links']\"\n      \u002F>\n    \u003C\u002Fheader>\n    \u003Cslot \u002F>\n    \u003Cfooter>...\u003C\u002Ffooter>\n  \u003C\u002Fdiv>\n\u003C\u002Ftemplate>\n","vue","",[373,425,426,435,449,460,471,480,501,516,531,537,547,561,583,593],{"__ignoreMap":423},[427,428,431],"span",{"class":429,"line":430},"line",1,[427,432,434],{"class":433},"sTBSN","\u003C!-- app\u002Fcwa\u002Flayouts\u002Fprimary.vue -->\n",[427,436,438,442,446],{"class":429,"line":437},2,[427,439,441],{"class":440},"sOvfz","\u003C",[427,443,445],{"class":444},"s-h7I","template",[427,447,448],{"class":440},">\n",[427,450,452,455,458],{"class":429,"line":451},3,[427,453,454],{"class":440},"  \u003C",[427,456,457],{"class":444},"div",[427,459,448],{"class":440},[427,461,463,466,469],{"class":429,"line":462},4,[427,464,465],{"class":440},"    \u003C",[427,467,468],{"class":444},"header",[427,470,448],{"class":440},[427,472,474,477],{"class":429,"line":473},5,[427,475,476],{"class":440},"      \u003C",[427,478,479],{"class":444},"CwaComponentGroup\n",[427,481,483,487,490,494,498],{"class":429,"line":482},6,[427,484,486],{"class":485},"sGtlX","        reference",[427,488,489],{"class":440},"=",[427,491,493],{"class":492},"seSrl","\"",[427,495,497],{"class":496},"sLL54","navigation",[427,499,500],{"class":492},"\"\n",[427,502,504,507,509,511,514],{"class":429,"line":503},7,[427,505,506],{"class":485},"        :location",[427,508,489],{"class":440},[427,510,493],{"class":492},[427,512,513],{"class":496},"$cwa.resources.layoutIri.value",[427,515,500],{"class":492},[427,517,519,522,524,526,529],{"class":429,"line":518},8,[427,520,521],{"class":485},"        :allowed-components",[427,523,489],{"class":440},[427,525,493],{"class":492},[427,527,528],{"class":496},"['\u002Fcomponent\u002Fnavigation_links']",[427,530,500],{"class":492},[427,532,534],{"class":429,"line":533},9,[427,535,536],{"class":440},"      \u002F>\n",[427,538,540,543,545],{"class":429,"line":539},10,[427,541,542],{"class":440},"    \u003C\u002F",[427,544,468],{"class":444},[427,546,448],{"class":440},[427,548,550,552,555,559],{"class":429,"line":549},11,[427,551,465],{"class":440},[427,553,554],{"class":444},"slot",[427,556,558],{"class":557},"s01iV"," \u002F",[427,560,448],{"class":440},[427,562,564,566,569,572,576,579,581],{"class":429,"line":563},12,[427,565,465],{"class":440},[427,567,568],{"class":444},"footer",[427,570,571],{"class":440},">",[427,573,575],{"class":574},"sPB8G","...",[427,577,578],{"class":440},"\u003C\u002F",[427,580,568],{"class":444},[427,582,448],{"class":440},[427,584,586,589,591],{"class":429,"line":585},13,[427,587,588],{"class":440},"  \u003C\u002F",[427,590,457],{"class":444},[427,592,448],{"class":440},[427,594,596,598,600],{"class":429,"line":595},14,[427,597,578],{"class":440},[427,599,445],{"class":444},[427,601,448],{"class":440},[355,603,604,605,608,609,612,613,616,617,620],{},"The ",[373,606,607],{},"reference"," is a stable name for this region. The ",[373,610,611],{},"location"," is the layout's own IRI (available from ",[373,614,615],{},"$cwa.resources.layoutIri","). The ",[373,618,619],{},"allowed-components"," restricts what types can be added to this group.",[622,623],"hr",{},[351,625,627],{"id":626},"pages","Pages",[355,629,630,631,634,635,637,638,640],{},"A page defines the ",[359,632,633],{},"content structure"," that renders inside a layout's ",[373,636,407],{},". It declares a ",[373,639,375],{}," that maps to one of your page template Vue files.",[418,642,647],{"className":643,"code":645,"language":646},[644],"language-text","Layout: CwaLayoutPrimary  →  primary.vue\n  Page: PrimaryPageTemplate  →  PrimaryPageTemplate.vue\n    ComponentGroup: \"primary\"\n      ComponentPosition  →  HtmlContent component\n      ComponentPosition  →  Image component\n","text",[373,648,645],{"__ignoreMap":423},[410,650,652],{"id":651},"static-pages","Static Pages",[355,654,655],{},"A static page is a one-to-one mapping: one URL → one page. The admin creates the layout structure once, adds components to the regions, and that's the page content.",[355,657,658],{},"Good for: Home page, About page, Contact page — anything with a fixed URL and manually managed content.",[355,660,661,662,665],{},"In the admin, static pages are shown in ",[359,663,664],{},"blue",".",[410,667,669,670,384],{"id":668},"template-pages-istemplate-true","Template Pages (",[373,671,672],{},"isTemplate: true",[355,674,675],{},"A template page has no URL of its own. Instead, it's a reusable structure that many PageData records share.",[355,677,678],{},"Good for: Blog articles, events, team members, products — anything where the same layout is used for many data records, each with its own URL.",[418,680,683],{"className":681,"code":682,"language":646},[644],"\u002Fblog\u002Farticle-one  →  BlogArticleData  →  BlogTemplate (isTemplate page)\n\u002Fblog\u002Farticle-two  →  BlogArticleData  →  BlogTemplate (same template)\n",[373,684,682],{"__ignoreMap":423},[355,686,687],{},"The template defines the layout regions. The actual content (title, body, image) comes from the PageData record.",[355,689,690,691,694,695,698],{},"In the admin, template pages are shown in ",[359,692,693],{},"yellow"," and PageData records in ",[359,696,697],{},"green"," — making it easy to see at a glance what is shared structure versus individual content.",[622,700],{},[351,702,704],{"id":703},"multiple-layouts","Multiple Layouts",[355,706,707],{},"You can have several layouts for different sections of the site:",[367,709,710,715,721],{},[370,711,712,714],{},[373,713,379],{}," — main site layout with full header\u002Ffooter",[370,716,717,720],{},[373,718,719],{},"CwaLayoutMinimal"," — stripped down, maybe for landing pages",[370,722,723,726],{},[373,724,725],{},"CwaLayoutDocs"," — sidebar navigation layout",[355,728,729,730,733,734,737],{},"Each is a separate Vue file in ",[373,731,732],{},"app\u002Fcwa\u002Flayouts\u002F",". Admins choose which layout a page uses from the ",[373,735,736],{},"\u002F_cwa\u002Fpages"," admin area.",[739,740,741],"style",{},"html pre.shiki code .sTBSN, html code.shiki .sTBSN{--shiki-light:#6A737D;--shiki-light-font-style:inherit;--shiki-default:#6A737D;--shiki-default-font-style:inherit;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sOvfz, html code.shiki .sOvfz{--shiki-light:#24292E;--shiki-default:#E1E4E8;--shiki-dark:#89DDFF}html pre.shiki code .s-h7I, html code.shiki .s-h7I{--shiki-light:#22863A;--shiki-default:#85E89D;--shiki-dark:#F07178}html pre.shiki code .sGtlX, html code.shiki .sGtlX{--shiki-light:#6F42C1;--shiki-default:#B392F0;--shiki-dark:#C792EA}html pre.shiki code .seSrl, html code.shiki .seSrl{--shiki-light:#032F62;--shiki-default:#9ECBFF;--shiki-dark:#89DDFF}html pre.shiki code .sLL54, html code.shiki .sLL54{--shiki-light:#032F62;--shiki-default:#9ECBFF;--shiki-dark:#C3E88D}html pre.shiki code .s01iV, html code.shiki .s01iV{--shiki-light:#B31D28;--shiki-light-font-style:italic;--shiki-default:#FDAEB7;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:inherit}html pre.shiki code .sPB8G, html code.shiki .sPB8G{--shiki-light:#24292E;--shiki-default:#E1E4E8;--shiki-dark:#BABED8}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}",{"title":423,"searchDepth":437,"depth":437,"links":743},[744,747,752],{"id":353,"depth":437,"text":168,"children":745},[746],{"id":412,"depth":451,"text":413},{"id":626,"depth":437,"text":627,"children":748},[749,750],{"id":651,"depth":451,"text":652},{"id":668,"depth":451,"text":751},"Template Pages (isTemplate: true)",{"id":703,"depth":437,"text":704},"How layouts form the site shell and pages define the content structure within — and the difference between static and template pages.","md",null,{},true,{"title":50,"description":753},"-dalBe7Xh5oUus7kksOit6XdmoLWhechIKnRdUiOBM8",[761,763],{"title":46,"path":47,"stem":48,"description":762,"children":-1},"The six resource types that form the content graph behind every CWA page — and how they chain together.",{"title":54,"path":55,"stem":56,"description":764,"children":-1},"How PageData records drive template pages — the pattern for blogs, events, products, and any repeating content type.",1782241278654]