/* ============================================================
   Rogers Machine Works — style.css
   All global styles. Page-specific overrides at bottom.
   ============================================================ */

/* ---- TOKENS ---- */
:root {
  --orange:       #D95F0E;
  --orange-light: #F07030;
  --orange-pale:  #FDF0E8;
  --white:        #FAFAF8;
  --cream:        #F5F2EE;
  --ink:          #1C1A17;
  --mid:          #6B6560;
  --border:       #E2DDD8;
}

/* ---- RESET ---- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html  { scroll-behavior: smooth; overflow-x: hidden; }
body  { font-family: 'DM Sans', sans-serif; background: var(--white); color: var(--ink); overflow-x: hidden; cursor: none; max-width: 100%; }

/* ---- CUSTOM CURSOR ---- */
#cursor      { position: fixed; width: 10px; height: 10px; background: var(--orange); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); mix-blend-mode: multiply; left: -100px; top: -100px; contain: strict; }
#cursor-ring { position: fixed; width: 36px; height: 36px; border: 1.5px solid var(--orange); border-radius: 50%; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: width 0.3s, height 0.3s; opacity: 0.6; left: -100px; top: -100px; contain: strict; }
body.cursor-hover #cursor-ring { width: 56px; height: 56px; }

/* ---- NAV ---- */
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 500; height: 72px; display: flex; align-items: center; justify-content: space-between; padding: 0 5%; transition: background 0.4s, box-shadow 0.4s; }
nav.scrolled { background: rgba(250,250,248,0.97); backdrop-filter: blur(12px); box-shadow: 0 1px 0 var(--border); }
.nav-logo     { font-family: 'Oswald', sans-serif; font-size: 1.1rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--ink); text-decoration: none; }
.nav-logo em  { color: var(--orange); font-style: normal; }
.nav-links    { display: flex; gap: 2.5rem; list-style: none; align-items: center; }
.nav-links a  { font-size: 0.78rem; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; color: var(--ink); text-decoration: none; position: relative; transition: color 0.2s; }
.nav-links a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 1.5px; background: var(--orange); transition: width 0.3s; }
.nav-links a:hover,
.nav-links a.active { color: var(--orange); }
.nav-links a:hover::after,
.nav-links a.active::after { width: 100%; }
.nav-cta             { background: var(--orange) !important; color: var(--white) !important; padding: 9px 22px !important; transition: background 0.2s !important; }
.nav-cta::after      { display: none !important; }
.nav-cta:hover       { background: var(--orange-light) !important; }

/* ---- DARK HERO NAV (inner pages) ---- */
/* Over dark .page-hero before scrolling */
nav.dark-hero .nav-logo          { color: var(--white); }
nav.dark-hero .nav-logo em       { color: var(--orange); }
nav.dark-hero .nav-links a       { color: rgba(255,255,255,0.85); }
nav.dark-hero .nav-links a:hover { color: var(--white); }
nav.dark-hero .nav-links a.active{ color: var(--orange); }
nav.dark-hero .burger span       { background: var(--white); }
/* Once scrolled, .scrolled overrides everything back to normal */
nav.dark-hero.scrolled .nav-logo          { color: var(--ink); }
nav.dark-hero.scrolled .nav-links a       { color: var(--ink); }
nav.dark-hero.scrolled .nav-links a:hover { color: var(--orange); }
nav.dark-hero.scrolled .burger span       { background: var(--ink); }

/* ---- BURGER / MOBILE MENU ---- */
.burger       { display: none; flex-direction: column; gap: 6px; background: none; border: none; padding: 6px; cursor: none; z-index: 600; }
.burger span  { display: block; width: 24px; height: 1.5px; background: var(--ink); transition: all 0.35s cubic-bezier(0.77,0,0.175,1); }
.burger.open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
/* Nav goes white with dark logo when mobile menu is open */
nav.menu-open,
nav.menu-open.scrolled,
nav.menu-open.dark-hero,
nav.menu-open.dark-hero.scrolled {
  background: rgba(250,250,248,0.97) !important;
  box-shadow: 0 1px 0 var(--border) !important;
}
nav.menu-open .nav-logo,
nav.menu-open.scrolled .nav-logo,
nav.menu-open.dark-hero .nav-logo,
nav.menu-open.dark-hero.scrolled .nav-logo { color: var(--ink) !important; }
nav.menu-open .burger span,
nav.menu-open.scrolled .burger span,
nav.menu-open.dark-hero .burger span,
nav.menu-open.dark-hero.scrolled .burger span { background: var(--ink) !important; }

