<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Geraldo Christoper</title>
    <description>The latest articles on DEV Community by Geraldo Christoper (@gerealdochristopher).</description>
    <link>https://dev.to/gerealdochristopher</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F4016144%2F9543e664-3cc8-4772-869b-b4527a3c402f.png</url>
      <title>DEV Community: Geraldo Christoper</title>
      <link>https://dev.to/gerealdochristopher</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/gerealdochristopher"/>
    <language>en</language>
    <item>
      <title>webdev, javascript, css, showdev, html, tutorial</title>
      <dc:creator>Geraldo Christoper</dc:creator>
      <pubDate>Sun, 05 Jul 2026 12:14:33 +0000</pubDate>
      <link>https://dev.to/gerealdochristopher/webdev-javascript-css-showdev-html-tutorial-5d19</link>
      <guid>https://dev.to/gerealdochristopher/webdev-javascript-css-showdev-html-tutorial-5d19</guid>
      <description>&lt;div class="ltag__link--embedded"&gt;
  &lt;div class="crayons-story "&gt;
  &lt;a href="https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m" class="crayons-story__hidden-navigation-link"&gt;I Built a Premium Business Consulting Landing Page Using Only HTML, CSS, and Vanilla JavaScript&lt;/a&gt;


  &lt;div class="crayons-story__body crayons-story__body-full_post"&gt;
    &lt;div class="crayons-story__top"&gt;
      &lt;div class="crayons-story__meta"&gt;
        &lt;div class="crayons-story__author-pic"&gt;

          &lt;a href="/gerealdochristopher" class="crayons-avatar  crayons-avatar--l  "&gt;
            &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F4016144%2F9543e664-3cc8-4772-869b-b4527a3c402f.png" alt="gerealdochristopher profile" class="crayons-avatar__image"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
        &lt;div&gt;
          &lt;div&gt;
            &lt;a href="/gerealdochristopher" class="crayons-story__secondary fw-medium m:hidden"&gt;
              Geraldo Christoper
            &lt;/a&gt;
            &lt;div class="profile-preview-card relative mb-4 s:mb-0 fw-medium hidden m:inline-block"&gt;
              
                Geraldo Christoper
                
              
              &lt;div id="story-author-preview-content-4072361" class="profile-preview-card__content crayons-dropdown branded-7 p-4 pt-0"&gt;
                &lt;div class="gap-4 grid"&gt;
                  &lt;div class="-mt-4"&gt;
                    &lt;a href="/gerealdochristopher" class="flex"&gt;
                      &lt;span class="crayons-avatar crayons-avatar--xl mr-2 shrink-0"&gt;
                        &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F4016144%2F9543e664-3cc8-4772-869b-b4527a3c402f.png" class="crayons-avatar__image" alt=""&gt;
                      &lt;/span&gt;
                      &lt;span class="crayons-link crayons-subtitle-2 mt-5"&gt;Geraldo Christoper&lt;/span&gt;
                    &lt;/a&gt;
                  &lt;/div&gt;
                  &lt;div class="print-hidden"&gt;
                    
                      Follow
                    
                  &lt;/div&gt;
                  &lt;div class="author-preview-metadata-container"&gt;&lt;/div&gt;
                &lt;/div&gt;
              &lt;/div&gt;
            &lt;/div&gt;

          &lt;/div&gt;
          &lt;a href="https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m" class="crayons-story__tertiary fs-xs"&gt;&lt;time&gt;Jul 5&lt;/time&gt;&lt;span class="time-ago-indicator-initial-placeholder"&gt;&lt;/span&gt;&lt;/a&gt;
        &lt;/div&gt;
      &lt;/div&gt;

    &lt;/div&gt;

    &lt;div class="crayons-story__indention"&gt;
      &lt;h2 class="crayons-story__title crayons-story__title-full_post"&gt;
        &lt;a href="https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m" id="article-link-4072361"&gt;
          I Built a Premium Business Consulting Landing Page Using Only HTML, CSS, and Vanilla JavaScript
        &lt;/a&gt;
      &lt;/h2&gt;
        &lt;div class="crayons-story__tags"&gt;
            &lt;a class="crayons-tag crayons-tag--filled  " href="/t/showdev"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;showdev&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/css"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;css&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/javascript"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;javascript&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/webdev"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;webdev&lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="crayons-story__bottom"&gt;
        &lt;div class="crayons-story__details"&gt;
          &lt;a href="https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left"&gt;
            &lt;div class="multiple_reactions_aggregate"&gt;
              &lt;span class="multiple_reactions_icons_container"&gt;
                  &lt;span class="crayons_icon_container"&gt;
                    &lt;img src="https://assets.dev.to/assets/multi-unicorn-b44d6f8c23cdd00964192bedc38af3e82463978aa611b4365bd33a0f1f4f3e97.svg" width="18" height="18"&gt;
                  &lt;/span&gt;
                  &lt;span class="crayons_icon_container"&gt;
                    &lt;img src="https://assets.dev.to/assets/sparkle-heart-5f9bee3767e18deb1bb725290cb151c25234768a0e9a2bd39370c382d02920cf.svg" width="18" height="18"&gt;
                  &lt;/span&gt;
              &lt;/span&gt;
              &lt;span class="aggregate_reactions_counter"&gt;3&lt;span class="hidden s:inline"&gt;&amp;nbsp;reactions&lt;/span&gt;&lt;/span&gt;
            &lt;/div&gt;
          &lt;/a&gt;
            &lt;a href="https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m#comments" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left flex items-center"&gt;
              

              &lt;span class="hidden s:inline"&gt;Add&amp;nbsp;Comment&lt;/span&gt;
            &lt;/a&gt;
        &lt;/div&gt;
        &lt;div class="crayons-story__save"&gt;
          &lt;small class="crayons-story__tertiary fs-xs mr-2"&gt;
            3 min read
          &lt;/small&gt;
            
              &lt;span class="bm-initial crayons-icon c-btn__icon"&gt;
                

              &lt;/span&gt;
              &lt;span class="bm-success crayons-icon c-btn__icon"&gt;
                

              &lt;/span&gt;
            
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  &lt;/div&gt;
&lt;/div&gt;

