HTML
Introduction to HTML
HTML stands for HyperText Markup Language. It is the standard
language used to create web pages. HTML is not a programming
language—it's a markup language, meaning it describes the
structure and content of a webpage using elements called tags.
      Key Features of HTML:
  •    HyperText: Links between web pages (hyperlinks).
  •    Markup Language: Tags are used to "mark up" text, images,
       and other content for display on the web.
      Explanation:
  •    <!DOCTYPE html>: Declares the document type and version of
       HTML.
  •    <html>: Root element of the HTML document.
  •    <head>: Contains meta information (title, links, scripts, etc.).
  •    <title>: Title shown in the browser tab.
  •    <body>: Contains all the content visible on the webpage.
      Common HTML Tags:
Tag              Description
<h1>–<h6>        Headings (h1 = largest, h6 = smallest)
<p>              Paragraph
<a>              Anchor (link)
<img>            Image
<ul>, <ol>, <li> Lists
<div>            Division or section
<span>           Inline container
<table>          Table layout
<form>           Forms for user input
<input>          Input field
      Creating Your First HTML File
Here’s how to create your first HTML file:
      Step-by-Step:
1. Create a Root Folder
   Name it something like: my-website
2. Inside that folder, create a file named: index.html
3. Write your first HTML code inside index.html:
    How to View It:
1. Save the file.
2. Right-click on index.html and select “Open with > Browser”
   (like Chrome or Firefox).
3. You'll see your first web page in action!
    1. <!DOCTYPE html> — Document Type Declaration
•    It tells the browser what version of HTML you’re using.
•    <!DOCTYPE html> means you're using HTML5, the latest
     standard.
•    It must be the first line in your HTML document.
    2. <head> — Document Metadata
•    Contains information about the web page, not visible to users.
•    Common tags inside <head>:
        o   <title> – Title shown in browser tab
        o   <meta> – Info like character set or author
        o   <link> – Link to external CSS files
        o   <style> – Internal CSS
        o   <script> – JavaScript
      3. <body> — Webpage Content
  •    Holds everything you see on the page:
          o   Text
          o   Images
          o   Buttons
          o   Links
          o   Videos
          o   Forms
  •    Only one <body> tag per page.
  •        HTML Headings
  •    HTML provides 6 levels of headings, from <h1> (the most important) to <h6> (the
       least important). These are used to define titles or section headings on a web page.
      Key Points:
  •    <h1> is usually used for main titles.
  •    <h2> to <h6> are used for subheadings.
  •    Headings are block-level elements (they start on a new line).
  •    By default, browsers display them in decreasing font size.
      HTML Comments
In HTML, comments are used to leave notes in your code. These
notes are ignored by the browser and do not appear on the
webpage. They’re useful for:
  •    Explaining parts of your code
  •    Temporarily hiding code
  •    Leaving reminders for yourself or other developers
         Rules:
     •    Comments must be enclosed within <!-- and -->.
     •    Do not use double dashes inside a comment like -- (it can break
          the comment).
     •        Nesting HTML Elements
     •    Nesting in HTML means placing one HTML element inside another. This is how
          you build structure and layout in a webpage.
         General Rule:
     •    Always close inner tags before closing the outer ones.
     •    Incorrect nesting can break your layout or cause unexpected
          behavior.
     •        HTML Lists
     •    HTML provides three main types of lists to organize content:
1.         Ordered List (<ol>)
     •    Items are numbered (1, 2, 3…).
     •   Useful for step-by-step instructions or ranked items.
2.       Unordered List (<ul>)
     •   Items are shown with bullets.
     •   Used for general lists where order doesn't matter.
3.       Description List (<dl>)
     •   Used for terms and their descriptions.
    Renders as:
HTML
→ A markup language for creating webpages.
CSS
→ Styles the layout of webpages.
      Semantic HTML
Semantic HTML refers to using HTML tags that convey meaning
about the content inside them. These tags help browsers,
developers, and assistive technologies (like screen readers)
understand the structure and role of content on a webpage.
      Why Use Semantic HTML?
  •    Improves readability of code
  •    Enhances SEO (Search Engine Optimization)
  •    Supports accessibility for users with disabilities
  •    Helps browsers and tools understand your layout
      Examples of Semantic Tags:
Tag            Purpose
<header>       Top section of a page or section
<nav>          Navigation links
<main>         Main content of the document
<section>      A standalone section of content
<article>      Independent content (like blog post)
<aside>        Sidebar or additional info
<footer>       Bottom section of a page or section
<figure>       Image with caption
<figcaption> Caption for the figure
<mark>         Highlights text
Tag            Purpose
<time>         Time or date-related content
      Semantic HTML Example:
      <strong> and <em> Elements in HTML
These tags are used to give meaning to text—not just styling.
      <strong> — Strong Importance
  •    Indicates that the text is important or urgent.
  •    Usually rendered bold by default.
      <em> — Emphasis
  •    Emphasizes a word or phrase as if you're stressing it when
       speaking.
  •    Usually rendered in italics by default.
      Semantic Meaning vs Styling:
  •    <strong> = important content (not just bold for looks)
  •    <em> = stressed/emphasized content (not just italics for design)
      Block vs. Inline Elements in HTML
In HTML, elements are categorized as either block-level or inline-
level, based on how they behave on the page.
      Block-Level Elements
  •    Start on a new line
  •    Take up the full width of the parent container
  •    Can contain other block or inline elements
      Common Block Elements:
<div>, <p>, <h1>–<h6>, <ul>, <ol>, <li>, <section>, <article>,
<header>, <footer>, <table>
      Inline Elements
  •    Do not start on a new line
  •    Only take up as much width as necessary
  •    Usually used within block elements
      Common Inline Elements:
<span>, <a>, <strong>, <em>, <img>, <label>, <input>
       1. Links in HTML — Using <a> (Anchor Tag)
The <a> tag is used to create hyperlinks.
       Syntax:
       2. Attributes in HTML
Attributes provide additional information about an element. They
are always in the form:
       Common Attributes:
Attribute Description
href         URL for a link (<a>)
src          Image/file path (<img>)
alt          Alt text for images
Attribute Description
title         Tooltip text
target        Where to open the link (_blank for new tab)
        3. Paths in HTML
Paths tell the browser where to find a file (like an image, CSS file, or
link).
        Types of Paths:
 Type          Example                          Meaning
 Absolute https://example.com/image.jpg Full URL
                                                Refers to a file in a
 Relative      images/photo.jpg                 folder relative to your
                                                HTML file
 Same                                           File is in the same
               file.html
 folder                                         directory
 Parent                                         One level up from
               ../file.html
 folder                                         current folder
        Images in HTML
To display images on a webpage, HTML uses the <img> tag.
Attribute Purpose
src      Source (path or URL of the image)
         Alternative text (shown if image doesn’t load; helps with
alt
         accessibility)
                                       CSS
