site
| |

Como criar seu primeiro site do zero com HTML e CSS

Criar um site do zero é a porta de entrada para o universo do desenvolvimento web. Neste tutorial, você vai aprender a montar um projeto completo baseado no exemplo Top 10 Melhores Jogos do ano, usando as duas principais tecnologias front‑end:

  • HTML5 para a estrutura semântica

  • CSS3 para o estilo e responsividade

Ao final, você terá um site completo, pronto para hospedar no GitHub Pages, Netlify ou qualquer outro serviço de hosting.

Passo 1 — Estrutura de arquivos

Crie uma pasta para o projeto (top10-jogos) e, dentro dela, organize:

				
					top10-jogos/
├── index.html
├── style.css

				
			

Passo 2 — Criar template básico HTML e CSS

  • Abra o index.html.

  • Insira a declaração do tipo de documento e as tags principais:

				
					<!DOCTYPE html>
<html lang="pt-br">
<head>
  
</head>
<body>
   <script data-no-optimize="1">window.lazyLoadOptions=Object.assign({},{threshold:300},window.lazyLoadOptions||{});!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).LazyLoad=e()}(this,function(){"use strict";function e(){return(e=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n,a=arguments[e];for(n in a)Object.prototype.hasOwnProperty.call(a,n)&&(t[n]=a[n])}return t}).apply(this,arguments)}function o(t){return e({},at,t)}function l(t,e){return t.getAttribute(gt+e)}function c(t){return l(t,vt)}function s(t,e){return function(t,e,n){e=gt+e;null!==n?t.setAttribute(e,n):t.removeAttribute(e)}(t,vt,e)}function i(t){return s(t,null),0}function r(t){return null===c(t)}function u(t){return c(t)===_t}function d(t,e,n,a){t&&(void 0===a?void 0===n?t(e):t(e,n):t(e,n,a))}function f(t,e){et?t.classList.add(e):t.className+=(t.className?" ":"")+e}function _(t,e){et?t.classList.remove(e):t.className=t.className.replace(new RegExp("(^|\\s+)"+e+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")}function g(t){return t.llTempImage}function v(t,e){!e||(e=e._observer)&&e.unobserve(t)}function b(t,e){t&&(t.loadingCount+=e)}function p(t,e){t&&(t.toLoadCount=e)}function n(t){for(var e,n=[],a=0;e=t.children[a];a+=1)"SOURCE"===e.tagName&&n.push(e);return n}function h(t,e){(t=t.parentNode)&&"PICTURE"===t.tagName&&n(t).forEach(e)}function a(t,e){n(t).forEach(e)}function m(t){return!!t[lt]}function E(t){return t[lt]}function I(t){return delete t[lt]}function y(e,t){var n;m(e)||(n={},t.forEach(function(t){n[t]=e.getAttribute(t)}),e[lt]=n)}function L(a,t){var o;m(a)&&(o=E(a),t.forEach(function(t){var e,n;e=a,(t=o[n=t])?e.setAttribute(n,t):e.removeAttribute(n)}))}function k(t,e,n){f(t,e.class_loading),s(t,st),n&&(b(n,1),d(e.callback_loading,t,n))}function A(t,e,n){n&&t.setAttribute(e,n)}function O(t,e){A(t,rt,l(t,e.data_sizes)),A(t,it,l(t,e.data_srcset)),A(t,ot,l(t,e.data_src))}function w(t,e,n){var a=l(t,e.data_bg_multi),o=l(t,e.data_bg_multi_hidpi);(a=nt&&o?o:a)&&(t.style.backgroundImage=a,n=n,f(t=t,(e=e).class_applied),s(t,dt),n&&(e.unobserve_completed&&v(t,e),d(e.callback_applied,t,n)))}function x(t,e){!e||0<e.loadingCount||0<e.toLoadCount||d(t.callback_finish,e)}function M(t,e,n){t.addEventListener(e,n),t.llEvLisnrs[e]=n}function N(t){return!!t.llEvLisnrs}function z(t){if(N(t)){var e,n,a=t.llEvLisnrs;for(e in a){var o=a[e];n=e,o=o,t.removeEventListener(n,o)}delete t.llEvLisnrs}}function C(t,e,n){var a;delete t.llTempImage,b(n,-1),(a=n)&&--a.toLoadCount,_(t,e.class_loading),e.unobserve_completed&&v(t,n)}function R(i,r,c){var l=g(i)||i;N(l)||function(t,e,n){N(t)||(t.llEvLisnrs={});var a="VIDEO"===t.tagName?"loadeddata":"load";M(t,a,e),M(t,"error",n)}(l,function(t){var e,n,a,o;n=r,a=c,o=u(e=i),C(e,n,a),f(e,n.class_loaded),s(e,ut),d(n.callback_loaded,e,a),o||x(n,a),z(l)},function(t){var e,n,a,o;n=r,a=c,o=u(e=i),C(e,n,a),f(e,n.class_error),s(e,ft),d(n.callback_error,e,a),o||x(n,a),z(l)})}function T(t,e,n){var a,o,i,r,c;t.llTempImage=document.createElement("IMG"),R(t,e,n),m(c=t)||(c[lt]={backgroundImage:c.style.backgroundImage}),i=n,r=l(a=t,(o=e).data_bg),c=l(a,o.data_bg_hidpi),(r=nt&&c?c:r)&&(a.style.backgroundImage='url("'.concat(r,'")'),g(a).setAttribute(ot,r),k(a,o,i)),w(t,e,n)}function G(t,e,n){var a;R(t,e,n),a=e,e=n,(t=Et[(n=t).tagName])&&(t(n,a),k(n,a,e))}function D(t,e,n){var a;a=t,(-1<It.indexOf(a.tagName)?G:T)(t,e,n)}function S(t,e,n){var a;t.setAttribute("loading","lazy"),R(t,e,n),a=e,(e=Et[(n=t).tagName])&&e(n,a),s(t,_t)}function V(t){t.removeAttribute(ot),t.removeAttribute(it),t.removeAttribute(rt)}function j(t){h(t,function(t){L(t,mt)}),L(t,mt)}function F(t){var e;(e=yt[t.tagName])?e(t):m(e=t)&&(t=E(e),e.style.backgroundImage=t.backgroundImage)}function P(t,e){var n;F(t),n=e,r(e=t)||u(e)||(_(e,n.class_entered),_(e,n.class_exited),_(e,n.class_applied),_(e,n.class_loading),_(e,n.class_loaded),_(e,n.class_error)),i(t),I(t)}function U(t,e,n,a){var o;n.cancel_on_exit&&(c(t)!==st||"IMG"===t.tagName&&(z(t),h(o=t,function(t){V(t)}),V(o),j(t),_(t,n.class_loading),b(a,-1),i(t),d(n.callback_cancel,t,e,a)))}function $(t,e,n,a){var o,i,r=(i=t,0<=bt.indexOf(c(i)));s(t,"entered"),f(t,n.class_entered),_(t,n.class_exited),o=t,i=a,n.unobserve_entered&&v(o,i),d(n.callback_enter,t,e,a),r||D(t,n,a)}function q(t){return t.use_native&&"loading"in HTMLImageElement.prototype}function H(t,o,i){t.forEach(function(t){return(a=t).isIntersecting||0<a.intersectionRatio?$(t.target,t,o,i):(e=t.target,n=t,a=o,t=i,void(r(e)||(f(e,a.class_exited),U(e,n,a,t),d(a.callback_exit,e,n,t))));var e,n,a})}function B(e,n){var t;tt&&!q(e)&&(n._observer=new IntersectionObserver(function(t){H(t,e,n)},{root:(t=e).container===document?null:t.container,rootMargin:t.thresholds||t.threshold+"px"}))}function J(t){return Array.prototype.slice.call(t)}function K(t){return t.container.querySelectorAll(t.elements_selector)}function Q(t){return c(t)===ft}function W(t,e){return e=t||K(e),J(e).filter(r)}function X(e,t){var n;(n=K(e),J(n).filter(Q)).forEach(function(t){_(t,e.class_error),i(t)}),t.update()}function t(t,e){var n,a,t=o(t);this._settings=t,this.loadingCount=0,B(t,this),n=t,a=this,Y&&window.addEventListener("online",function(){X(n,a)}),this.update(e)}var Y="undefined"!=typeof window,Z=Y&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),tt=Y&&"IntersectionObserver"in window,et=Y&&"classList"in document.createElement("p"),nt=Y&&1<window.devicePixelRatio,at={elements_selector:".lazy",container:Z||Y?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_poster:"poster",class_applied:"applied",class_loading:"litespeed-loading",class_loaded:"litespeed-loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1},ot="src",it="srcset",rt="sizes",ct="poster",lt="llOriginalAttrs",st="loading",ut="loaded",dt="applied",ft="error",_t="native",gt="data-",vt="ll-status",bt=[st,ut,dt,ft],pt=[ot],ht=[ot,ct],mt=[ot,it,rt],Et={IMG:function(t,e){h(t,function(t){y(t,mt),O(t,e)}),y(t,mt),O(t,e)},IFRAME:function(t,e){y(t,pt),A(t,ot,l(t,e.data_src))},VIDEO:function(t,e){a(t,function(t){y(t,pt),A(t,ot,l(t,e.data_src))}),y(t,ht),A(t,ct,l(t,e.data_poster)),A(t,ot,l(t,e.data_src)),t.load()}},It=["IMG","IFRAME","VIDEO"],yt={IMG:j,IFRAME:function(t){L(t,pt)},VIDEO:function(t){a(t,function(t){L(t,pt)}),L(t,ht),t.load()}},Lt=["IMG","IFRAME","VIDEO"];return t.prototype={update:function(t){var e,n,a,o=this._settings,i=W(t,o);{if(p(this,i.length),!Z&&tt)return q(o)?(e=o,n=this,i.forEach(function(t){-1!==Lt.indexOf(t.tagName)&&S(t,e,n)}),void p(n,0)):(t=this._observer,o=i,t.disconnect(),a=t,void o.forEach(function(t){a.observe(t)}));this.loadAll(i)}},destroy:function(){this._observer&&this._observer.disconnect(),K(this._settings).forEach(function(t){I(t)}),delete this._observer,delete this._settings,delete this.loadingCount,delete this.toLoadCount},loadAll:function(t){var e=this,n=this._settings;W(t,n).forEach(function(t){v(t,e),D(t,n,e)})},restoreAll:function(){var e=this._settings;K(e).forEach(function(t){P(t,e)})}},t.load=function(t,e){e=o(e);D(t,e)},t.resetStatus=function(t){i(t)},t}),function(t,e){"use strict";function n(){e.body.classList.add("litespeed_lazyloaded")}function a(){console.log("[LiteSpeed] Start Lazy Load"),o=new LazyLoad(Object.assign({},t.lazyLoadOptions||{},{elements_selector:"[data-lazyloaded]",callback_finish:n})),i=function(){o.update()},t.MutationObserver&&new MutationObserver(i).observe(e.documentElement,{childList:!0,subtree:!0,attributes:!0})}var o,i;t.addEventListener?t.addEventListener("load",a,!1):t.attachEvent("onload",a)}(window,document);</script><script data-no-optimize="1">window.litespeed_ui_events=window.litespeed_ui_events||["mouseover","click","keydown","wheel","touchmove","touchstart"];var urlCreator=window.URL||window.webkitURL;function litespeed_load_delayed_js_force(){console.log("[LiteSpeed] Start Load JS Delayed"),litespeed_ui_events.forEach(e=>{window.removeEventListener(e,litespeed_load_delayed_js_force,{passive:!0})}),document.querySelectorAll("iframe[data-litespeed-src]").forEach(e=>{e.setAttribute("src",e.getAttribute("data-litespeed-src"))}),"loading"==document.readyState?window.addEventListener("DOMContentLoaded",litespeed_load_delayed_js):litespeed_load_delayed_js()}litespeed_ui_events.forEach(e=>{window.addEventListener(e,litespeed_load_delayed_js_force,{passive:!0})});async function litespeed_load_delayed_js(){let t=[];for(var d in document.querySelectorAll('script[type="litespeed/javascript"]').forEach(e=>{t.push(e)}),t)await new Promise(e=>litespeed_load_one(t[d],e));document.dispatchEvent(new Event("DOMContentLiteSpeedLoaded")),window.dispatchEvent(new Event("DOMContentLiteSpeedLoaded"))}function litespeed_load_one(t,e){console.log("[LiteSpeed] Load ",t);var d=document.createElement("script");d.addEventListener("load",e),d.addEventListener("error",e),t.getAttributeNames().forEach(e=>{"type"!=e&&d.setAttribute("data-src"==e?"src":e,t.getAttribute(e))});let a=!(d.type="text/javascript");!d.src&&t.textContent&&(d.src=litespeed_inline2src(t.textContent),a=!0),t.after(d),t.remove(),a&&e()}function litespeed_inline2src(t){try{var d=urlCreator.createObjectURL(new Blob([t.replace(/^(?:<!--)?(.*?)(?:-->)?$/gm,"$1")],{type:"text/javascript"}))}catch(e){d="data:text/javascript;base64,"+btoa(t.replace(/^(?:<!--)?(.*?)(?:-->)?$/gm,"$1"))}return d}</script><script data-no-optimize="1">var litespeed_vary=document.cookie.replace(/(?:(?:^|.*;\s*)_lscache_vary\s*\=\s*([^;]*).*$)|^.*$/,"");litespeed_vary||fetch("/wp-content/plugins/litespeed-cache/guest.vary.php",{method:"POST",cache:"no-cache",redirect:"follow"}).then(e=>e.json()).then(e=>{console.log(e),e.hasOwnProperty("reload")&&"yes"==e.reload&&(sessionStorage.setItem("litespeed_docref",document.referrer),window.location.reload(!0))});</script><script data-optimized="1" type="litespeed/javascript" data-src="https://galaxialgorithm.com/wp-content/litespeed/js/db9fb283f8937d9f0ac41cb24c82260c.js?ver=3d856"></script></body>