/* ---- MODAL ---- */
.modal-overlay { position: fixed; inset: 0; background: rgba(28,26,23,0.75); z-index: 800; display: flex; align-items: center; justify-content: center; padding: 1.5rem; opacity: 0; pointer-events: none; transition: opacity 0.3s; backdrop-filter: blur(4px); }
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal-box    { background: var(--white); width: 100%; max-width: 560px; max-height: 90vh; overflow-y: auto; position: relative; transform: translateY(24px) scale(0.97); transition: transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94); }
.modal-overlay.open .modal-box { transform: none; }
.modal-header { background: var(--ink); padding: 2rem 2rem 1.5rem; position: relative; }
.modal-header .section-label { color: var(--orange); margin-bottom: 0.5rem; }
.modal-title  { font-family: 'Oswald', sans-serif; font-size: 1.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--white); line-height: 1; }
.modal-title em { color: var(--orange); font-style: normal; }
.modal-close  { position: absolute; top: 1.25rem; right: 1.25rem; width: 36px; height: 36px; background: rgba(255,255,255,0.1); border: none; color: var(--white); font-size: 1.1rem; cursor: none; display: flex; align-items: center; justify-content: center; transition: background 0.2s; line-height: 1; }
.modal-close:hover { background: var(--orange); }
.modal-body   { padding: 2rem; }

