/* =========================================================
   PROpersona — Blog & admin styles (extends style.css)
   ========================================================= */

/* PAGE LAYOUT (non-home) — header always solid white */
.page-blog .site-header,
.page-admin .site-header { background: #fff; box-shadow: 0 1px 0 var(--c-border); }
.page-blog .main-blog { padding-top: var(--header-h); }

/* BLOG HEADER (page hero strip) */
.blog-hero { padding: 64px 0 40px; background: var(--c-warm); border-bottom: 1px solid var(--c-border); }
.blog-hero .section-eyebrow { color: var(--c-accent); }
.blog-hero h1 { font-size: clamp(1.8rem, 3.6vw, 2.6rem); font-weight: 500; color: var(--c-primary-dark); margin-bottom: 10px; }
.blog-hero p { color: var(--c-text-light); max-width: 620px; }

/* BLOG LIST */
.blog-list-wrap { padding: 64px 0 100px; }
.blog-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px 28px; }
.blog-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--c-border); transition: var(--transition); overflow: hidden; }
.blog-card:hover { transform: translateY(-3px); box-shadow: var(--c-shadow); border-color: var(--c-accent); }
.blog-card a { color: inherit; }
.blog-card-img { aspect-ratio: 16/10; overflow: hidden; background: var(--c-warm); }
.blog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.blog-card:hover .blog-card-img img { transform: scale(1.04); }
.blog-card-body { padding: 22px 22px 26px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.blog-card-meta { font-size: .72rem; color: var(--c-accent); letter-spacing: .14em; text-transform: uppercase; font-weight: 600; }
.blog-card h2 { font-size: 1.15rem; font-family: var(--ff-display); font-weight: 500; color: var(--c-primary-dark); line-height: 1.3; }
.blog-card-excerpt { color: var(--c-text-light); font-size: .92rem; line-height: 1.65; flex: 1; }
.blog-card-link { font-size: .76rem; font-weight: 600; color: var(--c-primary); text-transform: uppercase; letter-spacing: .12em; padding-top: 6px; display: inline-flex; align-items: center; gap: 6px; }
.blog-card-link::after { content: '→'; transition: transform var(--transition); }
.blog-card:hover .blog-card-link { color: var(--c-accent); }
.blog-card:hover .blog-card-link::after { transform: translateX(4px); }
.blog-empty { text-align: center; padding: 80px 20px; color: var(--c-text-light); font-size: .95rem; }

/* SINGLE POST */
.post { padding: 48px 0 80px; }
.post-back { display: inline-flex; align-items: center; gap: 8px; font-size: .78rem; font-weight: 600; color: var(--c-text-light); text-transform: uppercase; letter-spacing: .14em; margin-bottom: 20px; }
.post-back:hover { color: var(--c-accent); }
.post-header { max-width: 820px; margin: 0 auto 36px; text-align: center; }
.post-header .post-meta { font-size: .76rem; color: var(--c-accent); letter-spacing: .16em; text-transform: uppercase; font-weight: 600; margin-bottom: 14px; }
.post-header h1 { font-size: clamp(1.7rem, 3.4vw, 2.4rem); font-weight: 500; color: var(--c-primary-dark); line-height: 1.2; margin-bottom: 18px; }
.post-header .post-excerpt { color: var(--c-text-light); font-size: 1.05rem; line-height: 1.65; }
.post-feature { max-width: 980px; margin: 0 auto 48px; aspect-ratio: 16/9; overflow: hidden; background: var(--c-warm); }
.post-feature img { width: 100%; height: 100%; object-fit: cover; }
.post-body { max-width: 720px; margin: 0 auto; font-size: 1.02rem; line-height: 1.8; color: var(--c-text); }
.post-body p { margin: 0 0 20px; }
.post-body h2 { font-size: 1.5rem; margin: 36px 0 14px; color: var(--c-primary-dark); font-weight: 500; }
.post-body h3 { font-size: 1.2rem; margin: 28px 0 10px; color: var(--c-primary-dark); font-weight: 600; font-family: var(--ff-body); }
.post-body ul, .post-body ol { margin: 0 0 20px 20px; padding-left: 16px; color: var(--c-text); }
.post-body ul li { list-style: disc; margin-bottom: 6px; }
.post-body ol li { list-style: decimal; margin-bottom: 6px; }
.post-body a { color: var(--c-accent); text-decoration: underline; }
.post-body img { max-width: 100%; height: auto; display: block; margin: 24px auto; border-radius: 4px; }
.post-body blockquote { border-left: 3px solid var(--c-accent); padding: 8px 0 8px 20px; margin: 24px 0; color: var(--c-text-light); font-style: italic; }
.post-body strong { color: var(--c-primary-dark); }
.post-share { max-width: 720px; margin: 50px auto 0; padding-top: 24px; border-top: 1px solid var(--c-border); display: flex; gap: 14px; align-items: center; flex-wrap: wrap; font-size: .82rem; color: var(--c-text-light); }
.post-share a { padding: 8px 16px; border: 1px solid var(--c-border); font-size: .76rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--c-primary); transition: var(--transition); }
.post-share a:hover { background: var(--c-accent); color: #fff; border-color: var(--c-accent); }

/* RELATED POSTS */
.related { padding: 60px 0; background: var(--c-warm); border-top: 1px solid var(--c-border); }
.related h2 { font-size: 1rem; font-family: var(--ff-body); font-weight: 600; text-transform: uppercase; letter-spacing: .18em; color: var(--c-primary); text-align: center; margin-bottom: 36px; }

@media (max-width: 1024px) {
  .blog-list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px) {
  .blog-list { grid-template-columns: 1fr; gap: 28px; }
  .post-feature { aspect-ratio: 4/3; }
  .post-header h1 { font-size: 1.5rem; }
}

/* =====================================================
   ADMIN
   ===================================================== */

.page-admin { background: var(--c-warm); min-height: 100vh; }
.admin-shell { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; }
.admin-side { background: var(--c-primary-dark); color: rgba(255,255,255,.85); padding: 28px 0; display: flex; flex-direction: column; }
.admin-side .admin-brand { padding: 0 24px 28px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 18px; }
.admin-side .admin-brand img { height: 38px; background: #fff; padding: 5px 10px; border-radius: 5px; display: inline-block; }
.admin-side a { display: flex; align-items: center; gap: 10px; padding: 12px 24px; color: rgba(255,255,255,.75); font-size: .88rem; font-weight: 500; transition: var(--transition); }
.admin-side a:hover, .admin-side a.active { background: rgba(255,255,255,.06); color: var(--c-accent); }
.admin-side .admin-side-foot { margin-top: auto; padding: 24px; border-top: 1px solid rgba(255,255,255,.08); font-size: .78rem; color: rgba(255,255,255,.5); }
.admin-side .admin-side-foot a { padding: 8px 0; color: rgba(255,255,255,.7); }
.admin-side .admin-side-foot a:hover { color: var(--c-accent); }

.admin-main { padding: 36px 44px 80px; }
.admin-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.admin-head h1 { font-size: 1.5rem; font-weight: 500; color: var(--c-primary-dark); font-family: var(--ff-display); }
.admin-head .btn { font-size: .76rem; padding: 11px 20px; }
.admin-card { background: #fff; border: 1px solid var(--c-border); padding: 28px; }

.flash { padding: 12px 16px; border-radius: 4px; margin-bottom: 20px; font-size: .9rem; }
.flash.ok { background: #E6F4EA; color: #1F5132; border-left: 3px solid #2D8659; }
.flash.err { background: #FCE8E6; color: #842029; border-left: 3px solid #D9534F; }

.posts-table { width: 100%; border-collapse: collapse; background: #fff; }
.posts-table th, .posts-table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--c-border); font-size: .9rem; vertical-align: middle; }
.posts-table th { background: var(--c-warm); font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; color: var(--c-primary); font-weight: 600; }
.posts-table tr:hover td { background: #fafaf8; }
.posts-table .pill { display: inline-block; padding: 3px 10px; border-radius: 12px; font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 600; }
.pill.published { background: #E6F4EA; color: #1F5132; }
.pill.draft { background: var(--c-warm-dark); color: var(--c-text-light); }
.posts-table .actions a, .posts-table .actions button { font-size: .78rem; padding: 6px 12px; border: 1px solid var(--c-border); margin-right: 4px; color: var(--c-primary); cursor: pointer; background: #fff; transition: var(--transition); }
.posts-table .actions a:hover { background: var(--c-accent); color: #fff; border-color: var(--c-accent); }
.posts-table .actions .danger:hover { background: #D9534F; color: #fff; border-color: #D9534F; }

.form-row { margin-bottom: 18px; }
.form-row label { display: block; font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .12em; color: var(--c-primary); margin-bottom: 6px; }
.form-row input[type=text], .form-row input[type=email], .form-row input[type=password], .form-row textarea, .form-row select {
  width: 100%; padding: 11px 14px; background: #fff; border: 1px solid var(--c-border); font-size: .92rem; color: var(--c-text); font-family: inherit; transition: var(--transition);
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus { border-color: var(--c-accent); box-shadow: 0 0 0 3px rgba(201,165,107,.12); outline: none; }
.form-row .help { font-size: .78rem; color: var(--c-text-light); margin-top: 4px; }
.form-row.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-actions { padding-top: 16px; border-top: 1px solid var(--c-border); margin-top: 24px; display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.form-actions .spacer { flex: 1; }

.featured-preview { margin-top: 8px; max-width: 280px; aspect-ratio: 16/10; background: var(--c-warm); border: 1px dashed var(--c-border); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.featured-preview img { width: 100%; height: 100%; object-fit: cover; }

/* LOGIN */
.login-shell { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--c-primary-dark) 0%, var(--c-primary) 100%); padding: 24px; }
.login-card { background: #fff; padding: 44px 40px; max-width: 400px; width: 100%; border-radius: 6px; box-shadow: 0 24px 60px -20px rgba(0,0,0,.4); border-top: 3px solid var(--c-accent); }
.login-card .logo { display: block; text-align: center; margin-bottom: 24px; }
.login-card .logo img { height: 56px; }
.login-card h1 { font-size: 1.2rem; text-align: center; margin-bottom: 6px; font-weight: 500; }
.login-card .login-sub { text-align: center; font-size: .85rem; color: var(--c-text-light); margin-bottom: 28px; }
.login-card .form-row label { color: var(--c-primary-dark); }
.login-card .btn { width: 100%; justify-content: center; padding: 14px; font-size: .82rem; }

/* TinyMCE container */
.tox-tinymce { border-color: var(--c-border) !important; }