</html>

				
			
  • Abra o style.css.

  • Insira o seletor universal (*) para aplicar as regras a todos os elementos da página, e evitar inconsistências de margens e paddings entre navegadores.

				
					/* style.css */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Segoe UI', sans-serif;
  color: #fff;
  background: linear-gradient(135deg, #1a1a2e, #16213e);
  min-height: 100vh;
  background-attachment: fixed;
  background-size: cover;
  line-height: 1.6;
  padding: 0 20px;
}

				
			

Propriedades do *

  • margin: 0; → zera todas as margens externas dos elementos.

  • padding: 0; → zera todo o espaçamento interno dos elementos.

  • box-sizing: border-box; → faz com que o width/height inclua padding e bordas no cálculo.

Propriedades do body

  • font-family: 'Segoe UI', sans-serif; → define “Segoe UI” como fonte principal e “sans‑serif” como opção secundária.

  • color: #fff; → ajusta a cor do texto para branco.

  • background: linear-gradient(135deg, #1a1a2e, #16213e); → aplica um gradiente linear de 135° entre dois tons de azul‑escuro.

  • min-height: 100vh; → garante que o <body> tenha, no mínimo, 100% da altura da janela de visualização.

  • background-attachment: fixed; → fixa o fundo de forma que ele não se mova ao rolar a página.

  • background-size: cover; → faz com que o fundo cubra toda a área disponível, mantendo proporção.

  • line-height: 1.6; → define espaçamento entre linhas igual a 1,6 vezes o tamanho da fonte.

  • padding: 0 20px; → adiciona 20px de espaçamento interno nas laterais esquerda e direita.

Passo 3 — Configurar o head

				
					<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Top 10 Melhores Jogos de 2025</title>
<meta name="description"
      content="Aprenda passo a passo a montar seu primeiro site do zero usando HTML5, CSS3 e JavaScript. Exemplo completo com layout responsivo e código comentado.">
<link data-asynced="1" as="style" onload="this.onload=null;this.rel='stylesheet'"  rel="preload" href="style.css">

				
			
  • <meta charset> define codificação de caracteres.

  • <meta viewport> garante responsividade.

  • <title> aparece na aba do navegador e nos resultados de busca.

  • <link> conecta o style.css.

Passo 4 — Montar o header

Dentro de <body>, crie:

				
					<header>
  <h1>Top 10 Melhores Jogos de 2025</h1>
</header>

				
			

E no arquivo do style.css:

				
					header {
  text-align: center;
  padding: 60px 20px 30px;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(5px);
  border-bottom: 2px solid #00f2ff;
}

header h1 {
  font-size: 2.5rem;
  color: #00f2ff;
}

				
			

Propriedades do header

  • text-align: center; → centraliza horizontalmente o conteúdo interno.

  • padding: 60px 20px 30px; → insere 60px acima, 20px nas laterais e 30px abaixo do conteúdo.

  • background: rgba(0, 0, 0, 0.4); → aplica fundo preto com 40% de opacidade.

  • backdrop-filter: blur(5px); → desfoca em 5px o que estiver atrás do elemento.

  • border-bottom: 2px solid #00f2ff; → cria uma linha sólida de 2px ciana na base.

Propriedades do header h1

  • font-size: 2.5rem; → ajusta o tamanho da fonte para 2.5 vezes o tamanho base.

  • color: #00f2ff; → define a cor do texto como ciano.

Passo 5 — Criar a sessão de um jogo

Nesta etapa, vamos detalhar a marcação HTML de uma seção individual que exibe título, descrição, imagem e vídeo de um jogo.

				
					   <main class="conteudo">
       
    
    <section class="jogo">
        
      <h2>1. Minecraft</h2>
      
      <p>	Sandbox de sobrevivência e construção infinito, onde blocos tridimensionais formam um mundo gerado proceduralmente. Continua recebendo atualizações e abriga uma das maiores comunidades do mundo.</p>

      <img data-lazyloaded="1" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDI0IiBoZWlnaHQ9IjEwMjQiIHZpZXdCb3g9IjAgMCAxMDI0IDEwMjQiPjxyZWN0IHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIHN0eWxlPSJmaWxsOiNjZmQ0ZGI7ZmlsbC1vcGFjaXR5OiAwLjE7Ii8+PC9zdmc+" width="1024" height="1024" decoding="async" data-src="https://image.api.playstation.com/vulcan/ap/rnd/202407/0401/670c294ded3baf4fa11068db2ec6758c63f7daeb266a35a1.png" alt="minecraf" class="jogo-img">
      
      <iframe data-lazyloaded="1" src="about:blank" width="100%" height="400" data-litespeed-src="https://www.youtube.com/embed/MmB9b5njVbA?si=DMU-xDRvqYoWeRXQ" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>
   
    </section>
    </main>
				
			

E no arquivo do style.css:

				
					.conteudo {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 40px;
  max-width: 1000px;
  margin: 40px auto;
  padding: 0 20px;
}

.jogo {
  background: rgba(255, 255, 255, 0.05);
  padding: 25px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.jogo:hover {
  transform: scale(1.02);
}

.jogo h2 {
  color: #ffcb05;
  font-size: 1.8rem;
}

.jogo-img {
  width: 100%;
  border-radius: 8px;
  border: 2px solid #00f2ff;
  object-fit: cover;
}

.jogo-img {
  max-height: 300px;
}

				
			

Estilo do container principal:

  • display: grid; → organiza itens em grade.

  • grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); → cria colunas responsivas que têm no mínimo 300px.

  • gap: 40px; → espaço de 40px entre linhas e colunas.

  • max-width: 1000px; → limita largura total do container.

  • margin: 40px auto; → centraliza horizontalmente e adiciona 40px de margem superior/inferior.

  • padding: 0 20px; → 20px de espaço interno nas laterais.

Estilo dos cards de jogo (.jogo):

  • background: rgba(255, 255, 255, 0.05); → fundo semitransparente para destacar o card.

  • padding: 25px; → espaçamento interno ao redor do conteúdo.

  • border-radius: 12px; → cantos arredondados no card.

  • border: 1px solid rgba(255, 255, 255, 0.1); → borda sutil em torno do card.

  • transition: transform 0.3s ease; → animação suave no hover.

  • display: flex; flex-direction: column; gap: 15px; → empilha elementos verticalmente com espaçamento.

  • transform: scale(1.02); → aplica leve zoom no hover.

  • color: #ffcb05; → define o título em tom dourado.

  • font-size: 1.8rem; → ajusta o tamanho da fonte do título.

  • width: 100%; → faz a mídia preencher todo o espaço horizontal.

  • border-radius: 8px; → arredonda cantos de imagem e vídeo.

  • border: 2px solid #00f2ff; → borda ciana para destacar a mídia.

  • object-fit: cover; → mantém proporção e preenche a caixa.

  • max-height: 300px; → limita altura máxima da imagem.

Nota: dentro da tag 'main', crie 10 seções uma para cada jogo exibido no site.

Passo 6 — Adicionar o footer

Adicione ao final do <body> a marcação do rodapé e o carregamento do seu script:

				
					 <footer>
    <p>&copy; 2025 GameZone. Todos os direitos reservados.</p>
  </footer>
				
			

E no arquivo do style.css:

				
					footer {
  text-align: center;
  padding: 20px;
  font-size: 14px;
  background: rgba(0, 0, 0, 0.4);
  border-top: 1px solid #00f2ff;
  color: #ddd;
}

				
			
  • text-align: center; → centraliza o texto horizontalmente.

  • padding: 20px; → adiciona 20px de espaço interno em todos os lados.

  • font-size: 14px; → define o tamanho da fonte em 14px.

  • background: rgba(0, 0, 0, 0.4); → cria um fundo preto com 40% de opacidade.

  • border-top: 1px solid #00f2ff; → adiciona uma borda fina ciana na parte superior.

  • color: #ddd; → define a cor do texto como cinza claro.

Conclusão

Neste tutorial de como criar seu primeiro site do zero com HTML5, CSS3, vimos como estruturar semanticamente a página com <header>, <main> e <footer>, construir seções de conteúdo responsivas em grid, estilizar com gradientes, texturas e efeitos de hover em CSS.

Posts Similares

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *