/*
Theme Name: Craftshed
Theme URI: http://craftshed.local
Author: Cursor
Description: Custom WordPress Theme for Craftshed — Blinds, Shutters & Outdoor Living
Version: 1.0.4
Text Domain: craftshed
*/

@font-face {
  font-family: 'Flama';
  src: url('./assets/fonts/FlamaTrial-Basic-BF64c1db8a1e7f6.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: 'Flama';
  src: url('./assets/fonts/FlamaTrial-Medium-BF64c1db89f0be1.otf') format('opentype');
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: 'Flama';
  src: url('./assets/fonts/FlamaTrial-Semibold-BF64c1db8a032cb.otf') format('opentype');
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: 'Flama';
  src: url('./assets/fonts/FlamaTrial-Bold-BF64c1db88e5897.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: 'Flama';
  src: url('./assets/fonts/FlamaTrial-Book-BF64c1db8923fcf.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
}



:root {
  --ink: #0d0d0d;
  --paper: #f5f5f5;
  --cream: #ede8e0;
  --orange: #E8721A;
  --orange-light: #f59040;
  --orange-dark: #c05a10;
  --orange-dim: rgba(232,114,26,0.15);
  --warm-gray: #e6e6e6;
  --mid: #888888;
  --light: #bbbbbb;
  --white: #ffffff;
  --orange: #c05a10;
  --orange-light: #E8721A;
  --outdoor-accent: #E8721A;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
em, i { font-style: normal !important; }
html { scroll-behavior: smooth; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: 'Flama', sans-serif;
  font-weight: 300;
  cursor: none;
  overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }

/* CURSOR */
#cursor { position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; mix-blend-mode: difference; }
#cursor-dot { width: 8px; height: 8px; background: var(--white); border-radius: 50%; position: absolute; transform: translate(-50%, -50%); transition: transform 0.1s; }
#cursor-ring { width: 36px; height: 36px; border: 1px solid var(--white); border-radius: 50%; position: absolute; transform: translate(-50%, -50%); transition: all 0.15s ease; opacity: 0.6; }
body:has(a:hover) #cursor-ring, body:has(button:hover) #cursor-ring { transform: translate(-50%, -50%) scale(1.8); opacity: 0.3; }

/* LOADER */
#loader { position: fixed; inset: 0; background: var(--paper); z-index: 9000; display: flex; align-items: center; justify-content: center; transition: opacity 0.8s ease, visibility 0.8s; }
#loader.done { opacity: 0; visibility: hidden; }
.loader-inner { text-align: center; }
.loader-word { color: var(--ink); font-family: 'Flama', sans-serif; font-size: clamp(1.5rem, 6vw, 6rem); font-weight: 500; letter-spacing: 0.3em; overflow: hidden; white-space: nowrap; }
.loader-word span { display: inline-block; animation: letterRise 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards; opacity: 0; transform: translateY(100%); }
.loader-line { height: 2px; background: var(--orange); width: 0; margin: 1rem auto 0; animation: lineExpand 0.6s ease 0.8s forwards; }
@keyframes letterRise { to { opacity: 1; transform: translateY(0); } }
@keyframes lineExpand { to { width: 100%; } }

/* NAVIGATION — outdoor gets a special pill */
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 2rem 4vw; display: flex; align-items: center; justify-content: space-between; transition: all 0.4s ease; }
nav.scrolled { padding: 1.2rem 4vw; background: rgba(255,255,255,0.95); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(232,114,26,0.2); }
.nav-logo { font-family: 'Flama', sans-serif; font-size: 1.5rem; font-weight: 500; letter-spacing: 0.15em; display: flex; align-items: center; gap: 0.6rem; }
.nav-logo-img { height: 60px; width: auto; object-fit: contain; }
.nav-links { display: flex; gap: 2.2rem; align-items: center; }
.nav-links a { font-size: 0.78rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink); transition: color 0.3s; position: relative; }
.nav-links a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 2px; background: var(--orange); transition: width 0.3s ease; }
.nav-links a:hover { color: var(--orange); }
.nav-links a:hover::after { width: 100%; }
/* OUTDOOR NAV PILL — prominent */
.nav-outdoor-pill { background: rgba(232,114,26,0.15); border: 1px solid rgba(232,114,26,0.5); color: var(--orange) !important; padding: 0.35rem 1rem; border-radius: 2px; transition: all 0.3s ease !important; }
.nav-outdoor-pill::after { background: var(--orange) !important; }
.nav-outdoor-pill:hover { background: rgba(232,114,26,0.25) !important; color: #f5a623 !important; }
.btn-nav { background: transparent; border: 1px solid var(--orange); color: var(--orange); padding: 0.6rem 1.6rem; font-family: 'Flama', sans-serif; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; cursor: none; transition: all 0.3s ease; }
.btn-nav:hover { background: var(--orange); color: var(--white); }

/* SPLIT HERO — left indoor, right outdoor */
#hero { height: 100vh; position: relative; overflow: hidden; display: block; }

.hero-half { position: relative; overflow: hidden; display: flex; align-items: flex-end; padding: 10vh 4vw 10vh; }
.hero-half-bg { position: absolute; inset: 0; }
.hero-half-bg img { width: 100%; height: 115%; object-fit: cover; transition: transform 0.1s; }

/* Indoor half */
.hero-indoor .hero-half-bg img { filter: brightness(0.28) saturate(0.5); }
.hero-indoor .hero-half-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(13,13,13,0.9) 0%, rgba(13,13,13,0.5) 60%, rgba(13,13,13,0.2) 100%); }

/* Outdoor half — greener tint, different atmosphere */
.hero-outdoor .hero-half-bg img { filter: brightness(0.32) saturate(0.7) hue-rotate(-5deg); }
.hero-outdoor .hero-half-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(225deg, rgba(13,13,13,0.9) 0%, rgba(13,13,13,0.5) 60%, rgba(13,13,13,0.2) 100%); }

/* Vertical divider line */
.hero-divider { position: absolute; left: 50%; top: 10%; bottom: 10%; width: 1px; background: linear-gradient(to bottom, transparent, rgba(232,114,26,0.6) 30%, rgba(232,114,26,0.6) 70%, transparent); z-index: 10; pointer-events: none; }

.hero-content { position: relative; z-index: 2; color: var(--white); }
.hero-half-tag { font-size: 0.68rem; letter-spacing: 0.25em; text-transform: uppercase; margin-bottom: 1.6rem; display: flex; align-items: center; gap: 0.8rem; }
.hero-half-tag::before { content: ''; display: block; width: 30px; height: 2px; }
.hero-indoor .hero-half-tag { color: var(--orange); }
.hero-indoor .hero-half-tag::before { background: var(--orange); }
.hero-outdoor .hero-half-tag { color: var(--orange); }
.hero-outdoor .hero-half-tag::before { background: var(--orange); }

.hero-single { display: flex; align-items: center; justify-content: flex-end; text-align: right; }
.hero-single .hero-content { display: flex; flex-direction: column; align-items: flex-end; max-width: 800px; }
.hero-single .hero-ctas { justify-content: flex-end; }

.hero-h1 { font-family: 'Flama', sans-serif; font-size: clamp(2.8rem, 4.5vw, 5.5rem); font-weight: 500; line-height: 1.05; margin-bottom: 1.5rem; }
.hero-indoor .hero-h1 em { font-style: normal; color: var(--orange-light); }
.hero-outdoor .hero-h1 em { font-style: normal; color: var(--orange); }

.hero-sub { font-size: 0.9rem; color: var(--ink); line-height: 1.7; max-width: 380px; margin-bottom: 2.5rem; }
.hero-ctas { display: flex; gap: 1.2rem; align-items: center; flex-wrap: wrap; }
.btn-primary { background: var(--orange); color: var(--white); padding: 0.9rem 2rem; font-family: 'Flama', sans-serif; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; cursor: none; border: none; transition: all 0.3s ease; position: relative; overflow: hidden; }
.btn-primary::before { content: ''; position: absolute; inset: 0; background: var(--orange-dark); transform: scaleX(0); transform-origin: right; transition: transform 0.4s ease; }
.btn-primary:hover::before { transform: scaleX(1); transform-origin: left; }
.btn-primary span { position: relative; z-index: 1; }
/* Outdoor CTA button — orange variant */
.btn-outdoor { background: var(--orange); color: var(--white); padding: 0.9rem 2rem; font-family: 'Flama', sans-serif; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; cursor: none; border: none; transition: all 0.3s ease; position: relative; overflow: hidden; font-weight: 500; }
.btn-outdoor::before { content: ''; position: absolute; inset: 0; background: #E8721A; transform: scaleX(0); transform-origin: right; transition: transform 0.4s ease; }
.btn-outdoor:hover::before { transform: scaleX(1); transform-origin: left; }
.btn-outdoor span { position: relative; z-index: 1; }
.btn-ghost { color: var(--ink); font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; display: flex; align-items: center; gap: 0.8rem; transition: gap 0.3s ease, color 0.3s; cursor: none; white-space: nowrap; }
.btn-ghost:hover { gap: 1.4rem; color: var(--orange-light); }
.btn-ghost::after { content: '→'; font-size: 1rem; }
.btn-ghost-orange:hover { color: var(--orange) !important; }
.btn-ghost-orange::after { content: '→'; }
.btn-ghost-white { color: var(--white) !important; }
.btn-ghost-white:hover { color: var(--orange-light) !important; }

/* Hero stats bar — full width below the split */
.hero-stats-bar { position: absolute; bottom: 0; left: 0; right: 0; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(232,114,26,0.2); z-index: 10; }
.stat-bar-item { padding: 1.2rem 1.5rem; border-right: 1px solid rgba(232,114,26,0.12); display: flex; flex-direction: column; gap: 0.3rem; background: rgba(255,255,255,0.85); backdrop-filter: blur(10px); color: var(--ink); transition: background 0.3s; }
.stat-bar-item:hover { background: rgba(232,114,26,0.06); }
.stat-bar-item:last-child { border-right: none; }
.stat-bar-num { font-family: 'Flama', sans-serif; font-size: 1.8rem; font-weight: 500; line-height: 1; }
.stat-bar-label { font-size: 0.62rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--mid); }
/* Colour-code the stat bar: first 3 = indoor (orange), last 3 = outdoor (orange) */
.stat-bar-item.indoor .stat-bar-num { color: var(--orange-light); }
.stat-bar-item.outdoor .stat-bar-num { color: var(--orange); }
.stat-bar-divider { grid-column: 4 / 5; border-left: 2px solid rgba(232,114,26,0.4); }

.hero-scroll { position: absolute; bottom: 4.5rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.8rem; font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mid); animation: scrollBounce 2s ease-in-out infinite; z-index: 15; }
.scroll-line { width: 1px; height: 30px; background: linear-gradient(to bottom, var(--orange), transparent); }
@keyframes scrollBounce { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(6px); } }

/* MARQUEE */
.marquee-wrap { overflow: hidden; border-top: 1px solid rgba(232,114,26,0.25); border-bottom: 1px solid rgba(232,114,26,0.25); padding: 1.2rem 0; background: rgba(232,114,26,0.04); }
.marquee-track { display: flex; gap: 0; animation: marquee 25s linear infinite; white-space: nowrap; }
.marquee-item { font-family: 'Flama', sans-serif; font-size: 1.1rem; font-weight: 500; letter-spacing: 0.1em; color: var(--mid); padding: 0 3rem; display: flex; align-items: center; gap: 3rem; }
.marquee-item::before { content: '◆'; color: var(--orange); font-size: 0.5rem; }
.marquee-item.orange-item::before { color: var(--orange); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* SECTIONS */
section { padding: 8rem 4vw; }
.section-tag { font-size: 0.7rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--orange); margin-bottom: 1.5rem; display: flex; align-items: center; gap: 1rem; }
.section-tag::before { content: ''; display: block; width: 30px; height: 2px; background: var(--orange); }
.section-tag.orange { color: var(--orange); }
.section-tag.orange::before { background: var(--orange); }

/* REVEAL ANIMATIONS */
.reveal-wrap { overflow: hidden; }
.reveal-text { display: block; transform: translateY(0%); transition: transform 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
.reveal-text.visible { transform: translateY(0); }
.fade-up { opacity: 0; transform: translateY(40px); transition: opacity 0.8s ease, transform 0.8s ease; }
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* ===== OUTDOOR SECTION — MAIN PRIORITY ===== */
/* Outdoor teaser — comes BEFORE indoor products */
#outdoor-teaser { position: relative; overflow: hidden; min-height: 85vh; display: flex; align-items: center; padding: 0; }
.outdoor-teaser-bg { position: absolute; inset: 0; }
.outdoor-teaser-bg img { width: 100%; height: 110%; object-fit: cover; filter: brightness(0.8) saturate(0.9); }
.outdoor-teaser-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(13,13,13,0.6) 0%, rgba(13,13,13,0.4) 50%, rgba(13,13,13,0.15) 100%); }
/* Orange tint overlay for outdoor atmosphere */
.outdoor-teaser-bg::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(232,114,26,0.15) 0%, transparent 70%); z-index: 1; }
.outdoor-teaser-inner { color: var(--white); position: relative; z-index: 2; width: 100%; padding: 8rem 4vw; display: grid; grid-template-columns: 1fr 1fr; gap: 6vw; align-items: center; }
.outdoor-teaser-left { }
.outdoor-big-badge { display: inline-flex; align-items: center; gap: 0.8rem; border: 1px solid rgba(232,114,26,0.4); color: var(--orange); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; padding: 0.5rem 1.2rem; margin-bottom: 2rem; }
.outdoor-big-badge::before { content: ''; width: 6px; height: 6px; background: var(--orange); border-radius: 50%; }
.outdoor-teaser-h2 { font-family: 'Flama', sans-serif; font-size: clamp(3rem, 5.5vw, 5.5rem); font-weight: 500; line-height: 1.08; margin-bottom: 1.5rem; }
.outdoor-teaser-h2 em { font-style: normal; color: var(--orange); }
.outdoor-teaser-p { font-size: 1rem; color: rgba(255,255,255,0.9); line-height: 1.8; max-width: 480px; margin-bottom: 2.5rem; }
.outdoor-teaser-ctas { display: flex; gap: 1.5rem; align-items: center; }
.outdoor-stats-row { display: flex; gap: 0; margin-top: 3.5rem; border-top: 1px solid rgba(232,114,26,0.2); padding-top: 2.5rem; }
.outdoor-stat { padding-right: 2.5rem; border-right: 1px solid rgba(232,114,26,0.15); margin-right: 2.5rem; }
.outdoor-stat:last-child { border-right: none; }
.outdoor-stat-num { font-family: 'Flama', sans-serif; font-size: 2.8rem; font-weight: 500; color: var(--orange); line-height: 1; }
.outdoor-stat-label { font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--mid); margin-top: 0.4rem; }

/* Outdoor right: category cards stack */
.outdoor-teaser-right { display: flex; flex-direction: column; gap: 3px; }
.outdoor-cat-mini { position: relative; overflow: hidden; height: 170px; cursor: none; }
.outdoor-cat-mini img { width: 100%; height: 100%; object-fit: cover; object-position: top; filter: brightness(0.9) saturate(1); transition: transform 0.5s ease, filter 0.4s; }
.outdoor-cat-mini:hover img { transform: scale(1.06); filter: brightness(1) saturate(1); }
.outdoor-cat-mini-info { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 1.4rem; background: linear-gradient(to top, rgba(13,13,13,0.65) 0%, transparent 65%); }
.outdoor-cat-mini-label { font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white); margin-bottom: 0.3rem; }
.outdoor-cat-mini-name { font-family: 'Flama', sans-serif; font-size: 1.25rem; font-weight: 500; color: var(--white); }
.outdoor-cat-mini-arrow { position: absolute; top: 1.2rem; right: 1.2rem; width: 32px; height: 32px; border: 1px solid rgba(232,114,26,0.4); display: flex; align-items: center; justify-content: center; color: var(--orange); font-size: 0.8rem; opacity: 0; transition: opacity 0.3s; }
.outdoor-cat-mini:hover .outdoor-cat-mini-arrow { opacity: 1; }