/* ---- FORMS ---- */
.form-row     { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
.form-field   { display: flex; flex-direction: column; gap: 6px; margin-bottom: 1rem; }
.form-field label { font-size: 0.7rem; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; color: var(--mid); }
.form-field input,
.form-field select,
.form-field textarea { background: var(--cream); border: 1.5px solid var(--border); color: var(--ink); font-family: 'DM Sans', sans-serif; font-size: 0.95rem; padding: 11px 14px; outline: none; transition: border-color 0.25s, box-shadow 0.25s; appearance: none; width: 100%; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus { border-color: var(--orange); box-shadow: 0 0 0 3px rgba(217,95,14,0.1); }
.form-field textarea { min-height: 100px; resize: vertical; }
.form-submit  { width: 100%; background: var(--orange); color: var(--white); font-family: 'DM Sans', sans-serif; font-weight: 500; font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase; padding: 15px; border: none; cursor: none; transition: background 0.25s; position: relative; overflow: hidden; }
.form-submit::before { content: ''; position: absolute; inset: 0; background: var(--orange-light); transform: translateX(-100%); transition: transform 0.3s; }
.form-submit:hover::before { transform: translateX(0); }
.form-submit span { position: relative; z-index: 1; }

/* Success / error notice */
.form-notice        { padding: 14px 18px; margin-bottom: 1.25rem; font-size: 0.9rem; font-weight: 500; }
.form-notice.success{ background: #e6f4ea; color: #2e7d32; border-left: 4px solid #4caf50; }
.form-notice.error  { background: #fdecea; color: #c62828; border-left: 4px solid #ef5350; }

/* ---- BUTTONS ---- */
.btn        { display: inline-flex; align-items: center; gap: 10px; font-size: 0.82rem; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; padding: 14px 28px; transition: all 0.25s; position: relative; overflow: hidden; border: none; font-family: 'DM Sans', sans-serif; cursor: none; }
.btn-solid  { background: var(--orange); color: var(--white); }
.btn-solid::before { content: ''; position: absolute; inset: 0; background: var(--orange-light); transform: translateX(-100%); transition: transform 0.3s; }
.btn-solid:hover::before { transform: translateX(0); }
.btn-solid span, .btn-solid .btn-arrow { position: relative; z-index: 1; }
.btn-ghost  { background: transparent; color: var(--ink); border: 1.5px solid var(--border); }
.btn-ghost:hover { border-color: var(--orange); color: var(--orange); }
.btn-arrow  { transition: transform 0.25s; display: inline-block; }
.btn:hover .btn-arrow { transform: translateX(4px); }
.btn-white  { background: var(--white); color: var(--orange); font-family: 'DM Sans', sans-serif; font-weight: 600; font-size: 0.85rem; letter-spacing: 1.5px; text-transform: uppercase; padding: 15px 32px; border: none; cursor: none; white-space: nowrap; transition: background 0.2s, color 0.2s; display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }
.btn-white:hover { background: var(--ink); color: var(--white); }

/* ---- SECTION BASICS ---- */
section { padding: 7rem 5%; width: 100%; max-width: 100%; }
.section-label { display: inline-flex; align-items: center; gap: 10px; font-size: 0.72rem; font-weight: 500; letter-spacing: 4px; text-transform: uppercase; color: var(--orange); margin-bottom: 1rem; }
.section-label::before { content: ''; display: block; width: 24px; height: 1px; background: var(--orange); }
.section-title { font-family: 'Oswald', sans-serif; font-size: clamp(2rem,4vw,3.2rem); font-weight: 700; line-height: 1; text-transform: uppercase; letter-spacing: -0.5px; }
.section-title em { color: var(--orange); font-style: normal; }

/* ---- MARQUEE ---- */
.marquee-wrap  { background: var(--orange); overflow: hidden; white-space: nowrap; padding: 14px 0; }
.marquee-track { display: inline-block; animation: marqueeScroll 30s linear infinite; }
.marquee-track span { font-family: 'Oswald', sans-serif; font-size: 0.82rem; letter-spacing: 3px; text-transform: uppercase; color: var(--white); padding: 0 3rem; }
.marquee-track span.dot { color: rgba(255,255,255,0.4); padding: 0; font-size: 0.5rem; vertical-align: middle; }
@keyframes marqueeScroll { from { transform: translateX(0) } to { transform: translateX(-50%) } }

/* ---- CTA BANNER ---- */
.cta-banner { background: var(--orange); padding: 4rem 5%; display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.cta-banner-text { font-family: 'Oswald', sans-serif; font-size: clamp(1.5rem,3vw,2.4rem); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--white); line-height: 1.1; }
.cta-banner-text span { display: block; font-size: 0.9rem; font-weight: 300; letter-spacing: 3px; margin-bottom: 0.4rem; opacity: 0.8; font-family: 'DM Sans', sans-serif; text-transform: uppercase; }

/* ---- SERVICES SECTION ---- */
#services         { background: var(--cream); }
.services-layout  { display: grid; grid-template-columns: 1fr 2fr; gap: 6rem; align-items: start; }
.services-intro   { position: sticky; top: 100px; }
.services-intro p { font-family: 'Lora', serif; font-size: 1rem; line-height: 1.8; color: var(--mid); margin-top: 1.5rem; margin-bottom: 2rem; }
.services-list    { display: flex; flex-direction: column; }
.service-row      { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 2rem; padding: 2rem 1rem; border-bottom: 1px solid var(--border); cursor: none; position: relative; overflow: hidden; }
.service-row::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--orange-pale); transition: width 0.4s cubic-bezier(0.77,0,0.175,1); z-index: 0; }
.service-row:hover::before { width: 100%; }
.service-row > *  { position: relative; z-index: 1; }
.service-row:first-child { border-top: 1px solid var(--border); }
.service-num      { font-family: 'Oswald', sans-serif; font-size: 0.75rem; letter-spacing: 2px; color: var(--orange); min-width: 28px; }
.service-name     { font-family: 'Oswald', sans-serif; font-size: 1.3rem; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; transition: color 0.2s; }
.service-row:hover .service-name { color: var(--orange); }
.service-desc-inline { font-size: 0.82rem; color: var(--mid); margin-top: 4px; font-weight: 300; display: block; }
.service-arrow    { font-size: 1.1rem; color: var(--orange); transform: translateX(-8px); opacity: 0; transition: all 0.3s; }
.service-row:hover .service-arrow { transform: translateX(0); opacity: 1; }

/* ---- GALLERY ---- */
.gallery-header   { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3rem; flex-wrap: wrap; gap: 1rem; }
.gallery-grid     { display: grid; grid-template-columns: repeat(12,1fr); grid-template-rows: 260px 260px; gap: 4px; }
.g-item           { overflow: hidden; position: relative; background: var(--cream); }
.g-item:nth-child(1)  { grid-column: span 5; grid-row: span 2; }
.g-item:nth-child(2)  { grid-column: span 4; }
.g-item:nth-child(3)  { grid-column: span 3; }
.g-item:nth-child(4)  { grid-column: span 3; }
.g-item:nth-child(5)  { grid-column: span 4; }
.g-item img       { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94), filter 0.4s; filter: saturate(0.85); }
.g-item:hover img { transform: scale(1.08); filter: saturate(1.1); }
.g-overlay        { position: absolute; inset: 0; background: linear-gradient(to top, rgba(217,95,14,0.75) 0%, transparent 50%); opacity: 0; transition: opacity 0.4s; display: flex; align-items: flex-end; padding: 1.5rem; }
.g-item:hover .g-overlay { opacity: 1; }
.g-label          { font-family: 'Oswald', sans-serif; font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase; color: var(--white); transform: translateY(8px); transition: transform 0.3s; }
.g-item:hover .g-label { transform: translateY(0); }
.gallery-cta-strip { background: var(--cream); padding: 3rem 5%; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; border-top: 1px solid var(--border); }
.gallery-cta-strip p { font-family: 'Lora', serif; font-size: 1.05rem; color: var(--mid); }
.gallery-cta-strip strong { color: var(--ink); }

/* Full gallery grid (gallery.php) */
.gallery-full-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.gallery-full-grid .g-item img { height: 280px; }
.gallery-filter-bar { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.filter-btn { font-size: 0.75rem; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; padding: 9px 20px; border: 1.5px solid var(--border); background: transparent; color: var(--mid); cursor: none; transition: all 0.2s; }
.filter-btn:hover, .filter-btn.active { background: var(--orange); color: var(--white); border-color: var(--orange); }

/* ---- BEFORE / AFTER ---- */
#before-after   { background: var(--cream); padding: 7rem 5%; }
.ba-header      { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3.5rem; flex-wrap: wrap; gap: 1rem; }
.ba-grid        { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px,1fr)); gap: 2.5rem; }
.ba-card        { position: relative; overflow: hidden; user-select: none; background: var(--border); aspect-ratio: 4/3; touch-action: none; }
.ba-card img    { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none; }
.ba-after       { z-index: 1; }
.ba-before-wrap { position: absolute; inset: 0; z-index: 2; overflow: hidden; width: 50%; }
.ba-before-wrap img { width: auto; min-width: 100%; max-width: none; height: 100%; object-fit: cover; object-position: left center; }
.ba-divider     { position: absolute; top: 0; bottom: 0; left: 50%; width: 2px; background: var(--white); z-index: 3; transform: translateX(-50%); pointer-events: none; box-shadow: 0 0 8px rgba(0,0,0,0.25); }
.ba-handle      { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 48px; height: 48px; background: var(--white); border-radius: 50%; z-index: 4; display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 16px rgba(0,0,0,0.22); cursor: ew-resize; transition: background 0.2s, transform 0.15s; }
.ba-handle:hover { background: var(--orange); transform: translate(-50%,-50%) scale(1.12); }
.ba-handle:hover svg path { stroke: var(--white); }
.ba-label       { position: absolute; bottom: 1rem; z-index: 5; font-family: 'Oswald', sans-serif; font-size: 0.7rem; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: var(--white); padding: 5px 12px; pointer-events: none; }
.ba-label-before { left: 1rem; background: rgba(28,26,23,0.75); }
.ba-label-after  { right: 1rem; background: rgba(217,95,14,0.85); }
.ba-caption     { margin-top: 1rem; font-size: 0.8rem; color: var(--mid); letter-spacing: 1.5px; text-transform: uppercase; font-weight: 500; }

