/*
Theme Name: AISF Bold Creative
Theme URI: https://ai-site-factory.com/themes/bold-creative
Author: AI Site Factory
Author URI: https://ai-site-factory.com
Description: A bold, high-impact theme for modern content sites. Features large typography, dynamic layouts, and vibrant colors. Optimized for attention-grabbing editorial content.
Version: 0.1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aisf-bold-creative
Tags: blog, news, editorial, bold, dark, modern, custom-colors, custom-logo, custom-menu, featured-images
*/

:root {
  --aisf-bg: #FFFFFF;
  --aisf-bg-secondary: #F5F5F5;
  --aisf-text: #1A1A1A;
  --aisf-text-secondary: #6B7280;
  --aisf-accent: #FF6B35;
  --aisf-accent-hover: #E55A25;
  --aisf-secondary: #00D4FF;
  --aisf-border: #E5E7EB;
  --aisf-header-bg: #FFFFFF;
  --aisf-header-text: #1A1A1A;
  --aisf-footer-bg: #121212;
  --aisf-footer-text: #F5F5F5;
  --aisf-hero-overlay: rgba(18, 18, 18, 0.7);
  
  --aisf-font-heading: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
  --aisf-font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
  --aisf-font-size-h1: 3.5rem;
  --aisf-font-size-h2: 2.75rem;
  --aisf-font-size-h3: 2rem;
  --aisf-font-size-body: 1.0625rem;
  --aisf-font-size-small: 0.875rem;
  
  --aisf-content-width: 800px;
  --aisf-header-height: 72px;
  --aisf-border-radius: 12px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --aisf-bg: #121212;
    --aisf-bg-secondary: #1E1E1E;
    --aisf-text: #FFFFFF;
    --aisf-text-secondary: #A0A0A0;
    --aisf-border: #333333;
    --aisf-header-bg: #121212;
    --aisf-header-text: #FFFFFF;
    --aisf-footer-bg: #0A0A0A;
    --aisf-footer-text: #FFFFFF;
  }
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; padding: 0; font-family: var(--aisf-font-body); font-size: var(--aisf-font-size-body); line-height: 1.6; color: var(--aisf-text); background-color: var(--aisf-bg); -webkit-font-smoothing: antialiased; }

h1, h2, h3, h4, h5, h6 { font-family: var(--aisf-font-heading); font-weight: 700; line-height: 1.15; margin-top: 2.5rem; margin-bottom: 1rem; color: var(--aisf-text); letter-spacing: -0.02em; }
h1 { font-size: var(--aisf-font-size-h1); }
h2 { font-size: var(--aisf-font-size-h2); }
h3 { font-size: var(--aisf-font-size-h3); }
p { margin-top: 0; margin-bottom: 1.25rem; }
a { color: var(--aisf-accent); text-decoration: none; transition: all 0.2s ease; }
a:hover { color: var(--aisf-accent-hover); }
img { max-width: 100%; height: auto; display: block; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }

.site-header { position: sticky; top: 0; z-index: 1000; background: var(--aisf-header-bg); border-bottom: 1px solid var(--aisf-border); height: var(--aisf-header-height); display: flex; align-items: center; transition: background 0.3s ease; }
.site-header.scrolled { background: rgba(255,255,255,0.95); backdrop-filter: blur(10px); }
@media (prefers-color-scheme: dark) { .site-header.scrolled { background: rgba(18,18,18,0.95); } }
.header-inner { display: flex; justify-content: space-between; align-items: center; width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
.site-logo { font-family: var(--aisf-font-heading); font-size: 1.5rem; font-weight: 800; color: var(--aisf-header-text); text-decoration: none; letter-spacing: -0.03em; text-transform: uppercase; }
.site-logo img { height: 48px; width: auto; }
.site-navigation ul { display: flex; list-style: none; margin: 0; padding: 0; gap: 2rem; }
.site-navigation a { color: var(--aisf-header-text); font-weight: 600; font-size: 0.9375rem; letter-spacing: 0.02em; position: relative; }
.site-navigation a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 3px; background: var(--aisf-accent); transition: width 0.3s ease; }
.site-navigation a:hover::after { width: 100%; }