/* OUTDOOR FEATURE — full bleed with overlay cards */
#outdoor-features { background: var(--paper); position: relative; overflow: hidden; }
#outdoor-features::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 70% 50% at 50% 50%, rgba(232,114,26,0.08) 0%, transparent 70%); pointer-events: none; }
.outdoor-features-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 4rem; }
.outdoor-products-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3px; }
/* First card is tall/featured */
.outdoor-prod-card { position: relative; overflow: hidden; cursor: none; }
.outdoor-prod-card.featured { grid-row: 1 / 3; }
.outdoor-prod-card img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.9) saturate(1); transition: transform 0.6s ease, filter 0.4s; }
.outdoor-prod-card:hover img { transform: scale(1.06); filter: brightness(1) saturate(1); }
.outdoor-prod-info { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem; background: linear-gradient(to top, rgba(13,13,13,0.65) 0%, transparent 100%); transform: translateY(40%); transition: transform 0.5s ease; }
.outdoor-prod-card:hover .outdoor-prod-info { transform: translateY(0); }
.outdoor-prod-label { font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white); margin-bottom: 0.5rem; }
.outdoor-prod-name { font-family: 'Flama', sans-serif; font-size: 1.6rem; font-weight: 500; margin-bottom: 0.8rem; line-height: 1.2; color: var(--white); }
.outdoor-prod-desc { font-size: 0.82rem; color: rgba(255,255,255,0.8); line-height: 1.7; opacity: 0; transition: opacity 0.4s 0.1s; }
.outdoor-prod-card:hover .outdoor-prod-desc { opacity: 1; }
.outdoor-prod-cta { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--white); background: var(--orange); padding: 0.6rem 1.2rem; margin-top: 1rem; opacity: 0; transform: translateY(8px); transition: opacity 0.4s 0.15s, transform 0.4s 0.15s; }
.outdoor-prod-card:hover .outdoor-prod-cta { opacity: 1; transform: translateY(0); }
/* Height fixes */
.outdoor-prod-card.featured { min-height: 600px; }
.outdoor-prod-card:not(.featured) { min-height: 298px; }
/* Orange accent badge on featured */
.featured-badge { position: absolute; top: 1.5rem; left: 1.5rem; background: var(--orange); color: var(--white); font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; padding: 0.35rem 0.9rem; font-weight: 500; z-index: 2; }

/* OUTDOOR SUB-PRODUCTS SCROLL */
.outdoor-scroll { display: flex; gap: 2px; overflow-x: auto; scrollbar-width: none; margin-top: 3px; }
.outdoor-scroll::-webkit-scrollbar { display: none; }
.outdoor-scroll-card { flex: 1; min-width: 140px; background: rgba(0,0,0,0.03); border: 1px solid rgba(232,114,26,0.1); position: relative; overflow: hidden; cursor: none; transition: border-color 0.3s; }
.outdoor-scroll-card:hover { border-color: rgba(232,114,26,0.4); }
.outdoor-scroll-img { width: 100%; aspect-ratio: 1; overflow: hidden; }
.outdoor-scroll-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.7); transition: transform 0.5s, filter 0.3s; }
.outdoor-scroll-card:hover .outdoor-scroll-img img { transform: scale(1.06); filter: brightness(0.88); }
.outdoor-scroll-info { padding: 1.1rem; }
.outdoor-scroll-tag { font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--orange); margin-bottom: 0.3rem; }
.outdoor-scroll-name { font-family: 'Flama', sans-serif; font-size: 1.1rem; font-weight: 500; margin-bottom: 0.5rem; }
.outdoor-scroll-btn { display: inline-block; font-size: 0.65rem; letter-spacing: 0.12em; text-transform: uppercase; border: 1px solid rgba(232,114,26,0.4); color: var(--orange); padding: 0.3rem 0.8rem; transition: background 0.3s, color 0.3s; }
.outdoor-scroll-card:hover .outdoor-scroll-btn { background: var(--orange); color: var(--white); }

/* PERFORMANCE — outdoor focused */
#outdoor-performance { background: var(--white); position: relative; }
#outdoor-performance::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 50% 60% at 20% 50%, rgba(232,114,26,0.12) 0%, transparent 60%); pointer-events: none; }
.perf-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 4rem; }
.perf-card { padding: 3rem 2.5rem; border: 1px solid rgba(232,114,26,0.1); transition: border-color 0.4s, background 0.4s; position: relative; }
.perf-card::before { content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 0; background: var(--orange); transition: height 0.5s ease; }
.perf-card:hover::before { height: 100%; }
.perf-card:hover { border-color: rgba(232,114,26,0.3); background: rgba(232,114,26,0.04); }
.perf-icon { font-size: 1.8rem; margin-bottom: 1.2rem; }
.perf-title { font-family: 'Flama', sans-serif; font-size: 1.4rem; font-weight: 500; margin-bottom: 0.8rem; }
.perf-text { font-size: 0.85rem; color: var(--ink); line-height: 1.8; }

