We use the grid-template-columns and grid-template-rows properties to assign a particular number of columns and rows to the grid.
The grid-template-columns property lists the number and width of future grid columns:
/*
Assign three columns to the grid,
The first has a width of 100px,
The second has a width of 200px,
And the third is 300px in height.
*/
.element {
grid-template-columns: 100px 200px 300px;
}
The grid-template-rows property works similarly to grid-template-columns, only it tells the grid how many rows it will contain and what height they will be:
/*
Assign three rows to the grid,
The first has a height of 100px,
The second has a height of 200px,
And the third is 300px in height.
*/
.element {
grid-template-rows: 100px 200px 300px;
}
It is also possible to set a non-fixed size to grid cells. The auto value exists for this:
/*
Assign two columns to the grid,
The first has a non-fixed width,
And the second has a width of 100px.
*/
.element {
grid-template-columns: auto 100px;
}
/*
Assign three rows to the grid,
The first has a height of 100px,
The second has a non-fixed height,
And the third has a height of 200px.
*/
.element {
grid-template-rows: 100px auto 200px;
}
Given the properties that we assigned to grid-template-columns and grid-template-rows, the grid items can be inserted into a given grid automatically. At the same time, some of the grid items can also have clear coordinates in the grid. By combining the task of assigning explicit positions to grid items and automatically positioning them, we are able to create complex and flexible grids at the same time.
Another mechanism for creating grid layouts is to use the grid-template-areas and grid-area properties. When it is assigned as the value of the grid-template-areas property, it describes the grid structure visually “cell-by-cell”.
Example:
HTML:
<div class="grid-container">
<div class="grid-element-1"></div>
<div class="grid-element-2"></div>
<div class="grid-element-3"></div>
</div>
CSS:
.grid-container {
grid-template-areas:
"red yellow green"
"red yellow green"
"red yellow green";
}
.grid-element-1 {
grid-area: red;
}
.grid-element-2 {
grid-area: yellow;
}
.grid-element-3 {
grid-area: green;
}
The grid-template-areas property allows certain grid areas to be marked as empty. The period character . is used for this instead of the alphabetic name of the area.
.grid-container {
grid-template-areas:
". . green"
"red yellow green"
"red yellow green";
}
The gap property allows you to add uniform spacing between rows and columns. If you only want to add spacing between rows, then use the row-gap property, whereas column-gap is only used to specify spacing between columns.
.grid-container {
gap: 10px; /* Spacing of 10px between rows and columns */
column-gap: 20px; /* Spacing of 20px between columns */
row-gap: 30px; /* Spacing of 30px between rows */
}
Continue
<!DOCTYPE html><html lang="en" class="no-js"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1"><script>var b=document.documentElement.classList;b.remove('no-js');if(!window.Promise||!window.sessionStorage||!!sessionStorage.getItem('muller.v2')){b.add('muller')}</script><link rel="dns-prefetch" href="https://assets.htmlacademy.org"><script async src="https://www.googletagmanager.com/gtag/js?id=G-MXPCRXM48C"></script><script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-MXPCRXM48C');
</script><script type="text/javascript">
(function(e,t){var n=e.amplitude||{_q:[],_iq:{}};var r=t.createElement("script")
;r.type="text/javascript"
;r.integrity="sha384-d/yhnowERvm+7eCU79T/bYjOiMmq4F11ElWYLmt0ktvYEVgqLDazh4+gW9CKMpYW"
;r.crossOrigin="anonymous";r.async=true
;r.src="https://cdn.amplitude.com/libs/amplitude-5.2.2-min.gz.js"
;r.onload=function(){if(!e.amplitude.runQueuedFunctions){
console.log("[Amplitude] Error: could not load SDK")}}
;var i=t.getElementsByTagName("script")[0];i.parentNode.insertBefore(r,i)
;function s(e,t){e.prototype[t]=function(){
this._q.push([t].concat(Array.prototype.slice.call(arguments,0)));return this}}
var o=function(){this._q=[];return this}
;var a=["add","append","clearAll","prepend","set","setOnce","unset"]
;for(var u=0;u<a.length;u++){s(o,a[u])}n.Identify=o;var c=function(){this._q=[]
;return this}
;var l=["setProductId","setQuantity","setPrice","setRevenueType","setEventProperties"]
;for(var p=0;p<l.length;p++){s(c,l[p])}n.Revenue=c
;var d=["init","logEvent","logRevenue","setUserId","setUserProperties","setOptOut","setVersionName","setDomain","setDeviceId","setGlobalUserProperties","identify","clearUserProperties","setGroup","logRevenueV2","regenerateDeviceId","groupIdentify","onInit","logEventWithTimestamp","logEventWithGroups","setSessionId","resetSessionId"]
;function v(e){function t(t){e[t]=function(){
e._q.push([t].concat(Array.prototype.slice.call(arguments,0)))}}
for(var n=0;n<d.length;n++){t(d[n])}}v(n);n.getInstance=function(e){
e=(!e||e.length===0?"$default_instance":e).toLowerCase()
;if(!n._iq.hasOwnProperty(e)){n._iq[e]={_q:[]};v(n._iq[e])}return n._iq[e]}
;e.amplitude=n})(window,document);
amplitude.getInstance().init("df11525b6880a3c5e2af14f9b6238408", null,{
includeUtm: true,
includeGclid: true,
includeReferrer: true,
deviceIdFromUrlParam: true
}, function (instance) {
window.amplitudeLoaded = true;
});
</script><link rel="stylesheet" href="https://assets.htmlacademy.org/css/core.v284.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/profile.v236.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/course.v246.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/course-interface-light.v20.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/course-interface-en.v2.css"><script src="https://assets.htmlacademy.org/js/sentry.js" data-sentry="3774884cc81746ed84c0ba7c5cd4ac7b" data-project="26" data-version="2"></script><link rel="stylesheet" href="/css/custom.css"><link rel="stylesheet" href="/css/cookies.css"><link rel="preload" as="script" href="https://assets.htmlacademy.org/js/general.v274.js"><title>Summary of “Creating layouts using grids” — Introduction to Grid Layout — HTML Academy</title><meta name="csrf-token" content="52664caf322823086fca37a7326b9bd2a54"><meta property="og:type" content="website"><meta property="og:site_name" content="HTML Academy"><meta name="twitter:url" property="og:url" content="https://htmlacademy.org"><meta name="twitter:title" property="og:title" content="Interactive online courses HTML Academy"><meta name="twitter:description" property="og:description" content="Together we’ll learn how to work with real code, solve true-to-life problems, use cutting edge technologies. Minimum of boring theory and lots of practical tasks."><meta name="twitter:image" property="og:image" content="https://htmlacademy.org/og/htmlacademy.png"><meta name="twitter:card" content="summary_large_image"><link rel="canonical" href="https://htmlacademy.org/courses/layout/grid/summary-2"><meta name="theme-color" content="#2f358f"></head><body class="course-interface course-interface--light course-interface--full" data-base="/assets/courses/28/"><header class="page-header page-header--course"><div class="page-header__inner"><div class="page-header__top"><a class="page-header__logo" href="/" aria-label="HTML Academy Home"><img src="https://assets.htmlacademy.org/img/logo--small.svg?cs=1218aec0be4a5f23db79ad29a14e30f7f9fb9a25" width="24" height="36" alt="HTML Academy"></a><nav class="main-nav main-nav--mini" role="navigation"><div class="main-nav__course-nav"><a class="main-nav__course-item main-nav__course-button main-nav__course-button--prev" href="/courses/layout/grid/row-column-gap">Grid spacing: the row-gap and column-gap properties</a><div class="main-nav__course-item main-nav__course-list main-nav__course-list--collapsed"><b class="main-nav__course-title">Introduction to Grid Layout</b><span class="main-nav__course-stat">20/32</span><div class="main-nav__course-contents"><a class="main-nav__course-contents-link" href="/courses/layout/grid">Back to the list of tasks</a><ul class="main-nav__course-contents-list"><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-row-column-start">1. The grid item’s position: grid-row-start and grid-column-start</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-column-start-end">2. The grid item’s position: grid-column-start and grid-column-end</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-row-start-end">3. The grid item’s position: grid-row-start and grid-row-end</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-column-negative">4. Negative values for grid-column-start and grid-column-end</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-row-negative">5. Negative values for grid-row-start and grid-row-end</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-item-overlay">6. Grid item overlay</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-item-overlay-z-index">7. Overlaying grid items and the z-index property</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/summary-1">8. Summary of “Grids: positioning grid items”</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/building-bridges">9. Test: Building bridges</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-template-areas">10. Named grid areas: the grid-template-areas property</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-template-areas-empty">11. The grid-template-areas property and empty grid areas</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/auto-coordinates-column">12. Automatic coordinates of the grid items: columns</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/auto-coordinates-rows">13. Automatic coordinates of elements in the grid: columns and rows</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/combine-coordinates">14. Combining automatic and explicit coordinates</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/combine-coordinates-2">15. Combining automatic and explicit coordinates, part 2</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/unfixed-column">16. Unfixed column width</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/unfixed-column-row">17. Unfixed column and row widths</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/grid-gap">18. Grid spacing: the gap property</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/row-column-gap">19. Grid spacing: the row-gap and column-gap properties</a></li><li class="main-nav__course-contents-item main-nav__course-contents-item--current"><a href="/courses/layout/grid/summary-2">20. Summary of “Creating layouts using grids”</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/park-layout">21. Test: Laying out a park</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/page-layout">22. Laying out a simple page: creating a grid</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/page-header-layout">23. Laying out a simple page: the header</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/promo-layout">24. Laying out a simple blog page: the promo block</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/sidebar-layout">25. Laying out a simple page: the sidebar</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/blog-layout">26. Laying out a simple blog page</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/page-final">27. Laying out a simple page: the final step</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/online-store-layout">28. Laying out the online store catalog: creating an internal grid</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/sorting-layout">29. Laying out an online store catalog: the “Sort by” block</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/filter-layout">30. Laying out an online store catalog: the filter block</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/online-store-final">31. Laying out an online store catalog: the final step</a></li><li class="main-nav__course-contents-item"><a href="/courses/layout/grid/page-grid-layout">32. Test: The grid layout of a page</a></li></ul></div></div><a class="main-nav__course-item main-nav__course-button main-nav__course-button--next" href="/courses/layout/grid/park-layout">Test: Laying out a park</a></div><ul class="main-nav__list main-nav__list--user main-nav__list--user-guest"><li class="main-nav__item" itemprop="name"><a class="main-nav__link" href="/signup?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" title="Sign up" data-modal="open" data-value="register" itemprop="url"><span class="main-nav__icon" aria-hidden="true"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#user"></use></svg></span>Sign up</a></li><li class="main-nav__item main-nav__item--login" itemprop="name"><a class="main-nav__link" href="/login?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" title="Log in" data-modal="open" data-value="login" itemprop="url"><span class="main-nav__icon" aria-hidden="true"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#login"></use></svg></span>Log in</a></li></ul></nav></div></div></header><main class="course-container"><div class="course-theory"><div class="course-theory__inner"><section class="course-theory__content"><h1 class="course-theory__content-heading course-theory__content-heading--synopsis">Summary of “Creating layouts using grids”</h1><div class="course-theory__content-text"><p>We use the <code>grid-template-columns</code> and <code>grid-template-rows</code> properties to assign a particular number of columns and rows to the grid.</p><p>The <code>grid-template-columns</code> property lists the number and width of future grid columns:</p><pre><code>/*
Assign three columns to the grid,
The first has a width of 100px,
The second has a width of 200px,
And the third is 300px in height.
*/
.element {
grid-template-columns: 100px 200px 300px;
}</code></pre><p>The <code>grid-template-rows</code> property works similarly to <code>grid-template-columns</code>, only it tells the grid how many rows it will contain and what height they will be:
<pre><code>/*
Assign three rows to the grid,
The first has a height of 100px,
The second has a height of 200px,
And the third is 300px in height.
*/
.element {
grid-template-rows: 100px 200px 300px;
}</code></pre><p>It is also possible to set a non-fixed size to grid cells. The <code>auto</code> value exists for this:</p><pre><code>/*
Assign two columns to the grid,
The first has a non-fixed width,
And the second has a width of 100px.
*/
.element {
grid-template-columns: auto 100px;
}
/*
Assign three rows to the grid,
The first has a height of 100px,
The second has a non-fixed height,
And the third has a height of 200px.
*/
.element {
grid-template-rows: 100px auto 200px;
}</code></pre><p>Given the properties that we assigned to <code>grid-template-columns</code> and <code>grid-template-rows</code>, the grid items can be inserted into a given grid automatically. At the same time, some of the grid items can also have clear coordinates in the grid. By combining the task of assigning explicit positions to grid items and automatically positioning them, we are able to create complex and flexible grids at the same time.</p><p>Another mechanism for creating grid layouts is to use the <code>grid-template-areas</code> and <code>grid-area</code> properties. When it is assigned as the value of the <code>grid-template-areas</code> property, it describes the grid structure visually “cell-by-cell”.</p><p>Example:</p><style>
.example-table {
font-family: monospace;
border-collapse: collapse;
}
.example-table td {
width: 30px;
border: 1px solid;
text-align: center;
height: 30px;
}
.example-table .red {
background-color: red;
}
.example-table .yellow {
background-color: yellow;
}
.example-table .green {
background-color: green;
}
</style><table class="example-table"><tr><td class="red"></td><td class="yellow"></td><td class="green"></td></tr><tr><td class="red"></td><td class="yellow"></td><td class="green"></td></tr><tr><td class="red"></td><td class="yellow"></td><td class="green"></td></tr></table><p>HTML:</p><pre><code><div class="grid-container">
<div class="grid-element-1"></div>
<div class="grid-element-2"></div>
<div class="grid-element-3"></div>
</div></code></pre><p>CSS:</p><pre><code>.grid-container {
grid-template-areas:
"red yellow green"
"red yellow green"
"red yellow green";
}
.grid-element-1 {
grid-area: red;
}
.grid-element-2 {
grid-area: yellow;
}
.grid-element-3 {
grid-area: green;
}</code></pre><p>The <code>grid-template-areas</code> property allows certain grid areas to be marked as empty. The period character <code>.</code> is used for this instead of the alphabetic name of the area.</p><table class="example-table"><tr><td></td><td></td><td class="green"></td></tr><tr><td class="red"></td><td class="yellow"></td><td class="green"></td></tr><tr><td class="red"></td><td class="yellow"></td><td class="green"></td></tr></table><pre><code>.grid-container {
grid-template-areas:
". . green"
"red yellow green"
"red yellow green";
}</code></pre><p>The <code>gap</code> property allows you to add uniform spacing between rows and columns. If you only want to add spacing between rows, then use the <code>row-gap</code> property, whereas <code>column-gap</code> is only used to specify spacing between columns.</p><pre><code>.grid-container {
gap: 10px; /* Spacing of 10px between rows and columns */
column-gap: 20px; /* Spacing of 20px between columns */
row-gap: 30px; /* Spacing of 30px between rows */
}</code></pre><br><a class="button button--green button--large button--wide button--icon" href="/courses/layout/grid/park-layout"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#icon-check-bold"></use></svg>
Continue
</a></div></section></div></div><script
src="https://assets.htmlacademy.org/scripts/courses-spa/htmlacademy-task.v43.js"
data-assets-path="https://assets.htmlacademy.org/scripts/courses-spa/"
data-task-type="theory"
data-lang="en"
></script><script>HtmlacademyTask.setup(function(){});</script></main><footer class="page-footer page-footer--tiny"><div class="page-footer__inner"><p><a href="/docs/cookies">Cookies</a> ∙
<a href="/docs/privacy">Privacy</a> ∙
<a href="/docs/agreement">License Agreement</a> ∙
<a href="/docs/about">About</a> ∙
<a href="/contacts">Contacts</a> ∙
© HTML Academy OÜ, 2019−2026
</p><div class="page-footer__financial"><img src="https://assets.htmlacademy.org/img/visa-white.svg?cs=96e54ec8c587db9d4b1d8d328ffd87c2ebfd9555" alt="VISA" title="VISA" width="35" height="35"><img src="https://assets.htmlacademy.org/img/mastercard-horizontal.v2.svg" alt="Mastercard" title="Mastercard" width="35" height="35"></div></div></footer><div class="modal"><div class="modal__inner"><div class="modal__wrapper js-login hidden"><button class="modal__close icon-close" type="button" title="Close" data-modal="close"></button><h4 class="modal__header">Log in</h4><ul class="modal__social"><li class="modal__social-link modal__social-link--fb"><a href="/login/fb?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" rel="nofollow" title="Log in via Facebook"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#facebook"></use></svg></a></li><li class="modal__social-link modal__social-link--google"><a href="/login/google?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" rel="nofollow" title="Log in via Google"><svg height="30" width="30" viewBox="0 0 512 512" xmlns="http://www.w3.org/2000/svg"><path fill="#ffffff" d="M457.732 216.625c2.628 14.041 4.063 28.743 4.063 44.098C461.796 380.688 381.481 466 260.204 466c-116.023 0-210-93.977-210-210s93.977-210 210-210c56.704 0 104.077 20.867 140.44 54.73l-59.204 59.197v-.135c-22.046-21.002-50-31.762-81.236-31.762-69.297 0-125.604 58.537-125.604 127.841 0 69.29 56.306 127.968 125.604 127.968 62.87 0 105.653-35.965 114.46-85.312h-114.46v-81.902h197.528z"/></svg></a></li></ul><div class="modal__or"><span>or</span></div><form class="modal__form form" action="/login?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" autocomplete="off" method="post" data-submit="o"><input type="hidden" name="csrf_name" value="csrf69aea4fd8c598"><input type="hidden" name="csrf_value" value="dde9ff266694fffe056ae150b675d4bf"><div class="form__group"><label class="sr-only" for="login-email">Email</label><input class="field field--text field--full-width" type="email" name="email" placeholder="Email" value="" id="login-email"></div><div class="form__group"><label class="sr-only" for="login-password">Password</label><input class="field field--text field--full-width ym-disable-keys" type="password" name="password" placeholder="Password" id="login-password"></div><input class="button button--full-width" type="submit" data-submit-text="Logging in…" value="Log in"></form><p class="modal__forgot-password"><a href="/recover" data-modal="open" data-value="recover">Forgot your password?</a></p><a class="modal__bottom-link" href="/signup" data-modal="open" data-value="register">Sign up</a></div><div class="modal__wrapper js-register hidden"><button class="modal__close icon-close" type="button" title="Close" data-modal="close"></button><h4 class="modal__header">Sign up</h4><ul class="modal__social"><li class="modal__social-link modal__social-link--fb"><a href="/login/fb?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" rel="nofollow" title="Log in via Facebook"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#facebook"></use></svg></a></li><li class="modal__social-link modal__social-link--google"><a href="/login/google?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" rel="nofollow" title="Log in via Google"><svg height="30" width="30" viewBox="0 0 512 512" xmlns="http://www.w3.org/2000/svg"><path fill="#ffffff" d="M457.732 216.625c2.628 14.041 4.063 28.743 4.063 44.098C461.796 380.688 381.481 466 260.204 466c-116.023 0-210-93.977-210-210s93.977-210 210-210c56.704 0 104.077 20.867 140.44 54.73l-59.204 59.197v-.135c-22.046-21.002-50-31.762-81.236-31.762-69.297 0-125.604 58.537-125.604 127.841 0 69.29 56.306 127.968 125.604 127.968 62.87 0 105.653-35.965 114.46-85.312h-114.46v-81.902h197.528z"/></svg></a></li></ul><div class="modal__or"><span>or</span></div><form class="modal__form form" action="/signup?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" autocomplete="off" method="post"><input type="hidden" name="csrf_name" value="csrf69aea4fd8c598"><input type="hidden" name="csrf_value" value="dde9ff266694fffe056ae150b675d4bf"><div class="form__group"><label class="sr-only" for="email">
Email
<span class="required"><span class="sr-only">Required field</span><span class="required__star">*</span></span></label><div class="form__group-fields"><input class="field field--text field--full-width" type="email" name="email" value="" id="email" required placeholder="Email"></div></div><div class="form__group"><label class="sr-only" for="password">
Password
<span class="required"><span class="sr-only">Required field</span><span class="required__star">*</span></span></label><div class="form__group-fields"><input class="field field--text field--full-width" type="password" name="password" value="" id="password" required placeholder="Password"></div></div><div class="form__group"><label class="checkbox"><input class="checkbox__input" type="checkbox" name="agreement" value="1" required><span class="checkbox__text"><span>By signing up, you agree to our <a href="/docs/agreement" target="_blank">License Agreement</a> and <a href="/docs/privacy" target="_blank">Privacy Policy</a>.</span></span></label></div><input class="button button--full-width" type="submit" data-submit-text="Signing up…" value="Sign up"></form><a class="modal__bottom-link" href="/login?redirect_url=%2Fcourses%2Flayout%2Fgrid%2Fsummary-2" data-modal="open" data-value="login">Log in</a></div><div class="modal__wrapper modal__wrapper--no-btn-bottom js-recover hidden"><button class="modal__close icon-close" type="button" title="Close" data-modal="close"></button><h4 class="modal__header">Restore access</h4><p class="modal__text-accent">Have you forgotten your password or lost access to your profile? Enter your email connected to your profile and we will send you a link to restore access.</p><form class="modal__form form" action="/recover" autocomplete="off" method="post" data-submit="o"><input type="hidden" name="csrf_name" value="csrf69aea4fd8c598"><input type="hidden" name="csrf_value" value="dde9ff266694fffe056ae150b675d4bf"><div class="form__group"><label class="sr-only" for="recovery-email">Email</label><input class="field field--text field--full-width" type="email" name="email" placeholder="Email" value="" id="recovery-email"></div><script src='https://www.google.com/recaptcha/api.js'></script><div class="form__group"><div class="g-recaptcha" data-sitekey="6LetCTEqAAAAANROWtPzfC7Rfg9iIRiRt2k2FPn7"></div></div><input class="button button--full-width" type="submit" data-submit-text="Sending…" value="Send"></form><p class="modal__text">Forgot to connect your email to the profile? Email us and we’ll help.</p></div></div></div><script async src="https://assets.htmlacademy.org/js/general.v274.js" data-assets="https://assets.htmlacademy.org" data-require="toggle,navigation-courses,modal,form,nav"></script></body></html>