/* Theme Name: Iconic Custom Styles - Compact & Optimized */
/* Version: 2.7 (Restored Front Page Styles + Back-to-Top Color Fix) */

/* --- 1. CORE VARIABLES & DEFAULTS --- */
:root { --iconic-orange: #ff5e00; --iconic-orange-hover: #cc4b00; --iconic-black: #050505; --iconic-dark: #0a0a0a; --iconic-card: #111111; --iconic-border: rgba(255, 255, 255, 0.1); --iconic-text-muted: #888888; --iconic-radius: 4px; }
body { background-color: var(--iconic-black); color: #fff; font-family: 'Inter', system-ui, -apple-system, sans-serif; overflow-x: hidden; }

/* --- 2. TYPOGRAPHY & BRANDING COLORS --- */
.font-display { font-family: 'Teko', sans-serif; text-transform: uppercase; line-height: 0.85; letter-spacing: 0.02em; }
.text-orange { color: var(--iconic-orange) !important; }
.bg-orange { background-color: var(--iconic-orange) !important; }
.border-orange { border-color: var(--iconic-orange) !important; }
strong, b { color: var(--iconic-orange); font-weight: 700; }

/* --- 3. UI COMPONENTS --- */
.btn-skewed { position: relative; display: inline-flex; align-items: center; justify-content: center; padding: 0.8rem 2.5rem; font-family: 'Teko', sans-serif; font-size: 1.25rem; font-weight: 600; text-transform: uppercase; text-decoration: none; transition: all 0.3s ease; transform: skewX(-10deg); border-radius: var(--iconic-radius); border: 1px solid transparent; overflow: hidden; z-index: 1; }
.btn-skewed > span { transform: skewX(10deg); display: block; }
.btn-primary { background-color: var(--iconic-orange); color: #000; border-color: var(--iconic-orange); }
.btn-primary:hover { background-color: var(--iconic-orange-hover); border-color: var(--iconic-orange-hover); color: #000; }
.btn-secondary { background: rgba(255, 255, 255, 0.05); color: #fff; border-color: rgba(255, 255, 255, 0.1); backdrop-filter: blur(5px); }
.btn-secondary:hover { border-color: var(--iconic-orange); color: var(--iconic-orange); background: rgba(255, 94, 0, 0.1); }
.skew-box { transform: skewX(-12deg); display: inline-block; }
.skew-content { transform: skewX(12deg); display: block; }
.skew-tag-orange { background-color: var(--iconic-orange); color: #000; padding: 0.2rem 1rem; }
.skew-tag-outline { border: 1px solid rgba(255, 94, 0, 0.5); background-color: rgba(255, 94, 0, 0.1); padding: 0.2rem 1rem; }

/* --- 4. HEADER & NAV --- */
#main-nav { background-color: rgba(5, 5, 5, 0.9); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(255, 255, 255, 0.05); transition: all 0.3s ease; }
.nav-link-custom { font-size: 1.1rem; color: #aaa; font-weight: 500; text-decoration: none; text-transform: uppercase; letter-spacing: 0.05em; font-family: 'Teko', sans-serif; transition: color 0.3s ease; }
.nav-link-custom:hover, .nav-link-custom.active-orange { color: #fff; }

/* --- 5. HERO SECTIONS --- */
.home-hero-bg { background-color: var(--iconic-black); position: relative; overflow: hidden; min-height: 90vh; display: flex; align-items: center; }
.hero-image-container { position: absolute; top: 0; right: 0; width: 55%; height: 100%; z-index: 0; mask-image: linear-gradient(to right, transparent, black 20%); }
.hero-gradient-overlay { position: absolute; inset: 0; background: radial-gradient(circle at 70% 30%, rgba(255, 94, 0, 0.15), transparent 60%), linear-gradient(to bottom, transparent 0%, var(--iconic-black) 100%); z-index: 1; }
.hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: saturate(0) contrast(1.1) brightness(0.8); }
.angled-separator { position: absolute; bottom: 0; left: 0; width: 100%; height: 100px; background: var(--iconic-black); clip-path: polygon(0 100%, 100% 100%, 100% 0); z-index: 2; }
.hero-header-section { position: relative; height: 85vh; overflow: hidden; border-bottom: 1px solid rgba(255, 94, 0, 0.2); }
.hero-header-bg-img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; filter: brightness(0.5) contrast(1.2); }
.hero-header-overlay { position: absolute; inset: 0; background: linear-gradient(to top, #000 0%, rgba(0,0,0,0.4) 100%); }
.hero-title-large { font-size: clamp(4rem, 10vw, 9rem); line-height: 0.85; font-weight: 900; letter-spacing: -0.02em; text-transform: uppercase; }

/* --- 6. CARDS & BENTO GRID --- */
.bg-dark-card { border: none !important; background-color: #111; }
/* Card Heights */
.hero-card-lg, .hero-card-sm {height: 350px !important}

/* Global Card Hover */
#heroes-section .group, .program-card, .sidebar-program-card { transition: border-color 0.4s ease, box-shadow 0.4s ease; position: relative; overflow: hidden; border: 1px solid var(--iconic-border); }
#heroes-section .group:hover, .program-card:hover, .sidebar-program-card:hover { border: 2px solid var(--iconic-orange) !important; box-shadow: 0 15px 30px rgba(0,0,0,0.5); }
/* Image Zoom & Filter */
#heroes-section .group img, .program-card img, .sidebar-program-card img { transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), filter 0.6s ease; filter: grayscale(100%); }
#heroes-section .group:hover img, .program-card:hover img, .sidebar-program-card:hover img { transform: scale(1.1); filter: grayscale(0%) brightness(1) !important; }

/* Bento Metadata - Fixed Positioning */
.hero-card-nickname { display: block; margin-bottom: 5px; opacity: 1; transition: opacity 0.3s ease; }
.group:hover .hero-card-nickname { opacity: 1; } /* Nickname stays */

/* Badges: Top Left Overlay on Hover */
.hero-card-badges { position: absolute; top: 0; left: 1.5rem; opacity: 0; transition: all 0.4s ease; pointer-events: none; display: flex; flex-wrap: wrap; gap: 5px; transform: translateY(-10px); z-index: 5; }
.group:hover .hero-card-badges { opacity: 1; pointer-events: auto; transform: translateY(0); }
.hero-card-badges span.badge { background-color: #ff5e00 !important;  color: var(--iconic-black) !important; font-family: 'Teko', sans-serif; letter-spacing: 0.1em; font-weight: 600; font-size: 0.8rem; text-transform: uppercase; border-radius: 2px; }

.hero-card-ex-style { color: rgba(255, 255, 255, 0.4); font-size: 0.75rem; text-transform: uppercase; font-weight: 600; letter-spacing: 0.05em; margin-top: 8px; }

/* Program Card Details */
.grayscale { filter: grayscale(100%); transition: filter 0.5s ease; }.group:hover .grayscale { filter: grayscale(0%); }
.program-card { height: 350px; }
.program-card .fw-bold {font-weight:600}
.program-card .program-card-img-container { position: absolute; inset: 0; z-index: 1; }
.program-card .program-card-img-container img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(100%) brightness(0.6); }
.program-card .p-4 { position: absolute; bottom: 0; left: 0; width: 100%; z-index: 2; background: #222; transition: background 0.3s ease;}
.program-card .program-card-img-container .p-4 {background: linear-gradient(to top, #222 0%, transparent 100%);}
.program-badge { position: absolute; top: 1rem; right: 1rem; background: rgba(0,0,0,0.8); border: 1px solid var(--iconic-orange); color: var(--iconic-orange); font-family: 'Teko', sans-serif; padding: 0.2rem 0.8rem; font-size: 0.8rem; text-transform: uppercase; border-radius: 2px; z-index: 3; }
.sidebar-program-card img { filter: brightness(0.4) !important; }
/* Specific overrides for this template */
.program-card { height: auto; /* Allow auto height for flex layout */transition: transform 0.3s ease, border-color 0.3s ease;background-color: #222;}
.program-card:hover { transform: translateY(-5px); border-color: var(--iconic-orange) !important; }
/* Redundant rules removed/merged to avoid conflict with top grayscale rule */
.program-title-hover { transition: color 0.3s ease; }
.program-card-wrapper:hover .program-title-hover { color: var(--iconic-orange) !important; }
.hover-orange:hover { border-color: var(--iconic-orange) !important; color: var(--iconic-orange) !important; }
.filter-btn.active {background-color: var(--iconic-orange) !important;color: #000 !important;border-color: var(--iconic-orange) !important;}


/* --- 7. WORKOUT & SPLIT STYLES --- */
.split-header-area { padding-top: 0 !important; padding-bottom: 0 !important; }
.exercise-item { border-left: 1px solid var(--iconic-orange); }
.superset-item-group { border-left: 1px solid var(--iconic-orange); position: relative; }
.superset-item-group .exercise-item { border-left: none !important; }
.superset-label { position: absolute; left: -10px; top: 50%; transform: translateY(-50%) translateX(8px); background: var(--iconic-orange); border: 1px solid var(--iconic-orange); padding: 6px 2px; border-radius: 2px; z-index: 11; }
.superset-label span { writing-mode: vertical-rl; transform: rotate(180deg); text-transform: uppercase; font-weight: 700; font-size: 0.75rem; letter-spacing: 0.1em; color: var(--iconic-black); display: block; }
.stat-box { background: rgba(0,0,0,0.5); padding: 0.5rem 1rem; border-radius: 4px; border: 1px solid rgba(255,255,255,0.1); text-align: center; width: auto; }
.stat-box .val { font-family: 'Teko', sans-serif; font-weight: 700; font-size: 2.5rem; line-height: 1; }
.stat-box .lbl { font-size: 0.9rem; text-transform: uppercase; font-weight: 700; color: #888; letter-spacing: 0.1em; }
.track-box { width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,0.2); border-radius: 4px; color: #fff; font-family: 'Teko', sans-serif; font-weight: 700; font-size: 1.5rem; cursor: pointer; transition: all 0.2s; }
.track-box:hover { border-color: var(--iconic-orange); color: var(--iconic-orange); }
.track-box.completed { background-color: var(--iconic-orange); border-color: var(--iconic-orange); color: #000; }
.program-hero-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; filter: brightness(0.6) contrast(1.1); }
.program-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, #050505 0%, rgba(5,5,5,0.4) 60%, transparent 100%); }

/* --- 8. SIDEBAR & INFO --- */
.quick-fact-box { background-color: var(--iconic-dark); border: 1px solid var(--iconic-border); padding: 2rem; }
.qf-header { border-bottom: 1px solid rgba(255, 94, 0, 0.2); padding-bottom: 1rem; margin-bottom: 1.5rem; }
.qf-title { color: var(--iconic-orange); font-size: 0.75rem; letter-spacing: 0.2em; font-weight: 800; text-transform: uppercase; }
.qf-label { font-size: 0.6rem; color: #666; text-transform: uppercase; font-weight: 700; letter-spacing: 0.1em; display: block; margin-bottom: 0.2rem; }
.qf-value { font-size: 1rem; color: #fff; font-weight: 700; line-height: 1.2; }
.content-area { font-size: 1.1rem; line-height: 1.8; color: #ccc; font-weight: 300; }
.philosophy-box { background: rgba(255, 255, 255, 0.02); border-left: 2px solid var(--iconic-orange); padding: 1.5rem; }
.nav-tab-btn.active { background-color: var(--iconic-orange); color: #000 !important; border-color: var(--iconic-orange); }
.video-overlay-play { transition: opacity 0.3s; opacity: 1; }
.custom-video-player.playing + .video-overlay-play { opacity: 0; pointer-events: none; }
.custom-video-player { cursor: pointer; }

/* --- 9. UTILITIES & GLOBAL FOOTER --- */
#back-to-top { position: fixed; bottom: 2rem; right: 2rem; width: 3rem; height: 3rem; background-color: var(--iconic-black); color: var(--iconic-orange) !important; border: 1px solid var(--iconic-orange); display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.3s ease; z-index: 1000; }
#back-to-top.visible { opacity: 1; visibility: visible; }
#back-to-top:hover { background-color: #ff5e00 !important; color: #000 !important; box-shadow: 0 0 15px rgba(255, 94, 0, 0.4); border-color: #ff5e00 !important; }
#back-to-top span.skew-content {color: var(--iconic-orange)}
#back-to-top:hover span.skew-content {color: var(--iconic-black)}
.hover-orange:hover { color: var(--iconic-orange) !important; }
.transition { transition: color 0.3s ease; }
.focus-orange:focus { border-color: var(--iconic-orange); box-shadow: 0 0 0 0.25rem rgba(255, 94, 0, 0.25); }

/* --- 10. FRONT PAGE SPECIFIC STYLES (Moved from index.php) --- */
.group:hover img { filter: grayscale(0%); transform: scale(1.05); }
.hover-orange:hover { border-color: var(--iconic-orange) !important; color: var(--iconic-orange) !important; }
.program-card-img-container img { transition: transform 0.5s ease; }
.btn-custom-dark { background-color: #111; border: 1px solid rgba(255,255,255,0.1); color: #fff; padding: 1rem 2.5rem; transition: all 0.3s ease; }
.btn-custom-dark span { color: #fff; transition: color 0.3s ease; }
.btn-custom-dark svg { stroke: #fff; transition: stroke 0.3s ease, transform 0.3s ease; }
.btn-custom-dark:hover { background-color: var(--iconic-orange); border-color: var(--iconic-orange); }
.btn-custom-dark:hover span, .btn-custom-dark:hover svg { color: #000 !important; stroke: #000 !important; }
.group-hover-translate { transform: translateY(0); }
.btn-custom-dark:hover .group-hover-translate { transform: translateY(3px); }
.program-card-wrapper { border-radius: 6px; overflow: hidden; border: 1px solid rgba(255, 255, 255, 0.05); transition: all 0.3s ease; }
.program-card-wrapper:hover { transform: translateY(-5px); border-color: var(--iconic-orange); box-shadow: 0 0 0 2px var(--iconic-orange); }
.program-visual-box .gradient-overlay { position: absolute; inset: 0; background: linear-gradient(to top, #111 0%, transparent 100%); z-index: 1; }
.program-img { transition: transform 0.7s duration-700 ease, filter 0.3s ease; filter: grayscale(100%); }
.program-card-wrapper:hover .program-img { transform: scale(1.1); filter: grayscale(0%); }
.program-title-hover { transition: color 0.3s ease; }
.program-card-wrapper:hover .program-title-hover { color: var(--iconic-orange) !important; }
.filter-btn.active { background-color: var(--iconic-orange) !important; color: #000 !important; border-color: var(--iconic-orange) !important; }