/* VALUES SECTION (indoor) */
#values { position: relative; }
.values-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-top: 5rem; }
.value-card { padding: 3.5rem; border: 1px solid rgba(232,114,26,0.15); position: relative; overflow: hidden; transition: all 0.5s ease; }
.value-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(232,114,26,0.08) 0%, transparent 60%); opacity: 0; transition: opacity 0.5s; }
.value-card:hover::before { opacity: 1; }
.value-card:hover { border-color: rgba(232,114,26,0.45); }
.value-num { font-family: 'Flama', sans-serif; font-size: 5rem; font-weight: 500; color: rgba(232,114,26,0.1); position: absolute; top: 1.5rem; right: 2rem; line-height: 1; pointer-events: none; transition: color 0.5s; }
.value-card:hover .value-num { color: rgba(232,114,26,0.22); }
.value-icon { width: 40px; height: 40px; margin-bottom: 1.5rem; border: 1px solid rgba(232,114,26,0.5); display: flex; align-items: center; justify-content: center; }
.value-icon svg { width: 18px; height: 18px; stroke: var(--orange); fill: none; }
.value-title { font-family: 'Flama', sans-serif; font-size: 1.6rem; font-weight: 500; margin-bottom: 1rem; line-height: 1.2; }
.value-text { font-size: 0.9rem; color: var(--ink); line-height: 1.8; }

/* INDOOR PRODUCTS */
#products { background: var(--warm-gray); }
.products-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 4rem; }
.products-scroll { display: flex; gap: 2px; overflow-x: auto; scrollbar-width: none; padding-bottom: 1rem; scroll-snap-type: x mandatory; }
.products-scroll::-webkit-scrollbar { display: none; }
.product-card { flex: 0 0 calc(20% - 2px); min-width: 260px; aspect-ratio: 3/4; position: relative; overflow: hidden; scroll-snap-align: start; cursor: none; background: var(--paper); }
.product-bg { position: absolute; inset: 0; transition: transform 0.6s ease; }
.product-card:hover .product-bg { transform: scale(1.08); }
.product-bg img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.65) saturate(0.8); }
.product-info { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem 1.8rem; background: linear-gradient(to top, rgba(13,13,13,0.65) 0%, transparent 100%); transform: translateY(30%); transition: transform 0.5s ease; }
.product-card:hover .product-info { transform: translateY(0); }
.product-label { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white); margin-bottom: 0.6rem; }
.product-name { font-family: 'Flama', sans-serif; font-size: 1.5rem; font-weight: 500; line-height: 1.2; margin-bottom: 1rem; color: var(--white); }
.product-desc { font-size: 0.82rem; color: rgba(255,255,255,0.8); line-height: 1.7; opacity: 0; transition: opacity 0.4s 0.1s; }
.product-card:hover .product-desc { opacity: 1; }
.product-cta { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--white); background: var(--orange); padding: 0.6rem 1.2rem; margin-top: 1rem; opacity: 0; transform: translateY(10px); transition: opacity 0.4s 0.15s, transform 0.4s 0.15s; }
.product-card:hover .product-cta { opacity: 1; transform: translateY(0); }
/* SHUTTERS */
.shutters-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; }
.shutter-card { flex: none; min-width: auto; aspect-ratio: 16/10; }

/* PROCESS */
#process { overflow: hidden; }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 5rem; position: relative; }
.process-grid::before { content: ''; position: absolute; top: 2.5rem; left: 0; right: 0; height: 1px; background: linear-gradient(to right, rgba(232,114,26,0.4), rgba(232,114,26,0.4) 50%, rgba(232,114,26,0.1)); z-index: 0; }
.process-step { padding: 0 2.5rem 0 0; position: relative; z-index: 1; transition: transform 0.4s ease; }
.process-step:hover { transform: translateY(-8px); }
.step-dot { width: 20px; height: 20px; border: 1px solid var(--orange); border-radius: 50%; background: var(--paper); margin-bottom: 2rem; position: relative; transition: background 0.3s; display: flex; align-items: center; justify-content: center; }
.process-step:hover .step-dot { background: var(--orange); }
.step-dot::after { content: ''; width: 6px; height: 6px; background: var(--orange); border-radius: 50%; transition: background 0.3s; }
.process-step:hover .step-dot::after { background: var(--white); }
.step-num { font-family: 'Flama', sans-serif; font-size: 0.75rem; color: var(--orange); letter-spacing: 0.1em; margin-bottom: 1rem; }
.step-title { font-family: 'Flama', sans-serif; font-size: 1.4rem; font-weight: 500; margin-bottom: 1rem; line-height: 1.3; }
.step-text { font-size: 0.85rem; color: var(--ink); line-height: 1.8; }