.hero { position: relative; min-height: 500px; display: flex; align-items: center; justify-content: center; background-size: cover; background-position: center; background-color: var(--aisf-bg-secondary); }
.hero::before { content: ''; position: absolute; inset: 0; background: var(--aisf-hero-overlay); }
.hero-content { position: relative; z-index: 1; text-align: center; max-width: 900px; padding: 4rem 1.5rem; }
.hero-title { color: #FFFFFF; font-size: 4rem; margin-bottom: 1.5rem; letter-spacing: -0.03em; line-height: 1.1; }
.hero-subtitle { color: rgba(255,255,255,0.85); font-size: 1.5rem; font-weight: 400; margin-bottom: 0; }
.hero--small { min-height: 280px; }
.hero--small .hero-title { font-size: 2.5rem; }

@media (max-width: 768px) {
  .hero-title { font-size: 2.5rem; }
  .hero-subtitle { font-size: 1.125rem; }
}

.site-content { padding: 4rem 0; min-height: 60vh; }

.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 2rem; }
.post-card { background: var(--aisf-bg-secondary); border-radius: var(--aisf-border-radius); overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease; position: relative; }
.post-card:hover { transform: translateY(-8px); box-shadow: 0 20px 40px rgba(0,0,0,0.15); }
.post-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--aisf-accent); transform: scaleX(0); transform-origin: left; transition: transform 0.3s ease; }
.post-card:hover::before { transform: scaleX(1); }
.post-card-image { aspect-ratio: 16/10; overflow: hidden; }
.post-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.post-card:hover .post-card-image img { transform: scale(1.05); }
.post-card-content { padding: 1.5rem; }
.post-card-category { display: inline-block; color: var(--aisf-accent); font-weight: 700; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 0.75rem; }
.post-card-title { font-size: 1.5rem; margin: 0 0 0.75rem; line-height: 1.2; }
.post-card-title a { color: var(--aisf-text); }
.post-card-excerpt { color: var(--aisf-text-secondary); margin: 0; font-size: 0.9375rem; line-height: 1.6; }
.post-card-meta { display: flex; gap: 1rem; font-size: var(--aisf-font-size-small); color: var(--aisf-text-secondary); margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--aisf-border); }

.category-pills { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-bottom: 3rem; justify-content: center; }
.category-pill { background: var(--aisf-bg-secondary); border: 2px solid var(--aisf-border); border-radius: 50px; padding: 0.5rem 1.25rem; font-weight: 600; font-size: 0.875rem; color: var(--aisf-text); transition: all 0.2s ease; }
.category-pill:hover { background: var(--aisf-accent); border-color: var(--aisf-accent); color: #FFFFFF; }

.page-header { margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 3px solid var(--aisf-accent); }
.page-title { font-size: 3rem; margin: 0; }

.about-section { display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; align-items: center; margin-bottom: 4rem; }
.about-image { border-radius: var(--aisf-border-radius); overflow: hidden; position: relative; }
.about-image::after { content: ''; position: absolute; top: 20px; left: 20px; right: -20px; bottom: -20px; border: 3px solid var(--aisf-accent); border-radius: var(--aisf-border-radius); z-index: -1; }
.about-image img { width: 100%; height: auto; }
.about-content h2 { font-size: 2.5rem; margin-top: 0; }
.about-content p { font-size: 1.125rem; color: var(--aisf-text-secondary); }

@media (max-width: 768px) { .about-section { grid-template-columns: 1fr; } .about-image::after { display: none; } }

.site-footer { background: var(--aisf-footer-bg); color: var(--aisf-footer-text); padding: 4rem 0 2rem; }
.footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
.footer-widgets { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; margin-bottom: 3rem; }
@media (max-width: 900px) { .footer-widgets { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .footer-widgets { grid-template-columns: 1fr; } }
.footer-widget h3 { color: #FFFFFF; font-size: 1rem; margin-top: 0; margin-bottom: 1.25rem; text-transform: uppercase; letter-spacing: 0.1em; }
.footer-widget ul { list-style: none; margin: 0; padding: 0; }
.footer-widget li { margin-bottom: 0.75rem; }
.footer-widget a { color: rgba(255,255,255,0.7); font-weight: 500; }
.footer-widget a:hover { color: var(--aisf-accent); }
.footer-bottom { padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); text-align: center; font-size: var(--aisf-font-size-small); color: rgba(255,255,255,0.5); }

.pagination { display: flex; justify-content: center; gap: 0.75rem; margin: 4rem 0; }
.pagination a, .pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 48px; height: 48px; padding: 0 1rem; border: 2px solid var(--aisf-border); border-radius: var(--aisf-border-radius); font-weight: 700; color: var(--aisf-text); }
.pagination a:hover { background: var(--aisf-accent); border-color: var(--aisf-accent); color: #FFFFFF; transform: translateY(-2px); }
.pagination .current { background: var(--aisf-accent); border-color: var(--aisf-accent); color: #FFFFFF; }

.search-form { display: flex; max-width: 500px; margin: 0 auto; }
.search-form input { flex: 1; padding: 1rem 1.5rem; border: 2px solid var(--aisf-border); border-right: none; border-radius: var(--aisf-border-radius) 0 0 var(--aisf-border-radius); font-size: 1rem; background: var(--aisf-bg); color: var(--aisf-text); }
.search-form input:focus { outline: none; border-color: var(--aisf-accent); }
.search-form button { padding: 1rem 2rem; border: none; border-radius: 0 var(--aisf-border-radius) var(--aisf-border-radius) 0; background: var(--aisf-accent); color: #FFFFFF; font-weight: 700; cursor: pointer; transition: background 0.2s; }
.search-form button:hover { background: var(--aisf-accent-hover); }

.screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 2rem; }
.mb-4 { margin-bottom: 4rem; }
