/*
Theme Name: Fabric Forge Fashion
Theme URI: https://fabricforgefashion.com
Author: Vance
Author URI: https://fabricforgefashion.com
Description: Dark editorial fashion theme for Fabric Forge Fashion. Designed for use with Elementor page builder. Features Cormorant Garamond display typography, deep charcoal palette with burgundy accents, and full light/dark mode support.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: fabricforge
Tags: fashion, dark, editorial, elementor, portfolio, one-page
*/

/* ============================================================
   FABRIC FORGE — DESIGN TOKENS
   ============================================================ */

:root {
  /* Fonts */
  --ff-display: 'Cormorant Garamond', 'Georgia', serif;
  --ff-body:    'Switzer', 'Helvetica Neue', Arial, sans-serif;

  /* Type scale */
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.5rem);
  --text-3xl:  clamp(2.5rem,   1rem    + 4vw,    5rem);
  --text-hero: clamp(3.5rem,   1rem    + 7vw,    9rem);

  /* Spacing */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;

  /* Radius */
  --radius-sm:   0.25rem;
  --radius-md:   0.5rem;
  --radius-full: 9999px;

  /* Transition */
  --transition:      180ms cubic-bezier(0.16, 1, 0.3, 1);
  --transition-slow: 400ms cubic-bezier(0.16, 1, 0.3, 1);

  /* Content widths */
  --content-default: 960px;
  --content-wide:    1200px;
}

/* ── Dark palette (default) ── */
:root,
[data-theme="dark"] {
  --color-bg:               #0a0908;
  --color-surface:          #0f0e0c;
  --color-surface-2:        #141210;
  --color-surface-offset:   #1a1816;
  --color-surface-dynamic:  #242220;
  --color-divider:          #2a2826;
  --color-border:           #333130;

  --color-text:         #e8e5e1;
  --color-text-muted:   #8a8784;
  --color-text-faint:   #4f4e4c;
  --color-text-inverse: #0a0908;

  --color-primary:           #8b1a3a;
  --color-primary-hover:     #a82047;
  --color-primary-active:    #c02550;
  --color-primary-highlight: #2d1018;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.5);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.6);
}

/* ── Light palette ── */
[data-theme="light"] {
  --color-bg:               #f5f2ef;
  --color-surface:          #f9f7f5;
  --color-surface-2:        #fdfcfb;
  --color-surface-offset:   #ede9e5;
  --color-surface-dynamic:  #e3dfd9;
  --color-divider:          #d6d2cc;
  --color-border:           #ccc8c2;

  --color-text:         #1a1614;
  --color-text-muted:   #756f6a;
  --color-text-faint:   #b5b0ab;
  --color-text-inverse: #f5f2ef;

  --color-primary:           #7a1530;
  --color-primary-hover:     #961a3a;
  --color-primary-active:    #b01f44;
  --color-primary-highlight: #f0d9df;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.12);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.18);
}

@media (prefers-color-scheme: light) {
  :root:not([data-theme]) {
    --color-bg:               #f5f2ef;
    --color-surface:          #f9f7f5;
    --color-surface-2:        #fdfcfb;
    --color-surface-offset:   #ede9e5;
    --color-divider:          #d6d2cc;
    --color-border:           #ccc8c2;
    --color-text:         #1a1614;
    --color-text-muted:   #756f6a;
    --color-text-faint:   #b5b0ab;
    --color-primary:      #7a1530;
  }
}

/* ============================================================
   BASE RESET
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
  scroll-padding-top: var(--space-16);
}

body {
  font-family: var(--ff-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background-color: var(--color-bg);
  line-height: 1.6;
  overflow-x: hidden;
}

img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; background: none; border: none; font: inherit; color: inherit; }
h1, h2, h3, h4, h5, h6 { line-height: 1.1; text-wrap: balance; }
p { text-wrap: pretty; max-width: 72ch; }

::selection { background: rgba(139,26,58,0.2); color: var(--color-text); }
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================================================
   WORDPRESS / ELEMENTOR OVERRIDES
   ============================================================ */