/* TESTIMONIALS */
#testimonials { background: var(--paper); overflow: hidden; padding-top: 3rem; padding-bottom: 3rem; }
#process { padding-bottom: 3rem; }
#our-works { padding-top: 3rem; }
.testi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(232,114,26,0.12); margin-top: 4rem; }
.testi-card { background: var(--paper); padding: 3rem; position: relative; overflow: hidden; opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease, background 0.4s; }
.testi-card.visible { opacity: 1; transform: translateY(0); }
.testi-card:hover { background: rgba(232,114,26,0.04); }
.testi-quote { font-family: 'Flama', sans-serif; font-size: 3rem; color: var(--orange); opacity: 0.5; line-height: 1; margin-bottom: 1.5rem; }
.testi-text { font-family: 'Flama', sans-serif; font-size: 0.9rem; font-weight: 300; font-style: normal; line-height: 1.7; color: var(--ink); margin-bottom: 2rem; }
.testi-stars { color: var(--orange); font-size: 0.8rem; letter-spacing: 0.2em; margin-bottom: 1rem; }
.testi-author { font-size: 0.8rem; letter-spacing: 0.1em; color: var(--mid); display: flex; align-items: center; gap: 0.8rem; }
.testi-author strong { color: var(--ink); font-weight: 400; letter-spacing: 0.15em; text-transform: uppercase; }
.testi-avatar { width: 38px; height: 38px; border-radius: 50%; overflow: hidden; border: 1px solid rgba(232,114,26,0.4); flex-shrink: 0; }
.testi-avatar img { width: 100%; height: 100%; object-fit: cover; }

/* GALLERY */
#gallery { padding: 0; }
.gallery-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 400px 300px; gap: 2px; }
.gallery-item { position: relative; overflow: hidden; cursor: none; background: var(--warm-gray); }
.gallery-item:first-child { grid-row: 1 / 3; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; filter: brightness(0.75) saturate(0.8); }
.gallery-item:hover img { transform: scale(1.05); filter: brightness(0.9) saturate(1); }
.gallery-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(13,13,13,0.55) 0%, transparent 50%); opacity: 0; transition: opacity 0.4s; display: flex; align-items: flex-end; padding: 2rem; }
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-label { font-family: 'Flama', sans-serif; font-size: 1.2rem; color: var(--white); }

/* OUR WORKS */
#our-works { padding: 8rem 4vw; }
.works-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; margin-top: 4rem; }
.work-item { position: relative; overflow: hidden; aspect-ratio: 1; cursor: none; }
.work-item img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.7) saturate(0.8); transition: transform 0.5s ease, filter 0.4s; }
.work-item:hover img { transform: scale(1.07); filter: brightness(0.9) saturate(1); }
.work-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(13,13,13,0.6) 0%, transparent 50%); opacity: 0; transition: opacity 0.4s; display: flex; align-items: flex-end; padding: 1.5rem; }
.work-item:hover .work-overlay { opacity: 1; }
.work-label { font-family: 'Flama', sans-serif; font-size: 1rem; color: var(--white); }

/* EXPERIENCE STATS */
#bworth-experience { background: var(--paper); padding: 8rem 4vw; }
.experience-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 4rem; }
.exp-card { padding: 3rem 2rem; border: 1px solid rgba(232,114,26,0.12); text-align: center; transition: border-color 0.4s, background 0.4s; }
.exp-card:hover { border-color: rgba(232,114,26,0.4); background: rgba(232,114,26,0.05); }
.exp-num { font-family: 'Flama', sans-serif; font-size: 3.5rem; font-weight: 500; color: var(--orange-light); line-height: 1; margin-bottom: 0.5rem; }
.exp-title { font-family: 'Flama', sans-serif; font-size: 1.2rem; font-weight: 500; margin-bottom: 0.8rem; }
.exp-text { font-size: 0.82rem; color: var(--ink); line-height: 1.7; }

/* MARQUEE BOTTOM — orange bar */
.marquee-wrap-dark { overflow: hidden; background: var(--orange); padding: 1rem 0; }
.marquee-track-dark { display: flex; gap: 0; animation: marquee 20s linear infinite; white-space: nowrap; }
.marquee-item-dark { font-family: 'Flama', sans-serif; font-size: 0.75rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--orange); padding: 0 2.5rem; display: flex; align-items: center; gap: 2.5rem; }
.marquee-item-dark::before { content: '◆'; font-size: 0.4rem; }

/* CTA SECTION */
#cta { text-align: center; position: relative; overflow: hidden; background: var(--warm-gray); }
#cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(232,114,26,0.1) 0%, transparent 70%); }
.cta-inner { position: relative; z-index: 1; }
.cta-h2 { font-family: 'Flama', sans-serif; font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 500; line-height: 1.1; margin-bottom: 1.5rem; }
.cta-h2 em { font-style: normal; color: var(--orange-light); }
.cta-sub { font-size: 1rem; color: var(--ink); margin-bottom: 3rem; max-width: 500px; margin-left: auto; margin-right: auto; }
.cta-buttons { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.contact-strip { display: flex; justify-content: center; gap: 4rem; margin-top: 4rem; padding-top: 3rem; border-top: 1px solid rgba(232,114,26,0.18); flex-wrap: wrap; }
.contact-item { text-align: center; }
.contact-label { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mid); margin-bottom: 0.5rem; }
.contact-val { font-family: 'Flama', sans-serif; font-size: 1.3rem; color: var(--orange-light); }