/* ---- PROCESS ---- */
#process        { background: var(--ink); color: var(--white); }
#process .section-label { color: var(--orange); }
#process .section-title { color: var(--white); }
.process-grid   { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; margin-top: 4rem; border: 1px solid rgba(255,255,255,0.08); }
.process-step   { padding: 3rem 2.5rem; border-right: 1px solid rgba(255,255,255,0.08); position: relative; overflow: hidden; transition: background 0.3s; }
.process-step:last-child { border-right: none; }
.process-step::before { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--orange); transform: scaleX(0); transform-origin: left; transition: transform 0.4s; }
.process-step:hover::before { transform: scaleX(1); }
.process-step:hover { background: rgba(217,95,14,0.05); }
.step-num       { font-family: 'Oswald', sans-serif; font-size: 4rem; font-weight: 700; line-height: 1; color: rgba(217,95,14,0.2); margin-bottom: 1.5rem; transition: color 0.3s; }
.process-step:hover .step-num { color: rgba(217,95,14,0.5); }
.step-name      { font-family: 'Oswald', sans-serif; font-size: 1.1rem; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 1rem; color: var(--white); }
.step-desc      { font-size: 0.88rem; line-height: 1.7; color: rgba(255,255,255,0.45); font-weight: 300; }

/* Process page extended */
.process-page-hero { background: var(--ink); padding: 8rem 5% 5rem; }
.process-page-hero .section-title { color: var(--white); }
.process-extended   { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; margin-top: 4rem; }
.process-img-wrap   { position: sticky; top: 100px; }
.process-img-wrap img { width: 100%; height: 500px; object-fit: cover; filter: saturate(0.9); }
.process-steps-full { display: flex; flex-direction: column; gap: 0; }
.process-step-full  { padding: 3rem 0; border-bottom: 1px solid rgba(255,255,255,0.1); display: grid; grid-template-columns: 80px 1fr; gap: 2rem; align-items: start; }
.process-step-full:first-child { padding-top: 0; }
.step-num-lg        { font-family: 'Oswald', sans-serif; font-size: 3rem; font-weight: 700; color: rgba(217,95,14,0.4); line-height: 1; }
.step-content-title { font-family: 'Oswald', sans-serif; font-size: 1.2rem; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: var(--white); margin-bottom: 0.75rem; }
.step-content-desc  { font-family: 'Lora', serif; font-size: 0.95rem; line-height: 1.8; color: rgba(255,255,255,0.5); }