/* Remove default WP margins */
.wp-site-blocks, .entry-content { margin: 0; padding: 0; }

/* Elementor full-width pages */
.elementor-page .site-content,
.elementor-page #content,
.elementor-page .entry-content {
  padding: 0 !important;
  margin: 0 !important;
}

/* Make Elementor sections respect our background */
.elementor-section-wrap,
.elementor-top-section {
  background-color: var(--color-bg);
}

/* Prevent WP admin bar from overlapping fixed header */
.admin-bar .ff-header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .ff-header { top: 46px; }
}

/* ============================================================
   SITE HEADER
   ============================================================ */

.ff-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  padding: var(--space-5) var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background var(--transition-slow), box-shadow var(--transition-slow);
}

.ff-header.scrolled {
  background: rgba(10,9,8,0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--shadow-sm);
}

[data-theme="light"] .ff-header.scrolled {
  background: rgba(245,242,239,0.92);
}

.ff-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
}

.ff-logo svg { width: 36px; height: 36px; flex-shrink: 0; color: var(--color-text); }

.ff-logo-text {
  font-family: var(--ff-display);
  font-size: var(--text-lg);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text);
}

.ff-nav {
  display: flex;
  align-items: center;
  gap: var(--space-8);
}

.ff-nav a {
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  position: relative;
  transition: color var(--transition);
}

.ff-nav a::after {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 0; height: 1px;
  background: var(--color-primary);
  transition: width var(--transition);
}

.ff-nav a:hover { color: var(--color-text); }
.ff-nav a:hover::after { width: 100%; }

.ff-header-controls {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.ff-theme-toggle {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-full);
  color: var(--color-text-muted);
  transition: color var(--transition), background var(--transition);
}
.ff-theme-toggle:hover { color: var(--color-text); background: var(--color-surface-offset); }

.ff-hamburger {
  display: none;
  width: 36px; height: 36px;
  align-items: center; justify-content: center;
  color: var(--color-text);
}

/* ── Mobile nav ── */
.ff-mobile-nav {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: var(--color-bg);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow);
}
.ff-mobile-nav.open { opacity: 1; pointer-events: all; }
.ff-mobile-nav a {
  font-family: var(--ff-display);
  font-size: var(--text-3xl);
  font-weight: 300;
  color: var(--color-text-muted);
  transition: color var(--transition);
}
.ff-mobile-nav a:hover { color: var(--color-text); }

/* ============================================================
   SITE FOOTER
   ============================================================ */

.ff-footer {
  border-top: 1px solid var(--color-divider);
  padding-block: var(--space-10);
  background: var(--color-bg);
}

.ff-footer-inner {
  max-width: var(--content-wide);
  margin: 0 auto;
  padding-inline: var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
}

.ff-footer-copy {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  letter-spacing: 0.08em;
}

.ff-footer-social {
  display: flex;
  gap: var(--space-5);
}

.ff-footer-social a {
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  transition: color var(--transition);
}
.ff-footer-social a:hover { color: var(--color-primary); }

/* ============================================================
   ELEMENTOR SECTION HELPERS
   These classes are applied via Elementor's CSS Classes field
   ============================================================ */

/* Section label / eyebrow */
.ff-eyebrow {
  font-size: var(--text-xs) !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--color-primary) !important;
  font-family: var(--ff-body) !important;
  font-weight: 500 !important;
  margin-bottom: var(--space-3) !important;
}

/* Display headings */
.ff-heading-display {
  font-family: var(--ff-display) !important;
  font-weight: 300 !important;
  line-height: 1.05 !important;
  letter-spacing: -0.01em !important;
  color: var(--color-text) !important;
}

.ff-heading-display em,
.ff-heading-display i {
  font-style: italic !important;
  color: var(--color-primary) !important;
}

/* Body text */
.ff-body-text {
  font-size: var(--text-base) !important;
  color: var(--color-text-muted) !important;
  line-height: 1.75 !important;
  font-family: var(--ff-body) !important;
}