/* FOOTER */
footer { padding: 4rem 4vw 3rem; border-top: 1px solid rgba(232,114,26,0.15); display: grid; grid-template-columns: 2fr repeat(3, 1fr); gap: 4rem; }
.footer-brand { }
.footer-logo { font-family: 'Flama', sans-serif; font-size: 1.6rem; font-weight: 500; letter-spacing: 0.15em; margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.5rem; }
.footer-logo img { height: 65px; width: auto; object-fit: contain; }
.footer-tagline { font-size: 0.85rem; color: var(--mid); line-height: 1.7; max-width: 260px; margin-top: 0.8rem; }
.footer-col h4 { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--orange); margin-bottom: 1.5rem; }
.footer-col.orange-col h4 { color: var(--orange); }
.footer-col a { display: block; font-size: 0.85rem; color: var(--mid); margin-bottom: 0.8rem; transition: color 0.3s; }
.footer-col a:hover { color: var(--ink); }
.footer-bottom { padding: 1.5rem 4vw; border-top: 1px solid rgba(232,114,26,0.1); display: flex; justify-content: space-between; align-items: center; font-size: 0.75rem; color: var(--mid); }

/* Section separator — outdoor/indoor visual divider */
.section-divider { height: 3px; background: linear-gradient(to right, var(--orange), var(--orange)); margin: 0; }
.section-divider-label { background: var(--paper); padding: 1rem 4vw; display: flex; align-items: center; gap: 2rem; border-bottom: 1px solid rgba(232,114,26,0.12); }
.divider-item { display: flex; align-items: center; gap: 0.6rem; font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; }
.divider-dot { width: 8px; height: 8px; border-radius: 50%; }

/* MOBILE MENU */
.mobile-menu-btn { display: none; flex-direction: column; justify-content: space-between; width: 32px; height: 20px; background: none; border: none; cursor: pointer; z-index: 1000; padding: 0; }
.mobile-menu-btn span { display: block; width: 100%; height: 2px; background: var(--white); transition: all 0.3s ease; transform-origin: left center; }
#nav.scrolled .mobile-menu-btn span { background: var(--ink); }
.mobile-menu-btn.open span:nth-child(1) { transform: rotate(45deg) translate(2px, -2px); }
.mobile-menu-btn.open span:nth-child(2) { opacity: 0; width: 0; }
.mobile-menu-btn.open span:nth-child(3) { transform: rotate(-45deg) translate(2px, 2px); }
.mobile-menu-btn.open span { background: var(--white) !important; }

.mobile-menu-overlay { position: fixed; inset: 0; background: rgba(13,13,13,0.98); z-index: 999; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.4s ease; backdrop-filter: blur(10px); }
.mobile-menu-overlay.active { opacity: 1; pointer-events: all; }
.mobile-nav-links { display: flex; flex-direction: column; gap: 2rem; align-items: center; transform: translateY(30px); transition: transform 0.4s ease; }
.mobile-menu-overlay.active .mobile-nav-links { transform: translateY(0); }
.mobile-nav-links a { font-family: 'Flama', sans-serif; font-size: 1.5rem; font-weight: 500; color: var(--white); text-transform: uppercase; letter-spacing: 0.15em; transition: color 0.3s; }
.mobile-nav-links a:hover, .mobile-nav-links a.active { color: var(--orange); }

/* RESPONSIVE */
@media (max-width: 900px) {
  .nav-links { display: none; }
  .mobile-menu-btn { display: flex; }
  #hero { grid-template-columns: 1fr; }
  .hero-half.hero-outdoor { display: none; }
  .hero-half.hero-indoor { height: 100vh; }
  .hero-single { justify-content: center; text-align: center; }
  .hero-single .hero-content { align-items: center; }
  .hero-single .hero-ctas { justify-content: center; }
  .hero-stats-bar { grid-template-columns: repeat(2, 1fr); }
  .values-grid, .testi-grid, .experience-grid, .perf-grid { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 250px 250px 250px; }
  .gallery-item:first-child { grid-row: auto; }
  footer { grid-template-columns: 1fr 1fr; }
  .outdoor-teaser-inner { color: var(--white); grid-template-columns: 1fr; }
  .outdoor-products-grid { grid-template-columns: 1fr; }
  .outdoor-prod-card.featured { grid-row: auto; min-height: 400px; }
  .works-grid { grid-template-columns: 1fr 1fr; }
  .hero-divider { display: none; }
  .shutters-grid { grid-template-columns: 1fr; }
  .shutter-card { aspect-ratio: 4/3; }
  .outdoor-scroll-card { flex: 0 0 260px; }
}

