Spaces:
Running
Running
| /* Modern, clean and accessible design system */ | |
| @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap'); | |
| :root { | |
| /* Light theme colors */ | |
| --bg: #ffffff; | |
| --bg-alt: #f8fafc; | |
| --bg-card: #ffffff; | |
| --text: #1e293b; | |
| --text-light: #64748b; | |
| --primary-1: #6366f1; | |
| --primary-2: #4f46e5; | |
| --accent-1: #f472b6; | |
| --accent-2: #ec4899; | |
| --success: #10b981; | |
| --error: #ef4444; | |
| --border-color: rgba(0, 0, 0, 0.1); | |
| /* Typography */ | |
| --font-base: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; | |
| --line-height-base: 1.6; | |
| /* Spacing */ | |
| --spacing-xs: 0.25rem; | |
| --spacing-sm: 0.5rem; | |
| --spacing-md: 1rem; | |
| --spacing-lg: 1.5rem; | |
| --spacing-xl: 2rem; | |
| /* UI Elements */ | |
| --card-radius: 16px; | |
| --btn-radius: 999px; /* pill buttons */ | |
| --shadow-sm: 0 1px 3px rgba(0,0,0,0.1); | |
| --shadow-md: 0 4px 6px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.08); | |
| --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05); | |
| /* Transitions */ | |
| --transition-fast: 150ms ease; | |
| --transition-base: 250ms ease; | |
| } | |
| /* Dark theme colors */ | |
| [data-theme="dark"] { | |
| --bg: #0f172a; | |
| --bg-alt: #1e293b; | |
| --bg-card: #1e293b; | |
| --text: #e2e8f0; | |
| --text-light: #94a3b8; | |
| --primary-1: #818cf8; | |
| --primary-2: #6366f1; | |
| --accent-1: #f472b6; | |
| --accent-2: #ec4899; | |
| --border-color: rgba(255, 255, 255, 0.1); | |
| } | |
| /* Base styles with modern refinements */ | |
| html, body { | |
| height: 100%; | |
| scroll-behavior: smooth; | |
| } | |
| body { | |
| margin: 0; | |
| font-family: var(--font-base); | |
| background: var(--bg); | |
| color: var(--text); | |
| line-height: var(--line-height-base); | |
| -webkit-font-smoothing: antialiased; | |
| -moz-osx-font-smoothing: grayscale; | |
| } | |
| ::selection { | |
| background: var(--primary-1); | |
| color: white; | |
| } | |
| .container { | |
| width: 100%; | |
| max-width: 100%; | |
| padding: 0 var(--spacing-md); | |
| margin: 0 auto; | |
| box-sizing: border-box; | |
| } | |
| .header { | |
| background: var(--bg); | |
| color: var(--text); | |
| padding: var(--spacing-md) 0; | |
| border-bottom: 1px solid rgba(0,0,0,0.1); | |
| position: sticky; | |
| top: 0; | |
| z-index: 1000; | |
| backdrop-filter: blur(8px); | |
| -webkit-backdrop-filter: blur(8px); | |
| } | |
| .header h1 { | |
| margin: 0; | |
| font-size: 1.5rem; | |
| font-weight: 600; | |
| background: linear-gradient(135deg, var(--primary-1), var(--primary-2)); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| letter-spacing: -0.02em; | |
| } | |
| .navbar { | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-between; | |
| padding: var(--spacing-sm) 0; | |
| gap: var(--spacing-md); | |
| } | |
| .nav-links { | |
| display: flex; | |
| gap: var(--spacing-md); | |
| flex-wrap: wrap; | |
| align-items: center; | |
| } | |
| /* Theme toggle button */ | |
| .theme-toggle { | |
| background: none; | |
| border: none; | |
| padding: var(--spacing-sm); | |
| cursor: pointer; | |
| color: var(--text-light); | |
| border-radius: 50%; | |
| width: 40px; | |
| height: 40px; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| transition: all var(--transition-base); | |
| position: relative; | |
| overflow: hidden; | |
| } | |
| .theme-toggle:hover { | |
| background: var(--bg-alt); | |
| color: var(--primary-1); | |
| transform: scale(1.1); | |
| } | |
| .theme-toggle::before { | |
| content: "🌙"; | |
| position: absolute; | |
| opacity: 0; | |
| transform: translateY(100%); | |
| transition: all var(--transition-base); | |
| } | |
| .theme-toggle::after { | |
| content: "☀️"; | |
| position: absolute; | |
| opacity: 1; | |
| transform: translateY(0); | |
| transition: all var(--transition-base); | |
| } | |
| [data-theme="dark"] .theme-toggle::before { | |
| opacity: 1; | |
| transform: translateY(0); | |
| } | |
| [data-theme="dark"] .theme-toggle::after { | |
| opacity: 0; | |
| transform: translateY(-100%); | |
| } | |
| .nav-links a { | |
| color: var(--text-light); | |
| text-decoration: none; | |
| font-weight: 500; | |
| padding: var(--spacing-xs) var(--spacing-sm); | |
| border-radius: var(--btn-radius); | |
| transition: all var(--transition-fast); | |
| } | |
| .nav-links a:hover { | |
| color: var(--primary-1); | |
| background: var(--bg-alt); | |
| } | |
| .nav-links a[rel="noopener"]::after{ | |
| content: '↗'; | |
| display:inline-block; | |
| margin-left:0.45rem; | |
| font-size:0.85rem; | |
| opacity:0.8; | |
| } | |
| .nav-links svg { | |
| vertical-align: middle; | |
| display: inline-block; | |
| margin-right: 0.15rem; | |
| color: inherit; | |
| } | |
| /* Modern card grid with hover effects */ | |
| .cards-grid { | |
| display: grid; | |
| grid-template-columns: 1fr; | |
| gap: var(--spacing-lg); | |
| padding: var(--spacing-md) 0; | |
| } | |
| .card { | |
| background: var(--bg-card); | |
| border-radius: var(--card-radius); | |
| box-shadow: var(--shadow-md); | |
| overflow: hidden; | |
| transition: all var(--transition-base); | |
| border: 1px solid var(--border-color); | |
| position: relative; | |
| z-index: 1; | |
| } | |
| .card::before { | |
| content: ''; | |
| position: absolute; | |
| top: 0; | |
| left: 0; | |
| width: 100%; | |
| height: 100%; | |
| background: linear-gradient(135deg, var(--primary-1), var(--accent-1)); | |
| opacity: 0; | |
| transition: opacity var(--transition-base); | |
| z-index: -1; | |
| border-radius: var(--card-radius); | |
| } | |
| .card:hover { | |
| transform: translateY(-4px) scale(1.02); | |
| box-shadow: var(--shadow-lg); | |
| border-color: transparent; | |
| } | |
| .card:hover::before { | |
| opacity: 0.1; | |
| } | |
| .card-img-top { | |
| width: 100%; | |
| height: 220px; | |
| object-fit: cover; | |
| transition: all var(--transition-base); | |
| filter: brightness(1); | |
| } | |
| .card:hover .card-img-top { | |
| transform: scale(1.05); | |
| filter: brightness(1.1); | |
| } | |
| .card-body { | |
| padding: var(--spacing-lg); | |
| } | |
| .card-title { | |
| margin: 0 0 var(--spacing-sm); | |
| font-weight: 600; | |
| color: var(--text); | |
| font-size: 1.25rem; | |
| line-height: 1.4; | |
| } | |
| .btn { | |
| display: inline-flex; | |
| align-items: center; | |
| justify-content: center; | |
| padding: 0.75rem 1.5rem; | |
| border-radius: var(--btn-radius); | |
| font-weight: 600; | |
| text-align: center; | |
| transition: all var(--transition-fast); | |
| text-decoration: none; | |
| border: 0; | |
| cursor: pointer; | |
| gap: var(--spacing-sm); | |
| font-size: 0.95rem; | |
| /* ensure pill appearance on all buttons */ | |
| border-radius: 999px; | |
| } | |
| .btn-primary { | |
| background: linear-gradient(135deg, var(--primary-1), var(--primary-2)); | |
| color: white; | |
| box-shadow: 0 2px 4px rgba(59, 130, 246, 0.25); | |
| } | |
| .btn-primary:hover { | |
| transform: translateY(-1px); | |
| box-shadow: 0 4px 8px rgba(59, 130, 246, 0.35); | |
| } | |
| .btn-secondary { | |
| background: var(--bg-alt); | |
| color: var(--text); | |
| border: 1px solid rgba(0,0,0,0.1); | |
| } | |
| .btn-secondary:hover { | |
| background: var(--bg); | |
| border-color: var(--primary-1); | |
| color: var(--primary-1); | |
| } | |
| /* Footer removed - styles cleaned up */ | |
| .article-content { | |
| background: var(--bg); | |
| border-radius: var(--card-radius); | |
| padding: var(--spacing-xl); | |
| margin-top: var(--spacing-lg); | |
| box-shadow: var(--shadow-md); | |
| max-width: 800px; | |
| margin-left: auto; | |
| margin-right: auto; | |
| } | |
| .article-content h1 { | |
| font-size: 2rem; | |
| margin: var(--spacing-md) 0 var(--spacing-lg); | |
| color: var(--text); | |
| font-weight: 700; | |
| line-height: 1.3; | |
| } | |
| .article-content p { | |
| margin: 0 0 var(--spacing-md); | |
| color: var(--text-light); | |
| line-height: 1.7; | |
| } | |
| .trix-content img{max-width:100%;height:auto;cursor:pointer;border-radius:6px} | |
| .breadcrumb{background:transparent;padding:0;margin-bottom:1rem} | |
| .breadcrumb{ | |
| display:flex; | |
| flex-wrap:wrap; | |
| gap:0.5rem; | |
| align-items:center; | |
| background:transparent; | |
| padding:0; | |
| margin-bottom:1rem; | |
| } | |
| .breadcrumb-item{ | |
| list-style:none; | |
| } | |
| .breadcrumb-item a{ | |
| display:inline-block; | |
| padding:0.4rem 0.8rem; | |
| background: var(--bg-alt); | |
| color: var(--text); | |
| border-radius: 999px; | |
| text-decoration:none; | |
| font-weight:600; | |
| transition: all var(--transition-fast); | |
| border: 1px solid var(--border-color); | |
| } | |
| .breadcrumb-item a:hover{ | |
| transform: translateY(-2px); | |
| box-shadow: var(--shadow-sm); | |
| } | |
| .breadcrumb-item.active{ | |
| display:inline-block; | |
| padding:0.45rem 1rem; | |
| border-radius:999px; | |
| background: linear-gradient(90deg, var(--primary-1), var(--accent-1)); | |
| color: #fff; | |
| font-weight:700; | |
| border: none; | |
| } | |
| /* small separator arrow */ | |
| .breadcrumb-item + .breadcrumb-item::before{ | |
| content: '›'; | |
| margin: 0 0.35rem; | |
| color: var(--text-light); | |
| } | |
| /* floats for image shortcodes */ | |
| .float-left{float:left;margin:0 1rem 1rem 0;max-width:40%} | |
| .float-right{float:right;margin:0 0 1rem 1rem;max-width:40%} | |
| /* video responsive container */ | |
| .video-player{width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:8px;margin-bottom:1rem} | |
| .video-player iframe{width:100%;height:100%;border:0} | |
| /* admin navigation */ | |
| .admin-nav{background:transparent;padding:.5rem 0;margin-bottom:1rem} | |
| .admin-nav a{display:inline-block;margin:.25rem;padding:.5rem .75rem;border-radius:6px;background:linear-gradient(135deg,var(--primary-1),var(--primary-2));color:#fff;text-decoration:none} | |
| /* Buttons full width on small screens */ | |
| .btn-full{display:block;width:100%} | |
| /* small utilities */ | |
| .text-muted{color:var(--muted)} | |
| /* Responsive layouts */ | |
| @media (min-width: 576px) { | |
| .container { | |
| max-width: 540px; | |
| } | |
| .header h1 { | |
| font-size: 1.75rem; | |
| } | |
| } | |
| @media (min-width: 768px) { | |
| .container { | |
| max-width: 720px; | |
| } | |
| .cards-grid { | |
| grid-template-columns: repeat(2, 1fr); | |
| } | |
| .article-content { | |
| padding: var(--spacing-xl); | |
| margin-top: var(--spacing-xl); | |
| } | |
| .btn { | |
| display: inline-flex; | |
| width: auto; | |
| } | |
| } | |
| @media (min-width: 992px) { | |
| .container { | |
| max-width: 960px; | |
| } | |
| .cards-grid { | |
| grid-template-columns: repeat(3, 1fr); | |
| gap: var(--spacing-xl); | |
| } | |
| .header { | |
| padding: var(--spacing-lg) 0; | |
| } | |
| } | |
| @media (min-width: 1200px) { | |
| .container { | |
| max-width: 1140px; | |
| } | |
| .article-content { | |
| padding: calc(var(--spacing-xl) * 1.5); | |
| } | |
| } | |
| /* Enhanced Trix editor */ | |
| trix-editor { | |
| min-height: 280px; | |
| border-radius: var(--card-radius); | |
| border: 1px solid rgba(0,0,0,0.1); | |
| padding: var(--spacing-md); | |
| background: var(--bg); | |
| color: var(--text); | |
| font-family: var(--font-base); | |
| line-height: var(--line-height-base); | |
| transition: border-color var(--transition-fast); | |
| } | |
| trix-editor:focus { | |
| outline: none; | |
| border-color: var(--primary-1); | |
| box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15); | |
| } | |
| /* Small screen optimizations */ | |
| @media (max-width: 575.98px) { | |
| .card-img-top { | |
| height: 200px; | |
| } | |
| .btn { | |
| width: 100%; | |
| margin-bottom: var(--spacing-sm); | |
| } | |
| .article-content { | |
| padding: var(--spacing-md); | |
| border-radius: var(--card-radius); | |
| margin-top: var(--spacing-md); | |
| } | |
| .nav-links { | |
| gap: var(--spacing-xs); | |
| } | |
| .header h1 { | |
| font-size: 1.25rem; | |
| } | |
| } | |
| /* Modern utilities */ | |
| .text-gradient { | |
| background: linear-gradient(135deg, var(--primary-1), var(--primary-2)); | |
| -webkit-background-clip: text; | |
| background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| } | |
| .glassmorphism { | |
| background: rgba(255, 255, 255, 0.8); | |
| backdrop-filter: blur(8px); | |
| -webkit-backdrop-filter: blur(8px); | |
| border: 1px solid rgba(255, 255, 255, 0.3); | |
| } | |
| .shadow-hover { | |
| transition: box-shadow var(--transition-fast); | |
| } | |
| .shadow-hover:hover { | |
| box-shadow: var(--shadow-lg); | |
| } |