/* ---- FAQ ---- */
#faq-preview     { background: var(--white); }
.faq-layout      { display: grid; grid-template-columns: 1fr 2fr; gap: 6rem; align-items: start; }
.faq-intro       { position: sticky; top: 100px; }
.faq-intro p     { font-family: 'Lora', serif; font-size: 1rem; line-height: 1.8; color: var(--mid); margin-top: 1.5rem; margin-bottom: 2rem; }
.faq-list        { display: flex; flex-direction: column; }
.faq-item        { border-bottom: 1px solid var(--border); }
.faq-item:first-child { border-top: 1px solid var(--border); }
.faq-q           { width: 100%; background: none; border: none; padding: 1.6rem 1rem; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; cursor: none; text-align: left; }
.faq-q-text      { font-family: 'Oswald', sans-serif; font-size: 1.1rem; font-weight: 500; letter-spacing: 0.5px; text-transform: uppercase; color: var(--ink); transition: color 0.2s; }
.faq-item.open .faq-q-text { color: var(--orange); }
.faq-icon        { width: 28px; height: 28px; border: 1.5px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 0.3s; }
.faq-item.open .faq-icon { background: var(--orange); border-color: var(--orange); transform: rotate(45deg); }
.faq-icon svg    { width: 12px; height: 12px; }
.faq-item.open .faq-icon svg path { stroke: white; }
.faq-a           { max-height: 0; overflow: hidden; transition: max-height 0.4s cubic-bezier(0.25,0.46,0.45,0.94); }
.faq-a-inner     { padding: 0 1rem 1.5rem; font-family: 'Lora', serif; font-size: 0.95rem; line-height: 1.8; color: var(--mid); }