&lt;/div&gt;


</description>
    </item>
    <item>
      <title>I Built a Premium Business Consulting Landing Page Using Only HTML, CSS, and Vanilla JavaScript</title>
      <dc:creator>Geraldo Christoper</dc:creator>
      <pubDate>Sun, 05 Jul 2026 12:13:32 +0000</pubDate>
      <link>https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m</link>
      <guid>https://dev.to/gerealdochristopher/i-built-a-premium-business-consulting-landing-page-using-only-html-css-and-vanilla-javascript-391m</guid>
      <description>&lt;p&gt;Over the past few days, I challenged myself to build a premium business consulting landing page without using any frameworks, UI libraries, CSS frameworks, build tools, or npm packages.&lt;/p&gt;

&lt;p&gt;The objective wasn't simply to recreate a beautiful design—it was to see how far modern HTML, CSS, and JavaScript can go on their own.&lt;/p&gt;

&lt;p&gt;The result is Scale Architects, a landing page designed for a fictional business growth consulting firm that combines lead generation, portfolio showcase, and trust-building into one responsive page.&lt;/p&gt;

&lt;p&gt;🚀 Live Demo&lt;/p&gt;

&lt;p&gt;Live: &lt;a href="https://gerealdochristopher.github.io/scale-architects-landing-page/" rel="noopener noreferrer"&gt;https://gerealdochristopher.github.io/scale-architects-landing-page/&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;GitHub: &lt;a href="https://github.com/GerealdoChristopher/scale-architects-landing-page" rel="noopener noreferrer"&gt;https://github.com/GerealdoChristopher/scale-architects-landing-page&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Why Vanilla?&lt;/p&gt;

&lt;p&gt;Frameworks are amazing productivity tools, but sometimes they hide how browsers actually work.&lt;/p&gt;

&lt;p&gt;For this project I wanted:&lt;/p&gt;

&lt;p&gt;complete control over every line of code&lt;br&gt;
zero runtime dependencies&lt;br&gt;
instant page loading&lt;br&gt;
browser-native ES Modules&lt;br&gt;
maintainable architecture without a build step&lt;/p&gt;

&lt;p&gt;Everything runs directly in the browser.&lt;/p&gt;

&lt;p&gt;No React.&lt;/p&gt;

&lt;p&gt;No Vue.&lt;/p&gt;

&lt;p&gt;No Tailwind.&lt;/p&gt;

&lt;p&gt;No Bootstrap.&lt;/p&gt;

&lt;p&gt;No jQuery.&lt;/p&gt;

&lt;p&gt;No GSAP.&lt;/p&gt;

&lt;p&gt;No npm install.&lt;/p&gt;

&lt;p&gt;Design System&lt;/p&gt;

&lt;p&gt;One thing I focused on was making the project easy to maintain.&lt;/p&gt;

&lt;p&gt;Instead of scattering colors and spacing values everywhere, I built a design system using more than 200 CSS Custom Properties.&lt;/p&gt;

&lt;p&gt;That means changing the brand colors, spacing, typography, or shadows only requires editing a single file.&lt;/p&gt;

&lt;p&gt;Typography is fully fluid using clamp(), so many elements scale naturally without relying on dozens of media queries.&lt;/p&gt;

&lt;p&gt;CSS Architecture&lt;/p&gt;

&lt;p&gt;Rather than putting thousands of lines into one stylesheet, I separated everything into independent modules using a SMACSS-inspired structure.&lt;/p&gt;

