<!
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>NOOR - Exquisite Fragrances</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?
family=Playfair+Display:wght@400;700&family=Lato:wght@300;400;700&display=swap"
rel="stylesheet">
<style>
/* --- Global Styles & Reset --- */
:root {
--color-background: #121212;
--color-text: #e0e0e0;
--color-primary: #D4AF37; /* Gold accent */
--color-secondary: #222222;
--color-white: #ffffff;
--font-primary: 'Playfair Display', serif;
--font-secondary: 'Lato', sans-serif;
--transition-speed: 0.3s;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
font-size: 16px; /* Base font size */
}
body {
font-family: var(--font-secondary);
background-color: var(--color-background);
color: var(--color-text);
line-height: 1.6;
overflow-x: hidden; /* Prevent horizontal scroll */
}
/* --- Typography --- */
h1, h2, h3 {
font-family: var(--font-primary);
color: var(--color-white);
margin-bottom: 1rem;
font-weight: 700;
letter-spacing: 1px;
}
h1 { font-size: 3.5rem; line-height: 1.2; }
h2 { font-size: 2.5rem; }
h3 { font-size: 1.8rem; }
p {
margin-bottom: 1rem;
font-weight: 300;
}
a {
color: var(--color-primary);
text-decoration: none;
transition: color var(--transition-speed) ease;
}
a:hover {
color: var(--color-white);
}
/* --- Layout & Containers --- */
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 2rem;
}
section {
padding: 6rem 0;
overflow: hidden; /* Contain animations */
}
/* --- Header & Navigation --- */
header {
position: fixed;
top: 0;
left: 0;
width: 100%;
padding: 1.5rem 0;
z-index: 1000;
transition: background-color var(--transition-speed) ease, padding
var(--transition-speed) ease;
}
header.scrolled {
background-color: rgba(18, 18, 18, 0.95); /* Slightly transparent black
*/
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
padding: 1rem 0;
}
.navbar {
display: flex;
justify-content: space-between;
align-items: center;
max-width: 1300px; /* Slightly wider for nav */
margin: 0 auto;
padding: 0 2rem;
}
.logo {
font-family: var(--font-primary);
font-size: 2rem;
font-weight: 700;
color: var(--color-primary);
letter-spacing: 2px;
text-transform: uppercase;
}
.nav-links {
list-style: none;
display: flex;
}
.nav-links li {
margin-left: 2.5rem;
}
.nav-links a {
color: var(--color-white);
font-family: var(--font-secondary);
font-weight: 400;
font-size: 0.9rem;
text-transform: uppercase;
letter-spacing: 1px;
position: relative;
padding-bottom: 0.3rem;
}
.nav-links a::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 0;
height: 1px;
background-color: var(--color-primary);
transition: width var(--transition-speed) ease;
}
.nav-links a:hover::after,
.nav-links a.active::after {
width: 100%;
}
/* --- Hero Section --- */
#hero {
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
text-align: center;
color: var(--color-white);
background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)),
url('https://placehold.co/1920x1080/111111/333333?text=Luxury+Background') no-
repeat center center/cover;
background-attachment: fixed; /* Parallax effect */
padding: 0 2rem; /* Padding for content on small screens */
}
.hero-content {
max-width: 800px;
}
#hero h1 {
color: var(--color-white);
text-shadow: 2px 2px 8px rgba(0,0,0,0.5);
margin-bottom: 1.5rem;
}
#hero p {
font-size: 1.2rem;
margin-bottom: 2rem;
color: var(--color-text);
font-weight: 300;
}
.cta-button {
display: inline-block;
background-color: var(--color-primary);
color: var(--color-background);
padding: 0.8rem 2rem;
font-family: var(--font-secondary);
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1px;
border: none;
border-radius: 3px;
cursor: pointer;
transition: background-color var(--transition-speed) ease, transform
var(--transition-speed) ease;
}
.cta-button:hover {
background-color: darken(var(--color-primary), 10%);
color: #000;
transform: translateY(-3px);
box-shadow: 0 4px 15px rgba(212, 175, 55, 0.3);
}
/* --- About Section --- */
#about {
background-color: var(--color-secondary);
}
.about-content {
display: flex;
align-items: center;
gap: 4rem;
}
.about-text {
flex: 1;
}
.about-image {
flex: 1;
max-width: 450px;
}
.about-image img {
width: 100%;
height: auto;
border-radius: 5px;
box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}
.about-text h2 {
color: var(--color-primary);
margin-bottom: 1.5rem;
}
/* --- Collections Section --- */
#collections h2 {
text-align: center;
margin-bottom: 4rem;
}
.product-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 2.5rem;
}
.product-card {
background-color: var(--color-secondary);
border-radius: 5px;
overflow: hidden;
text-align: center;
padding: 2rem 1.5rem;
transition: transform var(--transition-speed) ease, box-shadow var(--
transition-speed) ease;
position: relative; /* For potential future interactions */
}
.product-card:hover {
transform: translateY(-10px);
box-shadow: 0 15px 35px rgba(0,0,0,0.4);
}
.product-card img {
max-width: 80%;
height: 250px;
object-fit: contain; /* Use contain for perfume bottles */
margin-bottom: 1.5rem;
transition: transform var(--transition-speed) ease;
}
.product-card:hover img {
transform: scale(1.05);
}
.product-card h3 {
color: var(--color-primary);
font-size: 1.5rem;
margin-bottom: 0.5rem;
}
.product-card p {
font-size: 0.9rem;
color: #aaa;
margin-bottom: 1.5rem;
}
.product-card .cta-button {
padding: 0.6rem 1.5rem;
font-size: 0.8rem;
}
/* --- Experience Section (Example) --- */
#experience {
background: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)),
url('https://placehold.co/1920x800/222222/444444?text=Craftsmanship+Visual') no-
repeat center center/cover;
background-attachment: fixed;
text-align: center;
color: var(--color-white);
}
#experience h2 {
color: var(--color-primary);
margin-bottom: 1.5rem;
}
#experience p {
max-width: 700px;
margin: 0 auto 2rem auto;
font-size: 1.1rem;
}
/* --- Contact Section --- */
#contact {
background-color: var(--color-secondary);
text-align: center;
}
#contact h2 {
margin-bottom: 3rem;
}
#contact p {
max-width: 600px;
margin: 0 auto 1.5rem auto;
}
.contact-info a {
color: var(--color-primary);
font-weight: bold;
display: inline-block;
margin: 0 1rem;
}
/* --- Footer --- */
footer {
background-color: #0a0a0a;
color: #888;
text-align: center;
padding: 2rem 0;
font-size: 0.9rem;
}
.social-links a {
margin: 0 0.8rem;
color: #aaa;
font-size: 1.2rem;
transition: color var(--transition-speed) ease;
}
.social-links a:hover {
color: var(--color-primary);
}
/* --- Animations & Transitions --- */
.fade-in {
opacity: 0;
transform: translateY(30px);
transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.fade-in.visible {
opacity: 1;
transform: translateY(0);
}
/* Add delays for staggered effect if needed */
.product-card:nth-child(2) { transition-delay: 0.1s; }
.product-card:nth-child(3) { transition-delay: 0.2s; }
/* etc. */
/* --- Responsiveness --- */
@media (max-width: 992px) {
h1 { font-size: 3rem; }
h2 { font-size: 2.2rem; }
section { padding: 4rem 0; }
.about-content { flex-direction: column; text-align: center; }
.about-image { margin-top: 2rem; max-width: 80%; }
}
@media (max-width: 768px) {
html { font-size: 15px; }
h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
.navbar { padding: 0 1rem; } /* Adjust navbar padding */
.logo { font-size: 1.8rem; }
/* Simple Mobile Nav - Consider a JS toggle menu for real apps */
.nav-links {
/* Hide for now, replace with burger menu logic */
/* display: none; */
/* Example simple stack: */
position: absolute;
top: 70px; /* Adjust based on header height */
left: 0;
background: var(--color-secondary);
width: 100%;
flex-direction: column;
align-items: center;
padding: 1rem 0;
/* Add JS to toggle visibility */
display: none; /* Initially hidden */
}
.nav-links.active {
display: flex; /* Show when active */
}
.nav-links li {
margin: 1rem 0;
margin-left: 0;
}
/* Add a placeholder for a menu toggle button if needed */
.menu-toggle {
display: block; /* Show toggle button */
/* Add styling for burger icon here */
color: var(--color-white);
font-size: 1.5rem;
cursor: pointer;
/* Basic text fallback */
/* background: none; border: none; */
}
#hero { height: 80vh; }
#hero h1 { font-size: 2.2rem; }
#hero p { font-size: 1rem; }
.container { padding: 0 1rem; }
.product-grid { grid-template-columns: 1fr; } /* Stack products */
.about-content { gap: 2rem; }
}
@media (max-width: 480px) {
html { font-size: 14px; }
h1 { font-size: 2rem; }
h2 { font-size: 1.8rem; }
.logo { font-size: 1.6rem;}
/* Simple Menu Toggle - Needs JS */
.menu-toggle {
display: none; /* Hidden by default on larger screens */
/* Basic styling for a placeholder button */
background: none;
border: none;
color: white;
font-size: 1.8rem;
cursor: pointer;
}
@media (max-width: 768px) {
.menu-toggle { display: block; }
/* .nav-links { display: none; } /* Hide links initially */
.nav-links.active { display: flex; } /* Show when active */
}
</style>
</head>
<body>
<header id="main-header">
<div class="navbar">
<a href="#hero" class="logo">NOOR</a>
<!-- Placeholder for Menu Toggle Button -->
<button class="menu-toggle" aria-label="Toggle navigation">☰</button>
<!-- Basic Burger Icon -->
<nav>
<ul class="nav-links">
<li><a href="#hero">Home</a></li>
<li><a href="#about">Our Story</a></li>
<li><a href="#collections">Collections</a></li>
<li><a href="#experience">Experience</a></li>
<li><a href="#contact">Contact</a></li>
</ul>
</nav>
</div>
</header>
<main>
<!-- Hero Section -->
<section id="hero">
<div class="hero-content fade-in">
<h1>NOOR</h1>
<p>Discover Your Signature Scent. An Aura of Light and Luxury.</p>
<a href="#collections" class="cta-button">Explore Collections</a>
</div>
</section>
<!-- About Section -->
<section id="about">
<div class="container about-content">
<div class="about-text fade-in">
<h2>The Essence of Light</h2>
<p>NOOR, meaning 'light' in Arabic, represents more than just
fragrance. It embodies illumination, clarity, and the radiant energy within. Our
perfumes are crafted with the finest ingredients, sourced globally, to create
scents that are both timeless and contemporary.</p>
<p>We believe that perfume is a personal signature, an
invisible accessory that completes your presence. Each NOOR creation is a journey,
designed to evoke emotion, inspire confidence, and leave a lasting impression.</p>
</div>
<div class="about-image fade-in">
<img src="https://placehold.co/600x700/2a2a2a/555555?
text=Elegant+Lifestyle+Shot" alt="Elegant lifestyle visual representing the Noor
brand">
</div>
</div>
</section>
<!-- Collections Section -->
<section id="collections">
<div class="container">
<h2 class="fade-in">Our Collections</h2>
<div class="product-grid">
<!-- Product Card 1 -->
<div class="product-card fade-in">
<img src="https://placehold.co/300x300/eeeeee/777777?
text=NOOR+Aura" alt="Noor Aura Perfume Bottle">
<h3>Aura</h3>
<p>A radiant blend of citrus top notes, floral heart, and
warm amber base.</p>
<a href="#" class="cta-button">Discover Aura</a>
</div>
<!-- Product Card 2 -->
<div class="product-card fade-in">
<img src="https://placehold.co/300x300/eeeeee/777777?
text=NOOR+Éclat" alt="Noor Éclat Perfume Bottle">
<h3>Éclat</h3>
<p>Sparkling bergamot and pear illuminate a sophisticated
core of jasmine and musk.</p>
<a href="#" class="cta-button">Discover Éclat</a>
</div>
<!-- Product Card 3 -->
<div class="product-card fade-in">
<img src="https://placehold.co/300x300/eeeeee/777777?
text=NOOR+Mystique" alt="Noor Mystique Perfume Bottle">
<h3>Mystique</h3>
<p>An enigmatic fusion of dark spices, rare woods, and a
hint of vanilla orchid.</p>
<a href="#" class="cta-button">Discover Mystique</a>
</div>
<!-- Add more product cards as needed -->
</div>
</div>
</section>
<!-- Experience Section -->
<section id="experience">
<div class="container fade-in">
<h2>The Art of Perfumery</h2>
<p>Experience the meticulous craftsmanship behind every NOOR
fragrance. We blend traditional techniques with modern innovation to capture the
pure essence of nature's most precious ingredients. Each drop tells a story,
crafted to perfection.</p>
<a href="#" class="cta-button">Learn More</a>
</div>
</section>
<!-- Contact Section -->
<section id="contact">
<div class="container fade-in">
<h2>Connect With NOOR</h2>
<p>For inquiries, collaborations, or to simply share your NOOR
experience, please reach out. We cherish the connection with our community.</p>
<div class="contact-info">
<p>Email: <a
href="mailto:info@noorfragrance.com">info@noorfragrance.com</a></p>
<p>Follow us on social media</p>
<!-- Add Social Links Here in Footer -->
</div>
</div>
</section>
</main>
<footer>
<div class="container">
<div class="social-links">
<!-- Replace # with actual links -->
<a href="#" aria-label="Instagram"><i class="fab
fa-instagram"></i> IG</a> <!-- Placeholder -->
<a href="#" aria-label="Facebook"><i class="fab
fa-facebook-f"></i> FB</a> <!-- Placeholder -->
<a href="#" aria-label="Twitter"><i class="fab fa-twitter"></i>
TW</a> <!-- Placeholder -->
<!-- Add FontAwesome CDN link in <head> if you want actual icons
-->
</div>
<p>© 2024 NOOR Fragrances. All Rights Reserved.</p>
<p>Designed with Light & Luxury</p>
</div>
</footer>
<script>
document.addEventListener('DOMContentLoaded', () => {
// --- Header Scroll Effect ---
const header = document.getElementById('main-header');
window.addEventListener('scroll', () => {
if (window.scrollY > 50) {
header.classList.add('scrolled');
} else {
header.classList.remove('scrolled');
}
});
// --- Smooth Scrolling for Nav Links ---
const navLinks = document.querySelectorAll('.nav-links a[href^="#"]');
navLinks.forEach(link => {
link.addEventListener('click', function(e) {
e.preventDefault();
const targetId = this.getAttribute('href');
const targetElement = document.querySelector(targetId);
if (targetElement) {
targetElement.scrollIntoView({
behavior: 'smooth',
block: 'start'
});
// Close mobile menu if open after click
const navList = document.querySelector('.nav-links');
if (navList.classList.contains('active')) {
navList.classList.remove('active');
}
}
});
});
// --- Fade-in Animation on Scroll ---
const fadeElems = document.querySelectorAll('.fade-in');
const observerOptions = {
root: null, // viewport
rootMargin: '0px',
threshold: 0.1 // Trigger when 10% of the element is visible
};
const observer = new IntersectionObserver((entries, observer) => {
entries.forEach(entry => {
if (entry.isIntersecting) {
entry.target.classList.add('visible');
// Optional: unobserve after animation to save resources
// observer.unobserve(entry.target);
}
// Optional: remove class if element scrolls out of view
// else {
// entry.target.classList.remove('visible');
// }
});
}, observerOptions);
fadeElems.forEach(elem => {
observer.observe(elem);
});
// --- Mobile Menu Toggle ---
const menuToggle = document.querySelector('.menu-toggle');
const navList = document.querySelector('.nav-links');
if (menuToggle && navList) {
menuToggle.addEventListener('click', () => {
navList.classList.toggle('active');
});
}
// --- Active Nav Link Highlighting (Basic) ---
// More complex logic needed for accurate highlighting based on scroll
position
// This is a simplified version based on clicks
const navAnchors = document.querySelectorAll('.nav-links a');
navAnchors.forEach(anchor => {
anchor.addEventListener('click', function() {
navAnchors.forEach(a => a.classList.remove('active'));
this.classList.add('active');
})
})
});
</script>
<!-- Optional: Add Font Awesome for Social Icons (if desired) -->
<!-- <script src="https://kit.fontawesome.com/your-fontawesome-kit.js"
crossorigin="anonymous"></script> -->
</body>
</html>