To link a CSS file to your HTML file, use the <link> tag inside the
<head> section of your HTML document. Here's the basic syntax:
Explanation:
  •   <link>: Defines a relationship between the HTML and an
      external resource.
  •   rel="stylesheet": Tells the browser the file is a stylesheet.
  •   href="style.css": Path to your CSS file. If it’s in the same folder
      as your HTML file, just the name is enough. Otherwise, use a
      relative or absolute path like:
         o   css/style.css (if it's in a subfolder named css)
         o   ../style.css (if it’s in the parent folder)
  •       CSS Syntax – The Basics
  •   CSS (Cascading Style Sheets) is used to style HTML elements. The basic syntax
      looks like this:
Colors
    1. Cascade Priority
CSS = Cascading Style Sheets. When multiple rules apply to the same
element, the last one wins if they have the same specificity.
    2. Specificity Matters More Than Order
If selectors have different specificity, the more specific one wins,
even if it comes earlier.
    3. Linked CSS Files – Order Also Matters
If you link multiple stylesheets in HTML, the last linked one overrides
earlier ones (if they conflict).
    4. Shorthand vs. Longhand
If you use both, order again matters:
    Text Alignment in CSS
Use the text-align property to control horizontal alignment of text
inside an element.
       Syntax:
       Common Values:
Value        Meaning
left         Aligns text to the left (default)
right        Aligns text to the right
center       Centers the text
             Stretches the text to align left and right edges (like in
justify
             newspapers)
start /
             Aligns based on text direction (e.g., for RTL languages)
end
       CSS Font Families and Font Stacks
In CSS, font-family sets the font for your text. You can provide
multiple fonts in a font stack to ensure the browser uses the next
available one if the first isn’t installed.
    Tips:
•    Always include a generic family at the end.
•    If a font name has spaces, wrap it in quotes.
•    Web-safe fonts (like Arial, Verdana) are widely supported, but
     for custom fonts, consider using Google Fonts.
•           CSS Inheritance – How Styles Are Passed Down
•    Inheritance in CSS means that some properties applied to a parent element are
     automatically inherited by its children.
•
•           Inherited Automatically:
•    These text-related properties are usually inherited:
Property                               Description
color                                  Text color
font-family                            Font type
font-size                              Text size
font-style                             Italic, normal, etc.
font-variant                           Small caps, etc.
font-weight                            Boldness
letter-spacing                         Space between letters
line-height                            Line spacing
text-align                             Horizontal alignment
visibility                             Show/hide elements
word-spacing                           Space between words
         Not Inherited by Default:
    Layout, box, and visual properties are not inherited automatically:
     Property      Description
     margin        Space outside
     padding       Space inside
     border        Border styling
     width, height Sizing
     display       Box type (block/inline)
Property        Description
position        Layout control
background Background styling
      Forcing Inheritance:
You can force inheritance using the inherit keyword.
      What Are User Agent Styles in CSS?
User agent styles are the default styles applied by your web browser
to HTML elements — before any CSS you write.
      Why They Matter:
  •    They explain why your webpage doesn’t look totally plain
       even without CSS.
  •    They can cause inconsistencies across different browsers.
  •    They can interfere with your styles unless you override or
       reset them.
  •        How to Deal With Them
  •    1. Override With Your Own CSS
  •    2. Use a CSS Reset
  •    A CSS reset removes browser defaults to give you a clean slate:
Or use popular reset libraries like:
  •    Normalize.css – keeps useful defaults and fixes cross-browser
       issues.
  •    Eric Meyer’s Reset – clears everything
      CSS Font Sizes – Everything You Need to Know
In CSS, you can control the size of text using the font-size property.
      Basic Syntax:
      Common Units for font-size:
Unit Meaning                                    Example
px     Pixels (absolute size)                   font-size: 16px;
em Relative to parent font size                 font-size: 1.5em;
rem Relative to root (<html>) size font-size: 2rem;
Unit Meaning                            Example
%        Percentage of parent font size font-size: 120%;
vw Relative to viewport width           font-size: 3vw;
vh       Relative to viewport height    font-size: 2vh;
        em vs rem
    •    em: relative to the current element’s parent
    •    rem: relative to the root element
        1. Line Height – Spacing between lines of text
        Property: line-height
Syntax:
        Values:
Value               Meaning
normal (default) Automatically based on font size
number              Multiplies the font size (1.5 means 150%)
px, em, rem         Absolute or relative units
   2. Spacing Between Elements
   A. margin – Space outside the element
   B. padding – Space inside the element (between content and
border)
   CSS: Inline vs Internal Stylesheet
There are 3 main ways to add CSS to HTML:
  1. Inline
  2. Internal
  3. External (we covered this earlier)
  4.       1. Inline CSS
  5. CSS written directly in an HTML element using the style attribute.
    2. Internal Stylesheet
CSS is written inside a <style> tag within the <head> section of the
HTML file.
    Pros:
  •    Keeps styles in one place (inside the file)
  •    Better than inline for small/medium projects
  •    Can apply styles to multiple elements
      Cons:
  •    Still mixes HTML and CSS
  •    Not reusable across multiple pages
  •        DevTools (Developer Tools) – Your Web Debugging Superpower
  •    DevTools are built-in tools in modern web browsers (like Chrome, Firefox, Edge) that
       let you inspect, debug, and experiment with HTML, CSS, and JavaScript directly in
       the browser.
      How to Open DevTools:
  •    Chrome/Edge/Firefox:
       Press F12 or Ctrl + Shift + I (or right-click → Inspect)
      Key Panels in DevTools:
Panel             What It Does
Elements          Inspect and edit HTML & CSS
Console           Shows JavaScript output and errors
Sources           View and debug JavaScript files
Network           Shows files and data being loaded
Application Cookies, local storage, cache
Performance Analyze speed and bottlenecks
Lighthouse        Website performance/report tool
    Introduction to the CSS Box Model
The CSS Box Model is a fundamental concept in web design and
layout. It describes how elements on a webpage are structured and
spaced. Think of every HTML element as a rectangular box, made up
of the following layers (from innermost to outermost):
    Tip: box-sizing: border-box
If you set:
   Padding in the Box Model
Padding is the space between the content and the border of an
element. It creates inner spacing that makes content look cleaner
and more readable.
   Padding Syntax in CSS
You can set padding in a few ways:
1. All Sides (Uniform Padding)
In the CSS Box Model, the border is the area between the element’s
padding and margin. It wraps around the padding and content.
      Border Basics:
  •    The border is visible and can have:
          o   Width (e.g., 1px, 5px)
          o   Style (e.g., solid, dashed, none)
          o   Color (e.g., black, #ff0000)
      CSS Box Model: Margin
The margin is the outermost layer in the CSS box model. It creates
space outside the element’s border, pushing the element away from
others.
    Notes:
•    Margins can be positive (adds space) or negative (pulls
     elements closer).
•    Margins between vertical elements can collapse (called margin
     collapsing):
       o     Example: If one element has margin-bottom: 20px and the
             next has margin-top: 30px, the resulting margin between
             them is 30px, not 50px.
      CSS box-sizing Property
The box-sizing property controls how the total width and height of
an element are calculated.
      Two Main Values:
1. content-box (default):
  •    Only the content area is counted in width and height.
  •    Padding and border are added on top of the set dimensions.
2. border-box (commonly used):
  •    Padding and border are included inside the width and height.
  •    The content area shrinks to make room for padding and border.
      Best Practice:
Set this globally for easier layout control:
      Introduction to the Updated CSS Box Model Layout
The updated layout model in modern CSS often refers to using:
  •    box-sizing: border-box (instead of the default content-box)
  •    Flexible, responsive layouts with padding/margins managed
       more intuitively
  •    Consistent element sizing that simplifies calculations
      Traditional vs Updated Box Model
                       Traditional (content-
Feature                                      Updated (border-box)
                       box)
                                               Content + Padding +
Width includes         Only content
                                               Border
Easier layout
                          More complex            Easier to maintain
control?
                      Traditional (content-
Feature                                     Updated (border-box)
                      box)
Used in modern        Rarely (mostly          Common and
CSS?                  legacy)             recommended
      Why Use box-sizing: border-box?
  •    Prevents layout overflow.
  •    Makes fixed-width components predictable.
  •    Great for responsive designs.
      CSS Classes vs. IDs
In CSS and HTML, classes and IDs are used to select and style
elements. Here's how they differ:
      1. Class Selector (.)
  •    Used for grouping and applying styles to multiple elements.
  •    Defined with a dot (.) in CSS.
    2. ID Selector (#)
•    Used to target a single unique element.
•    Defined with a hash (#) in CSS.
    div vs. span in HTML
Both <div> and <span> are container elements, but they behave
differently in layout and use.
      1. <div> – Block-level element
  •    Used to group larger chunks of content.
  •    Takes full width of its container by default.
  •    Starts on a new line.
      2. <span> – Inline element
  •    Used to style or group inline text.
  •    Does not break onto a new line.
  •    Only takes up as much width as its content.
      Styling Links in CSS
Links (<a>) can be styled using CSS pseudo-classes depending on
their state.
   Common Link States:
Pseudo-class Meaning
a:link        Unvisited link
a:visited     Visited link
a:hover       When the mouse is over the link
a:active      When the link is being clicked
   Best Practice: Link Order
Always style in this order to avoid unexpected behavior:
   CSS Background Images
You can use background-image in CSS to add images behind
elements like div, body, or even buttons.
   Common Background Properties:
Property                Description
background-repeat       Repeat or not (repeat, no-repeat, repeat-x)
background-size         Resize image (cover, contain, 100px 200px)
background-position     Position image (center, top right, etc.)
background-attachment Scroll behavior (scroll, fixed)
background-color        Fallback color if image doesn't load
   CSS Descendant Selectors
A descendant selector targets elements inside other elements, no
matter how deeply nested they are — as long as they are within the
specified ancestor.
   Syntax:
   CSS Specificity – What Rules Win?
Specificity determines which CSS rule is applied when multiple rules
target the same element. The more specific rule takes priority.
   How Specificity Works
Each CSS selector gets a specificity value, often written as
inline styles : IDs : classes/attributes/pseudo-classes :
elements/pseudo-elements
        (a)   (b)        (c)             (d)
      Specificity Examples
                     Specificity
Selector                              Notes
                     (a,b,c,d)
div                  (0,0,0,1)        Element selector
.card                (0,0,1,0)        Class selector
#header              (0,1,0,0)        ID selector
div p span           (0,0,0,3)        Three element selectors
#header .card
                     (0,1,1,1)        ID > class > element
span
                                      Inline style (highest priority
style="color:red" (1,0,0,0)
                                      except !important)
   CSS Specificity & Browser DevTools — How to Inspect and
Debug Styles
When multiple CSS rules apply to an element, DevTools helps you
understand which one wins using specificity and source order.
      How to Check Specificity in DevTools (e.g., Chrome or Firefox):
  1. Right-click on any element → Click “Inspect”.
  2. In the "Elements" tab, find the element’s HTML.
  3. In the "Styles" pane on the right:
         o   You’ll see all the CSS rules applied to the element.
         o   The active rule is applied (not crossed out).
         o   Overridden rules are crossed out (due to lower specificity
             or later rules).
         o   Hovering over the selector often shows its source file and
             line number.
In DevTools:
  •   You'll see all 3 rules.
  •    Only color: red; will be active.
  •    The others will be crossed out, showing they were overridden.
  •    If you hover, you may see the specificity calculated (in some
       DevTools).
      Styling Lists in CSS
HTML lists (<ul>, <ol>, and <li>) can be visually customized using CSS
to change bullets, spacing, alignment, and more.
      Types of Lists:
  •    <ul> → Unordered list (default bullets)
  •    <ol> → Ordered list (numbers by default)
  •    <li> → List items
      Common List Styling Properties:
Property                Description
list-style-type         Changes bullet or number style
list-style-position Inside or outside the content box
list-style-image        Use an image instead of default bullets
margin, padding Adjust space around the list or items
      Examples:
1. Custom Bullet Style
2. Remove Bullets
3. Add Custom Spacing
4. Use Images as Bullets
5. List Inside/Outside Content Box
    Preventing Layouts from Getting Too Wide in CSS
To keep your web page layouts from stretching too far on wide
screens, use CSS constraints that control maximum width and
content flow.
    Common Techniques:
1. Use max-width
Limits how wide a container can grow even on large screens.
  width: 100% makes it responsive.
  max-width sets the max limit.
  margin: 0 auto centers it horizontally.
2. Avoid Fixed width on Everything
Avoid this:
3. Use Media Queries for Responsive Breakpoints
4. Use overflow-wrap and word-break for long content
Prevents long words or URLs from breaking the layout:
5. Set box-sizing: border-box
So padding/border don’t increase element width.
      Creating a Two-Column Layout in CSS
A two-column layout is a common design pattern where content is
divided horizontally into two sections — like a sidebar and main
content.
      Method 1: Flexbox (Most Common & Responsive)
   It’s responsive by default — will stack on smaller screens unless
handled with media queries.
      Method 2: Grid Layout
      Use fr units to control how much space each column takes.
      Method 3: Float (Old-school method — avoid unless necessary)
      Use Flexbox or Grid instead of floats for modern layouts.
      Tips:
  •    Add media queries to stack columns on small screens.
  •    Use min-height, box-sizing, or overflow to control layout
       behavior.
   Creating a Navigation Bar in HTML & CSS
A navigation bar (navbar) is a key part of most websites. Here’s how
to create one using HTML + CSS (modern & responsive).
   What is Flexbox?
Flexbox (Flexible Box Layout) is a CSS module that makes it easy to
align, distribute, and space items in a container — even when their
sizes are unknown or dynamic.
   Main Properties
Property        Description
display: flex   Enables flexbox
flex-direction Row or column layout
Property       Description
justify-content Main axis alignment (left to right by default)
align-items    Cross axis alignment (top to bottom by default)
flex-wrap      Allows items to wrap onto multiple lines
   Media Query Basics in CSS
Media queries let you apply different CSS rules depending on the
device’s screen size, resolution, or type — making your design
responsive.