&lt;p&gt;css/&lt;br&gt;
├── base/&lt;br&gt;
│   ├── reset.css&lt;br&gt;
│   ├── variables.css&lt;br&gt;
│   └── typography.css&lt;br&gt;
├── layouts/&lt;br&gt;
└── components/&lt;/p&gt;

&lt;p&gt;Each UI section has its own stylesheet, making the project easier to navigate and maintain.&lt;/p&gt;

&lt;p&gt;JavaScript Architecture&lt;/p&gt;

&lt;p&gt;The JavaScript is also modular.&lt;/p&gt;

&lt;p&gt;js/&lt;br&gt;
├── modules/&lt;br&gt;
│   ├── navigation.js&lt;br&gt;
│   ├── smoothScroll.js&lt;br&gt;
│   └── testimonialCarousel.js&lt;br&gt;
└── script.js&lt;/p&gt;

&lt;p&gt;Each module has one responsibility.&lt;/p&gt;

&lt;p&gt;The main entry file simply initializes everything.&lt;/p&gt;

&lt;p&gt;Features&lt;/p&gt;

&lt;p&gt;Some of the interactions I implemented include:&lt;/p&gt;

&lt;p&gt;3D tilt effects&lt;br&gt;
Scroll reveal animations&lt;br&gt;
Animated particle background&lt;br&gt;
Glow effects&lt;br&gt;
Floating badges&lt;br&gt;
Animated testimonial cards&lt;br&gt;
Progress indicator&lt;br&gt;
Smooth scrolling&lt;br&gt;
Counter animations&lt;br&gt;
Swipe-enabled testimonial carousel&lt;br&gt;
Mobile-friendly navigation&lt;/p&gt;

&lt;p&gt;Everything is built using the browser APIs—no animation libraries.&lt;/p&gt;

&lt;p&gt;The Bug That Cost Me Hours&lt;/p&gt;

&lt;p&gt;Deployment worked perfectly locally...&lt;/p&gt;

&lt;p&gt;...until GitHub Pages broke my entire CSS architecture.&lt;/p&gt;

&lt;p&gt;The reason?&lt;/p&gt;

&lt;p&gt;GitHub Pages enables Jekyll by default, and Jekyll ignores files or folders beginning with an underscore.&lt;/p&gt;

&lt;p&gt;My component styles looked like this:&lt;/p&gt;

&lt;p&gt;_header.css&lt;br&gt;
_hero.css&lt;br&gt;
_footer.css&lt;/p&gt;

&lt;p&gt;None of them were being served.&lt;/p&gt;

&lt;p&gt;The solution turned out to be surprisingly simple:&lt;/p&gt;

&lt;p&gt;.nojekyll&lt;/p&gt;

&lt;p&gt;Adding one empty .nojekyll file in the repository root disables Jekyll processing, and everything immediately worked.&lt;/p&gt;

&lt;p&gt;Sometimes the smallest fixes take the longest to discover.&lt;/p&gt;

&lt;p&gt;What I'd Improve Next&lt;/p&gt;

&lt;p&gt;Although I'm happy with the current result, there are several things I'd like to improve:&lt;/p&gt;

&lt;p&gt;Dark mode&lt;br&gt;
Functional contact form&lt;br&gt;
Better accessibility&lt;br&gt;
AVIF/WebP image optimization&lt;br&gt;
Lighthouse performance optimization&lt;br&gt;
More keyboard navigation support&lt;br&gt;
Final Thoughts&lt;/p&gt;

&lt;p&gt;This project reminded me that modern browsers are incredibly capable.&lt;/p&gt;

&lt;p&gt;Frameworks certainly make development faster, but it's refreshing to build something from scratch and understand exactly how every interaction works.&lt;/p&gt;

&lt;p&gt;I'd love to hear your thoughts.&lt;/p&gt;

&lt;p&gt;Are the animations too much?&lt;br&gt;
How does the mobile experience feel?&lt;br&gt;
Would you structure the CSS differently?&lt;br&gt;
What would you improve first?&lt;/p&gt;

&lt;p&gt;Feedback is always appreciated.&lt;/p&gt;

&lt;p&gt;If you'd like to explore the project:&lt;/p&gt;

&lt;p&gt;⭐ GitHub: &lt;a href="https://github.com/GerealdoChristopher/scale-architects-landing-page" rel="noopener noreferrer"&gt;https://github.com/GerealdoChristopher/scale-architects-landing-page&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;🌐 Live Demo: &lt;a href="https://gerealdochristopher.github.io/scale-architects-landing-page" rel="noopener noreferrer"&gt;https://gerealdochristopher.github.io/scale-architects-landing-page&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Thanks for reading!&lt;/p&gt;

</description>
      <category>css</category>
      <category>javascript</category>
      <category>showdev</category>
      <category>webdev</category>
    </item>
  </channel>
</rss>