/* ---- AREAS ---- */
#areas           { background: var(--orange-pale); padding: 5rem 5%; width: 100%; }
.areas-layout    { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.areas-text p    { font-family: 'Lora', serif; font-size: 1rem; line-height: 1.8; color: var(--mid); margin-top: 1.5rem; }
.areas-tags      { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 2rem; }
.area-tag        { background: var(--white); border: 1px solid var(--border); color: var(--ink); font-size: 0.78rem; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; padding: 8px 16px; transition: all 0.2s; cursor: none; }
.area-tag:hover  { background: var(--orange); color: var(--white); border-color: var(--orange); }
.areas-img-wrap  { position: relative; overflow: hidden; }
.areas-img-wrap img { width: 100%; height: 400px; object-fit: cover; display: block; filter: saturate(0.9); transition: transform 0.6s; }
.areas-img-wrap:hover img { transform: scale(1.04); }
.areas-img-badge { position: absolute; bottom: 0; left: 0; background: var(--orange); color: var(--white); padding: 1.5rem; width: 160px; }
.areas-img-badge .big { font-family: 'Oswald', sans-serif; font-size: 2.5rem; font-weight: 700; line-height: 1; display: block; }
.areas-img-badge .badge-label { font-size: 0.7rem; letter-spacing: 2px; text-transform: uppercase; opacity: 0.8; margin-top: 4px; display: block; }

/* ---- CONTACT ---- */
#contact         { background: var(--white); padding: 0; width: 100%; }
.contact-grid    { display: grid; grid-template-columns: 1fr 1fr; min-height: 600px; width: 100%; }
.contact-left    { background: var(--ink); padding: 6rem 5%; display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.contact-left .section-label { color: var(--orange); }
.contact-left .section-title { color: var(--white); margin-bottom: 3rem; }
.contact-detail  { margin-bottom: 2.5rem; }
.contact-detail-label { font-size: 0.7rem; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-bottom: 0.5rem; }
.contact-detail-value { font-family: 'Oswald', sans-serif; font-size: 1.4rem; font-weight: 400; letter-spacing: 1px; color: var(--white); text-decoration: none; display: block; transition: color 0.2s; word-break: break-all; }
.contact-detail-value:hover { color: var(--orange); }
.contact-right   { background: var(--cream); padding: 6rem 5%; display: flex; flex-direction: column; justify-content: center; min-width: 0; }

/* ---- PAGE HEROES (inner pages) ---- */
.page-hero       { background: var(--ink); padding: 9rem 5% 5rem; }
.page-hero .section-label { color: var(--orange); }
.page-hero-title { font-family: 'Oswald', sans-serif; font-size: clamp(2.5rem,6vw,5rem); font-weight: 700; text-transform: uppercase; line-height: 0.95; letter-spacing: -1px; color: var(--white); margin-top: 1rem; }
.page-hero-title em { color: var(--orange); font-style: normal; }
.page-hero-desc  { font-family: 'Lora', serif; font-size: 1.05rem; line-height: 1.75; color: rgba(255,255,255,0.5); max-width: 540px; margin-top: 1.5rem; }

/* ---- FOOTER ---- */
footer           { background: var(--ink); padding: 3rem 5%; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1.5rem; border-top: 3px solid var(--orange); }
.footer-logo     { font-family: 'Oswald', sans-serif; font-size: 1.1rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--white); }
.footer-logo em  { color: var(--orange); font-style: normal; }
.footer-links    { display: flex; gap: 2rem; list-style: none; }
.footer-links a  { font-size: 0.75rem; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.4); text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: var(--orange); }
.footer-copy     { font-size: 0.78rem; color: rgba(255,255,255,0.3); letter-spacing: 1px; text-align: right; }

@media (max-width: 768px) {
  footer {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1.25rem;
    padding: 2rem 5%;
  }
  .footer-logo {
    font-size: 0.85rem;
    letter-spacing: 2px;
    text-align: center;
  }
  .footer-links {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem 1.25rem;
  }
  .footer-links a { font-size: 0.7rem; }
  .footer-copy {
    text-align: center;
    font-size: 0.72rem;
    line-height: 1.6;
  }
}