/* Tags row */
.ff-tag {
  display: inline-block;
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  margin: var(--space-1);
}

/* Stat blocks */
.ff-stat-number {
  font-family: var(--ff-display) !important;
  font-size: var(--text-2xl) !important;
  font-weight: 300 !important;
  color: var(--color-text) !important;
  line-height: 1 !important;
  display: block !important;
}

.ff-stat-label {
  font-size: var(--text-xs) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--color-text-faint) !important;
}

/* Primary CTA button */
.ff-btn-primary,
.ff-btn-primary.elementor-button {
  font-size: var(--text-xs) !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
  font-family: var(--ff-body) !important;
  padding: var(--space-4) var(--space-8) !important;
  background: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0 !important;
  transition: background var(--transition) !important;
}
.ff-btn-primary:hover,
.ff-btn-primary.elementor-button:hover {
  background: var(--color-primary-hover) !important;
  color: #fff !important;
}

/* Work / portfolio card overlay */
.ff-work-card {
  position: relative;
  overflow: hidden;
}
.ff-work-card img { transition: transform 600ms cubic-bezier(0.16, 1, 0.3, 1); }
.ff-work-card:hover img { transform: scale(1.04); }

.ff-work-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 50%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-6);
  opacity: 0;
  transition: opacity var(--transition-slow);
}
.ff-work-card:hover .ff-work-card-overlay { opacity: 1; }

.ff-work-card-category {
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}

.ff-work-card-title {
  font-family: var(--ff-display);
  font-size: var(--text-lg);
  font-weight: 400;
  color: #fff;
}

/* Contact form styling */
.ff-contact-form input,
.ff-contact-form textarea,
.elementor-field-type-text input,
.elementor-field-type-email input,
.elementor-field-type-textarea textarea {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--color-text) !important;
  font-family: var(--ff-body) !important;
  font-size: var(--text-sm) !important;
  padding: var(--space-3) var(--space-4) !important;
  transition: border-color var(--transition), box-shadow var(--transition) !important;
}
.ff-contact-form input:focus,
.ff-contact-form textarea:focus,
.elementor-field-type-text input:focus,
.elementor-field-type-email input:focus,
.elementor-field-type-textarea textarea:focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-highlight) !important;
  outline: none !important;
}
.elementor-field-label {
  font-size: var(--text-xs) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--color-text-faint) !important;
  font-family: var(--ff-body) !important;
}

/* Divider line */
.ff-divider {
  border: none;
  border-top: 1px solid var(--color-divider);
  margin: 0;
}

/* Section backgrounds */
.ff-section-dark   { background: var(--color-bg) !important; }
.ff-section-surface { background: var(--color-surface) !important; }

/* Scroll reveal (JS-driven) */
.ff-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 700ms cubic-bezier(0.16, 1, 0.3, 1),
              transform 700ms cubic-bezier(0.16, 1, 0.3, 1);
}
.ff-reveal.visible { opacity: 1; transform: translateY(0); }
.ff-reveal-d1 { transition-delay: 100ms; }
.ff-reveal-d2 { transition-delay: 200ms; }
.ff-reveal-d3 { transition-delay: 300ms; }

/* Hero scroll indicator */
.ff-scroll-indicator {
  position: absolute;
  bottom: var(--space-8);
  right: var(--space-8);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-faint);
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  pointer-events: none;
}
.ff-scroll-indicator-line {
  width: 1px;
  height: 48px;
  background: var(--color-text-faint);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(1); }
  50%       { opacity: 1;   transform: scaleY(0.6); }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 900px) {
  .ff-nav { display: none; }
  .ff-hamburger { display: flex; }
  .ff-mobile-nav { display: flex; }
  .ff-footer-inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 600px) {
  .ff-header { padding: var(--space-4) var(--space-5); }
  .ff-footer-inner { padding-inline: var(--space-5); }
}

/* ============================================================
   UTILITY
   ============================================================ */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border-width: 0;
}
