/* =====================================================
   POLYGEN PLASTIK — Blog & Admin Styles
   ===================================================== */

/* Blog Listing */
.blog-hero { background: var(--color-primary); padding: calc(var(--header-height) + 4rem) 0 4rem; text-align: center; }
.blog-hero h1 { color: white; margin-bottom: var(--space-3); }
.blog-hero p { color: rgba(255,255,255,0.7); font-size: var(--text-lg); }
.blog-filters { display: flex; gap: var(--space-2); justify-content: center; margin-bottom: var(--space-8); flex-wrap: wrap; }
.blog-filter-btn { padding: 0.5rem 1.25rem; border-radius: var(--radius-full); border: 1px solid var(--color-border); background: white; font-size: var(--text-sm); font-weight: var(--fw-medium); cursor: pointer; transition: all var(--transition-fast); }
.blog-filter-btn:hover, .blog-filter-btn.active { background: var(--color-accent-green); color: white; border-color: var(--color-accent-green); }
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.blog-card { background: white; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: all var(--transition-normal); }
.blog-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.blog-card__image { width: 100%; height: 220px; object-fit: cover; background: linear-gradient(135deg, var(--color-primary-light), var(--color-accent-green-dark)); }
.blog-card__content { padding: var(--space-6); }
.blog-card__meta { display: flex; gap: var(--space-3); margin-bottom: var(--space-3); }
.blog-card__date { color: var(--color-text-light); font-size: var(--text-xs); }
.blog-card__category { color: var(--color-accent-green); font-size: var(--text-xs); font-weight: var(--fw-bold); text-transform: uppercase; }
.blog-card__title { font-size: var(--text-lg); margin-bottom: var(--space-3); color: var(--color-primary); line-height: 1.4; }
.blog-card__excerpt { color: var(--color-text-light); font-size: var(--text-sm); line-height: 1.6; margin-bottom: var(--space-4); }
.blog-card__link { color: var(--color-accent-green); font-weight: var(--fw-semibold); font-size: var(--text-sm); display: inline-flex; align-items: center; gap: 0.25rem; }

@media (max-width: 1024px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .blog-grid { grid-template-columns: 1fr; } }

/* ---- Admin Panel ---- */
.admin-login { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--color-primary); }
.admin-login__card { background: white; padding: var(--space-10); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); width: 100%; max-width: 420px; text-align: center; }
.admin-login__logo { font-size: 3rem; margin-bottom: var(--space-4); }
.admin-login__title { margin-bottom: var(--space-8); }

.admin-panel { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.admin-sidebar { background: var(--color-primary); padding: var(--space-6); display: flex; flex-direction: column; }
.admin-sidebar__logo { color: white; font-size: var(--text-xl); font-weight: var(--fw-bold); margin-bottom: var(--space-10); padding-bottom: var(--space-4); border-bottom: 1px solid rgba(255,255,255,0.1); }
.admin-sidebar__nav { display: flex; flex-direction: column; gap: var(--space-1); }
.admin-sidebar__link { color: rgba(255,255,255,0.6); padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: var(--fw-medium); transition: all var(--transition-fast); cursor: pointer; display: flex; align-items: center; gap: var(--space-3); }
.admin-sidebar__link:hover { color: white; background: rgba(255,255,255,0.08); }
.admin-sidebar__link.active { color: white; background: var(--color-accent-green); }
.admin-main { padding: var(--space-8); background: var(--color-bg-light); overflow-y: auto; }
.admin-main__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-8); }
.admin-main__title { font-size: var(--text-2xl); }

.admin-card { background: white; border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); margin-bottom: var(--space-6); }
.admin-card__title { font-size: var(--text-lg); margin-bottom: var(--space-4); padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-border); }

.admin-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin-bottom: var(--space-8); }
.admin-stat { background: white; border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); text-align: center; }
.admin-stat__number { font-size: var(--text-3xl); font-weight: var(--fw-bold); color: var(--color-accent-green); }
.admin-stat__label { font-size: var(--text-sm); color: var(--color-text-light); margin-top: var(--space-1); }

.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th { background: var(--color-bg-light); padding: var(--space-3) var(--space-4); text-align: left; font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--color-text-light); border-bottom: 2px solid var(--color-border); }
.admin-table td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); }
.admin-table tr:hover td { background: var(--color-bg-light); }

/* AI Generation */
.ai-preview { background: var(--color-bg-light); border-radius: var(--radius-lg); padding: var(--space-6); min-height: 300px; margin-top: var(--space-4); }
.ai-preview h2, .ai-preview h3 { margin: var(--space-4) 0 var(--space-2); }
.ai-preview p { line-height: 1.8; margin-bottom: var(--space-4); }
.ai-preview ul { padding-left: var(--space-6); margin-bottom: var(--space-4); }
.ai-preview li { margin-bottom: var(--space-2); list-style: disc; }
.ai-loading { display: flex; align-items: center; justify-content: center; gap: var(--space-3); padding: var(--space-10); color: var(--color-text-light); }
.ai-loading__spinner { width: 24px; height: 24px; border: 3px solid var(--color-border); border-top-color: var(--color-accent-green); border-radius: 50%; animation: spin 0.8s linear infinite; }

@media (max-width: 1024px) {
  .admin-panel { grid-template-columns: 1fr; }
  .admin-sidebar { display: none; }
  .admin-stats { grid-template-columns: repeat(2, 1fr); }
}