/* ---- REVEAL ANIMATIONS ---- */
.reveal-up    { opacity: 0; transform: translateY(30px); transition: opacity 0.7s cubic-bezier(0.25,0.46,0.45,0.94), transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94); }
.reveal-up.in { opacity: 1; transform: none; }
.reveal-left    { opacity: 0; transform: translateY(20px); transition: opacity 0.7s cubic-bezier(0.25,0.46,0.45,0.94), transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94); }
.reveal-left.in { opacity: 1; transform: none; }
.reveal-right    { opacity: 0; transform: translateY(20px); transition: opacity 0.7s cubic-bezier(0.25,0.46,0.45,0.94), transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94); }
.reveal-right.in { opacity: 1; transform: none; }

/* ---- SERVICES PAGE ---- */
.services-full-list { display: flex; flex-direction: column; gap: 0; }
.service-card-full  { display: grid; grid-template-columns: 60px 1fr auto; gap: 2.5rem; align-items: center; padding: 3rem 2rem; border-bottom: 1px solid var(--border); position: relative; overflow: hidden; transition: background 0.3s; }
.service-card-full:first-child { border-top: 1px solid var(--border); }
.service-card-full::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--orange-pale); transition: width 0.4s cubic-bezier(0.77,0,0.175,1); z-index: 0; }
.service-card-full:hover::before { width: 100%; }
.service-card-full > * { position: relative; z-index: 1; }
.service-icon       { width: 52px; height: 52px; border: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; transition: all 0.3s; }
.service-card-full:hover .service-icon { background: var(--orange); border-color: var(--orange); }
.service-card-body  { flex: 1; }
.service-card-title { font-family: 'Oswald', sans-serif; font-size: 1.4rem; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; color: var(--ink); margin-bottom: 0.5rem; transition: color 0.2s; }
.service-card-full:hover .service-card-title { color: var(--orange); }
.service-card-desc  { font-family: 'Lora', serif; font-size: 0.9rem; line-height: 1.7; color: var(--mid); max-width: 560px; }
.service-card-arrow { font-size: 1.2rem; color: var(--orange); opacity: 0; transform: translateX(-8px); transition: all 0.3s; }
.service-card-full:hover .service-card-arrow { opacity: 1; transform: translateX(0); }

/* ---- FAQ PAGE CATEGORIES ---- */
.faq-category       { margin-bottom: 4rem; }
.faq-category-title { font-family: 'Oswald', sans-serif; font-size: 0.8rem; letter-spacing: 4px; text-transform: uppercase; color: var(--orange); margin-bottom: 1rem; display: flex; align-items: center; gap: 12px; }
.faq-category-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }

/* ---- RESPONSIVE ---- */
@media (max-width: 1024px) {
  .services-layout, .faq-layout { grid-template-columns: 1fr; gap: 3rem; }
  .services-intro, .faq-intro { position: static; }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .process-step { border-bottom: 1px solid rgba(255,255,255,0.08); }
  .areas-layout { grid-template-columns: 1fr; }
  .gallery-full-grid { grid-template-columns: 1fr 1fr; }
  .process-extended { grid-template-columns: 1fr; }
  .process-img-wrap { position: static; }
  .process-img-wrap img { height: 300px; }
}
@media (max-width: 768px) {
  section { padding: 4.5rem 5%; }
  .nav-links { display: none; }
  .burger { display: flex; }
  body { cursor: auto; }
  #cursor, #cursor-ring { display: none; }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px 200px; }
  .g-item:nth-child(1) { grid-column: span 2; grid-row: auto; }
  .g-item:nth-child(n) { grid-column: span 1; }
  .gallery-full-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }
  .cta-banner { flex-direction: column; align-items: flex-start; }
  .service-card-full { grid-template-columns: 1fr; gap: 1rem; }
  .service-card-arrow { display: none; }
  .process-step-full { grid-template-columns: 60px 1fr; }
}
@media (max-width: 480px) {
  .gallery-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
  .g-item img { min-height: 220px; }
  .areas-img-badge { display: none; }
  .form-row { grid-template-columns: 1fr; }
  .ba-grid { grid-template-columns: 1fr; }
}