@media (max-width: 600px) {
  .nav-logo-img { height: 40px; }
  nav { padding: 1rem 4vw; background: rgba(255,255,255,0.98); border-bottom: 1px solid rgba(232,114,26,0.1); }
  .mobile-menu-btn span { background: var(--ink); }
  .mobile-menu-btn.open span { background: var(--white) !important; }
  .hero-half { padding: 30vh 4vw 10vh; }
  section { padding: 4rem 4vw; }
  #bworth-experience { padding: 4rem 4vw; }
  .outdoor-teaser-inner { padding: 4rem 4vw; gap: 3rem; }
  .outdoor-teaser-h2 { font-size: clamp(2.5rem, 8vw, 3rem); }
  .cta-h2 { font-size: clamp(2.5rem, 8vw, 3rem); }
  .outdoor-teaser-ctas { flex-direction: column; width: 100%; align-items: stretch; text-align: center; }
  .outdoor-stats-row { flex-direction: column; gap: 1.5rem; border-top: none; padding-top: 1.5rem; text-align: center; }
  .outdoor-stat { padding-right: 0; margin-right: 0; border-right: none; border-bottom: 1px solid rgba(232,114,26,0.15); padding-bottom: 1.5rem; }
  .outdoor-stat:last-child { border-bottom: none; padding-bottom: 0; }
  .value-card { padding: 2rem 1.5rem; }
  .process-grid { grid-template-columns: 1fr; margin-top: 3rem; gap: 2rem; }
  .process-grid::before { display: none; }
  .process-step { padding-right: 0; }
  .step-dot { margin-bottom: 1rem; }
  .exp-card { padding: 2.5rem 1.5rem; }
  .contact-strip { flex-direction: column; gap: 2.5rem; }
  footer { grid-template-columns: 1fr; gap: 3rem; text-align: center; padding-top: 3rem; }
  .footer-logo { justify-content: center; }
  .footer-tagline { margin: 0.8rem auto 0; }
  .footer-bottom { flex-direction: column; gap: 1rem; text-align: center; }
  .works-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
  .gallery-item { min-height: 250px; }
  .products-header { flex-direction: column; align-items: flex-start; gap: 1.5rem; margin-bottom: 2rem; }
  .outdoor-features-header { flex-direction: column; align-items: flex-start; gap: 1.5rem; margin-bottom: 2rem; }
}

/* QUOTE MODAL */
.quote-modal-overlay { position: fixed; inset: 0; background: rgba(13,13,13,0.7); backdrop-filter: blur(8px); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.4s ease; padding: 2rem 4vw; }
.quote-modal-overlay.active { opacity: 1; pointer-events: all; }
.quote-modal-container { background: var(--white); border: 1px solid rgba(232,114,26,0.15); width: 100%; max-width: 800px; padding: 3rem; position: relative; transform: translateY(30px); transition: transform 0.4s ease; border-radius: 4px; overflow-y: auto; max-height: 90vh; }
.quote-modal-overlay.active .quote-modal-container { transform: translateY(0); }
.quote-modal-close { position: absolute; top: 1.5rem; right: 1.5rem; background: none; border: none; color: var(--mid); font-size: 2.5rem; line-height: 1; cursor: pointer; transition: color 0.3s; padding: 0; display: flex; }
.quote-modal-close:hover { color: var(--ink); }

.quote-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.form-group.full-width { grid-column: 1 / -1; }
.quote-form-grid input[type="text"], .quote-form-grid input[type="email"], .quote-form-grid input[type="tel"], .quote-form-grid textarea { width: 100%; background: var(--paper); border: 1px solid rgba(13,13,13,0.1); padding: 1.2rem 1.2rem; color: var(--ink); font-family: 'Flama', sans-serif; transition: border-color 0.3s; border-radius: 2px; }
.quote-form-grid textarea { min-height: 90px; resize: vertical; }
.quote-form-grid input:focus, .quote-form-grid textarea:focus { border-color: var(--orange); outline: none; }
.showroom-group { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; margin-top: 0.5rem; }
.showroom-group label { color: var(--ink); font-size: 1rem; font-weight: 500; }
.showroom-group .wpcf7-list-item { display: inline-flex; align-items: center; gap: 0.5rem; margin-right: 1.5rem; color: var(--ink); }
.showroom-group input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--orange); cursor: pointer; }
.quote-form-grid input[type="submit"] { background: var(--orange); border: 1px solid var(--orange); color: var(--white); padding: 1rem 3rem; text-transform: uppercase; letter-spacing: 0.1em; cursor: pointer; transition: all 0.3s; margin-top: 1rem; }
.quote-form-grid input[type="submit"]:hover { background: transparent; color: var(--orange); }

@media (max-width: 600px) {
  .quote-form-grid { grid-template-columns: 1fr; }
  .quote-modal-container { padding: 2.5rem 1.5rem; }
}

/* MODAL OPEN STATE - CURSOR FIX */
body.modal-open { cursor: auto !important; }
body.modal-open * { cursor: auto; }
body.modal-open #cursor { display: none !important; }
body.modal-open button, body.modal-open a, body.modal-open input[type="submit"], body.modal-open input[type="checkbox"], body.modal-open .quote-modal-close { cursor: pointer !important; }
body.modal-open input[type="text"], body.modal-open input[type="email"], body.modal-open input[type="tel"], body.modal-open textarea { cursor: text !important; }

/* DISABLE CUSTOM CURSOR ON TOUCH DEVICES */
@media (hover: none) and (pointer: coarse), (max-width: 768px) {
  #cursor { display: none !important; }
  body, * { cursor: auto !important; }
  a, button, input[type="submit"], input[type="checkbox"], 
  .btn-primary, .btn-outdoor, .btn-ghost, .btn-nav, 
  .product-card, .work-item, .gallery-item, 
  .outdoor-cat-mini, .outdoor-prod-card, .outdoor-scroll-card {
    cursor: pointer !important;
  }
}

/* FLOATING MOBILE QUOTE BUTTON */
.mobile-floating-quote { display: none; }
@media (max-width: 768px) {
  .mobile-floating-quote {
    display: block;
    position: fixed;
    bottom: 20px;
    right: 20px;
    background: var(--orange);
    color: var(--white);
    padding: 1rem 1.5rem;
    border-radius: 50px;
    font-family: 'Flama', sans-serif;
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border: none;
    z-index: 8000;
    box-shadow: 0 6px 20px rgba(232,114,26,0.4);
    cursor: pointer !important;
  }
}
