/*
Theme Name: HumorPets
Theme URI: https://humorpets.com
Author: HumorPets
Description: A viral pet humor community platform inspired by BoredPanda. Features post submission, voting, user accounts, dashboard, and full community tools.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: humorpets
Tags: community, blog, magazine, viral, pets, humor
*/

/* ============================================================
   CSS VARIABLES
   ============================================================ */
:root {
  --orange:      #FF6314;
  --orange-dk:   #e5550d;
  --orange-lt:   #fff3ee;
  --dark:        #1a1a2e;
  --mid:         #2d2d44;
  --text:        #222233;
  --muted:       #6b7280;
  --border:      #e5e7eb;
  --bg:          #f3f4f6;
  --white:       #ffffff;
  --green:       #16a34a;
  --red:         #dc2626;
  --yellow:      #f59e0b;
  --radius:      10px;
  --radius-sm:   6px;
  --shadow:      0 1px 4px rgba(0,0,0,.08),0 2px 12px rgba(0,0,0,.06);
  --shadow-lg:   0 4px 24px rgba(0,0,0,.14);
  --font-head:   'Montserrat','Arial Black',sans-serif;
  --font-body:   'Open Sans',Arial,sans-serif;
  --font-ui:     'Inter',Arial,sans-serif;
  --max-w:       1200px;
  --sidebar-w:   320px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--orange);text-decoration:none;transition:color .15s}
a:hover{color:var(--orange-dk)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{font-family:var(--font-ui)}
input,textarea,select{font-family:var(--font-body)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:800;line-height:1.25;color:var(--dark)}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}
.flex{display:flex}.flex-col{flex-direction:column}
.align-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.gap-xs{gap:6px}.gap-sm{gap:10px}.gap-md{gap:16px}.gap-lg{gap:24px}.gap-xl{gap:32px}
.text-center{text-align:center}.text-right{text-align:right}
.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--muted)}
.fw-bold{font-weight:700}.fw-black{font-weight:900}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}
.p-0{padding:0}.hidden{display:none!important}
.w-full{width:100%}.grid{display:grid}

/* ============================================================
   BADGE
   ============================================================ */
.badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:.72rem;font-weight:700;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.06em;line-height:1.6}
.badge-orange{background:var(--orange);color:#fff}
.badge-dark{background:var(--dark);color:#fff}
.badge-green{background:#dcfce7;color:#166534}
.badge-yellow{background:#fef3c7;color:#92400e}
.badge-red{background:#fee2e2;color:#991b1b}
.badge-gray{background:var(--border);color:var(--muted)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 22px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-weight:700;font-size:.9rem;border:none;cursor:pointer;transition:all .18s;text-decoration:none;line-height:1;white-space:nowrap}
.btn:focus-visible{outline:3px solid var(--orange);outline-offset:2px}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-dk);color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px rgba(255,99,20,.35)}
.btn-secondary{background:var(--dark);color:#fff}
.btn-secondary:hover{background:var(--mid);color:#fff;transform:translateY(-1px)}
.btn-outline{background:transparent;border:2px solid var(--orange);color:var(--orange)}
.btn-outline:hover{background:var(--orange);color:#fff}
.btn-ghost{background:transparent;border:2px solid var(--border);color:var(--text)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-lt)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover{background:#15803d;color:#fff}
.btn-sm{padding:6px 14px;font-size:.8rem;border-radius:var(--radius-sm)}
.btn-lg{padding:14px 32px;font-size:1rem}
.btn-xl{padding:16px 40px;font-size:1.05rem}
.btn-block{width:100%}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none!important}

/* Social login buttons */
.btn-google{background:#fff;color:#333;border:2px solid var(--border)}
.btn-google:hover{border-color:#4285f4;color:#4285f4;background:#fff}
.btn-facebook{background:#1877f2;color:#fff}
.btn-facebook:hover{background:#1565d8;color:#fff}

/* ============================================================
   FORMS
   ============================================================ */
.form-group{margin-bottom:20px}
.form-label{display:block;font-family:var(--font-ui);font-weight:600;font-size:.875rem;color:var(--dark);margin-bottom:6px}
.form-label .req{color:var(--red)}
.form-control{width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--white);transition:border-color .18s,box-shadow .18s;outline:none;appearance:none}
.form-control:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,99,20,.1)}
.form-control::placeholder{color:#bbb}
.form-control:invalid:not(:placeholder-shown){border-color:var(--red)}
textarea.form-control{resize:vertical;min-height:120px}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-hint{font-size:.8rem;color:var(--muted);margin-top:4px}
.form-error{font-size:.8rem;color:var(--red);margin-top:4px;display:none}
.has-error .form-control{border-color:var(--red)}
.has-error .form-error{display:block}
.input-icon-wrap{position:relative}
.input-icon-wrap .form-control{padding-left:40px}
.input-icon-wrap .icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:1rem;pointer-events:none}
.char-count{font-size:.77rem;color:var(--muted);text-align:right;margin-top:3px}

/* Checkbox & Radio */
.form-check{display:flex;align-items:center;gap:9px;cursor:pointer;font-size:.9rem}
.form-check input[type=checkbox],.form-check input[type=radio]{width:18px;height:18px;accent-color:var(--orange);cursor:pointer;flex-shrink:0}

/* ============================================================
   ALERTS / NOTICES
   ============================================================ */
.alert{padding:13px 16px;border-radius:var(--radius-sm);font-size:.9rem;display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;border:1px solid transparent}
.alert .alert-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
.alert-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}
.alert-error{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.alert-info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}
.alert-warning{background:#fffbeb;color:#92400e;border-color:#fde68a}
.alert-dismiss{margin-left:auto;background:none;border:none;cursor:pointer;opacity:.6;font-size:1rem;padding:0;line-height:1}
.alert-dismiss:hover{opacity:1}

/* ============================================================
   HEADER
   ============================================================ */
#site-header{background:var(--white);border-bottom:3px solid var(--orange);position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.07)}
.header-wrap{display:flex;align-items:center;height:66px;gap:18px}

/* Logo */
.site-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--orange),#ff9a3c);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.35rem;box-shadow:0 2px 8px rgba(255,99,20,.3)}
.logo-text{font-family:var(--font-head);font-size:1.5rem;font-weight:900;color:var(--dark);line-height:1}
.logo-text em{color:var(--orange);font-style:normal}

/* Search */
.header-search{flex:1;max-width:440px;position:relative}
.header-search input{width:100%;padding:9px 42px 9px 16px;border:2px solid var(--border);border-radius:30px;font-size:.9rem;outline:none;background:var(--bg);transition:all .18s}
.header-search input:focus{border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(255,99,20,.08)}
.header-search .search-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:var(--orange);border:none;border-radius:20px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:.85rem;transition:background .15s}
.header-search .search-btn:hover{background:var(--orange-dk)}

/* Nav */
.header-nav{display:flex;align-items:center;gap:4px}
.header-nav a.nav-link{font-family:var(--font-ui);font-weight:600;font-size:.875rem;color:var(--text);padding:7px 11px;border-radius:var(--radius-sm);transition:all .15s}
.header-nav a.nav-link:hover,.header-nav a.nav-link.active{color:var(--orange);background:var(--orange-lt)}

/* User avatar dropdown */
.user-menu{position:relative;display:flex;align-items:center}
.user-avatar-btn{width:38px;height:38px;border-radius:50%;border:2px solid var(--orange);cursor:pointer;overflow:hidden;padding:0;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:box-shadow .15s}
.user-avatar-btn:hover{box-shadow:0 0 0 3px rgba(255,99,20,.2)}
.user-avatar-btn img{width:100%;height:100%;object-fit:cover}
.user-dropdown{display:none;position:absolute;right:0;top:calc(100% + 10px);background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:210px;padding:6px 0;z-index:500}
.user-dropdown.open{display:block;animation:fadeDown .15s ease}
@keyframes fadeDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.user-dropdown .dd-header{padding:12px 16px 10px;border-bottom:1px solid var(--border)}
.user-dropdown .dd-name{font-weight:700;font-size:.9rem;color:var(--dark)}
.user-dropdown .dd-email{font-size:.77rem;color:var(--muted)}
.user-dropdown a,.user-dropdown button{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:.875rem;font-family:var(--font-ui);color:var(--text);width:100%;background:none;border:none;cursor:pointer;text-align:left;text-decoration:none;transition:background .12s}
.user-dropdown a:hover,.user-dropdown button:hover{background:var(--bg);color:var(--orange)}
.user-dropdown hr{border:none;border-top:1px solid var(--border);margin:5px 0}
.dd-icon{font-size:1rem;width:20px;text-align:center}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;border-radius:var(--radius-sm);transition:background .15s}
.hamburger:hover{background:var(--bg)}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   CATEGORY BAR
   ============================================================ */
.cat-bar{background:var(--white);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none}
.cat-bar::-webkit-scrollbar{display:none}
.cat-bar-inner{display:flex;align-items:stretch;gap:0;max-width:var(--max-w);margin:0 auto;padding:0 20px}
.cat-bar a{padding:10px 13px;font-family:var(--font-ui);font-weight:600;font-size:.8rem;color:var(--muted);white-space:nowrap;border-bottom:3px solid transparent;transition:all .15s;text-transform:uppercase;letter-spacing:.05em;text-decoration:none}
.cat-bar a:hover,.cat-bar a.active{color:var(--orange);border-bottom-color:var(--orange)}

/* ============================================================
   HERO BANNER
   ============================================================ */
.hero{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 40%,#0f3460 100%);padding:52px 0;position:relative;overflow:hidden}
.hero::before{content:'🐱🐶🐰🦊🐸🦜🐠🐹';position:absolute;right:-20px;top:-10px;font-size:7rem;opacity:.06;letter-spacing:-.5rem;line-height:1;pointer-events:none}
.hero-inner{text-align:center;position:relative;z-index:1}
.hero-eyebrow{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.18em;color:var(--orange);margin-bottom:12px;font-family:var(--font-ui)}
.hero-title{font-size:clamp(2rem,5vw,3.4rem);font-weight:900;color:#fff;margin-bottom:14px;line-height:1.1}
.hero-title em{color:var(--orange);font-style:normal}
.hero-desc{font-size:1.05rem;color:rgba(255,255,255,.68);max-width:540px;margin:0 auto 28px;line-height:1.65}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;gap:32px;justify-content:center;margin-top:32px;flex-wrap:wrap}
.hero-stat{text-align:center}
.hero-stat-num{font-size:1.6rem;font-weight:900;color:#fff;font-family:var(--font-head);line-height:1}
.hero-stat-label{font-size:.78rem;color:rgba(255,255,255,.5);font-family:var(--font-ui);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:3px}

/* ============================================================
   MAIN LAYOUT
   ============================================================ */
.site-main{padding:28px 0 60px}
.content-sidebar-wrap{display:grid;grid-template-columns:1fr var(--sidebar-w);gap:28px;align-items:start}
.main-content{min-width:0}


/* =============================================================
   LAYOUT
   ============================================================= */
.site-main { padding: 28px 0 60px; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.content-sidebar-wrap {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 24px;
  align-items: start;
}
.main-content { min-width: 0; }

/* =============================================================
   HERO BANNER
   ============================================================= */
.hero {
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 40%, #0f3460 100%);
  padding: 52px 0;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '🐱🐶🐰🦊🐸🦜🐠🐹';
  position: absolute; right: -20px; top: -10px;
  font-size: 7rem; opacity: .05; letter-spacing: -.5rem;
  line-height: 1; pointer-events: none;
}
.hero-inner { text-align: center; position: relative; z-index: 1; }
.hero-eyebrow {
  font-size: .7rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .18em; color: #FF6314; margin-bottom: 12px;
  font-family: 'Inter', sans-serif;
}
.hero-title {
  font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 900; color: #fff;
  margin-bottom: 14px; line-height: 1.1;
  font-family: 'Montserrat', sans-serif;
}
.hero-title em { color: #FF6314; font-style: normal; }
.hero-desc {
  font-size: 1rem; color: rgba(255,255,255,.65);
  max-width: 520px; margin: 0 auto 26px; line-height: 1.65;
}
.hero-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 30px; justify-content: center; margin-top: 30px; flex-wrap: wrap; }
.hero-stat { text-align: center; }
.hero-stat-num {
  font-size: 1.55rem; font-weight: 900; color: #fff;
  font-family: 'Montserrat', sans-serif; line-height: 1;
}
.hero-stat-label {
  font-size: .72rem; color: rgba(255,255,255,.45); font-family: 'Inter', sans-serif;
  font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-top: 3px;
}

/* =============================================================
   FEED HEADER (sort bar)
   ============================================================= */
.feed-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid #f0f0f0;
  flex-wrap: wrap;
  gap: 10px;
}
.feed-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 1rem; font-weight: 900; color: #1a1a2e;
  display: flex; align-items: center; gap: 7px;
}
.feed-sort { display: flex; gap: 6px; }
.feed-sort-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 14px; border-radius: 20px;
  font-family: 'Inter', sans-serif; font-weight: 700; font-size: .78rem;
  color: #6b7280; text-decoration: none;
  border: 1.5px solid #e5e7eb; background: #fff;
  transition: all .15s;
}
.feed-sort-btn:hover,
.feed-sort-btn.active {
  border-color: #FF6314; color: #FF6314; background: #fff3ee;
}

/* =============================================================
   POST CARD  — Image 2 reference style
   ============================================================= */
.hp-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid #e8eaed;
  box-shadow: 0 1px 6px rgba(0,0,0,.07);
  margin-bottom: 16px;
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
}
.hp-card:hover {
  box-shadow: 0 6px 28px rgba(0,0,0,.1);
  transform: translateY(-2px);
}

/* ── Author row ── */
.hp-card-author {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px 8px;
}
.hp-card-av-link { display: block; flex-shrink: 0; line-height: 0; }
.hp-card-avatar {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  display: block !important;
  border: 2px solid #f3f4f6;
}
.hp-card-author-info { flex: 1; min-width: 0; }
.hp-card-author-name {
  font-family: 'Inter', sans-serif;
  font-weight: 700; font-size: .875rem;
  color: #1a1a2e; text-decoration: none;
  display: block; line-height: 1.3;
}
.hp-card-author-name:hover { color: #FF6314; }
.hp-card-meta-row {
  display: flex; align-items: center; gap: 5px; margin-top: 2px;
}
.hp-card-time,
.hp-card-views {
  font-size: .74rem; color: #9ca3af; font-family: 'Inter', sans-serif;
}
.hp-card-sep { color: #d1d5db; font-size: .74rem; }
.hp-card-cat {
  font-family: 'Inter', sans-serif; font-size: .68rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .07em;
  color: #FF6314; background: #fff3ee;
  padding: 3px 10px; border-radius: 20px; text-decoration: none;
  flex-shrink: 0; transition: all .15s; line-height: 1.7; white-space: nowrap;
}
.hp-card-cat:hover { background: #FF6314; color: #fff; }

/* ── Title ── */
.hp-card-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.15rem; font-weight: 900; line-height: 1.3;
  color: #1a1a2e; padding: 4px 16px 12px; margin: 0;
}
.hp-card-title a { color: inherit; text-decoration: none; }
.hp-card-title a:hover { color: #FF6314; }

/* ── Featured image — FULL natural height ── */
.hp-card-img-wrap {
  display: block;
  width: 100%;
  line-height: 0;
  background: #f8f9fb;
}
.hp-card-img {
  width: 100%;
  height: auto;
  display: block;
  /* No max-height, no object-fit — show full image */
}

/* ── Excerpt ── */
.hp-card-excerpt {
  padding: 12px 16px 6px;
  font-size: .875rem; color: #6b7280;
  line-height: 1.6; margin: 0;
  font-family: 'Open Sans', sans-serif;
}

/* ── Tags ── */
.hp-card-tags {
  display: flex; flex-wrap: wrap; gap: 6px; padding: 6px 16px 2px;
}
.hp-card-tag {
  font-size: .72rem; color: #9ca3af; font-family: 'Inter', sans-serif;
  font-weight: 600; text-decoration: none; transition: color .12s;
}
.hp-card-tag:hover { color: #FF6314; }

/* ── Footer row (Funny | +0 | Meh  ·  comments · share · view) ── */
.hp-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 12px;
  border-top: 1px solid #f0f0f0;
  margin-top: 8px;
  gap: 8px;
}

/* Vote pill */
.hp-vote-pill {
  display: inline-flex;
  align-items: center;
  border: 1.5px solid #e5e7eb;
  border-radius: 30px;
  overflow: hidden;
  flex-shrink: 0;
  background: #fff;
}
.hp-vote-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 13px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-weight: 700; font-size: .8rem;
  color: #6b7280;
  transition: all .15s;
  line-height: 1;
  white-space: nowrap;
}
.hp-vote-emoji { font-size: .92rem; line-height: 1; }
.hp-vote-sep {
  width: 1px; height: 22px;
  background: #e5e7eb; flex-shrink: 0; display: inline-block;
}
.hp-vote-score {
  font-family: 'Montserrat', sans-serif; font-weight: 900;
  font-size: .88rem; color: #1a1a2e;
  min-width: 30px; text-align: center; padding: 0 5px;
}
.hp-vote-up:hover,
.hp-vote-up.is-active  { color: #FF6314; background: #fff3ee; }
.hp-vote-down:hover,
.hp-vote-down.is-active { color: #dc2626; background: #fef2f2; }

/* Action buttons */
.hp-card-actions {
  display: inline-flex; align-items: center; gap: 2px;
}
.hp-card-action {
  display: inline-flex; align-items: center; gap: 5px;
  background: none; border: none; cursor: pointer;
  font-family: 'Inter', sans-serif; font-weight: 600; font-size: .78rem;
  color: #9ca3af; padding: 6px 8px; border-radius: 7px;
  text-decoration: none; transition: all .15s; line-height: 1; white-space: nowrap;
}
.hp-card-action:hover { color: #FF6314; background: #fff3ee; }
.hp-card-action svg { flex-shrink: 0; }
.hp-card-readmore { color: #FF6314; font-weight: 700; }
.hp-card-readmore:hover { color: #e5550d; background: #fff3ee; }

/* No results */
.no-results {
  text-align: center; padding: 60px 20px;
  background: #fff; border-radius: 12px; border: 1px solid #e8eaed;
}
.no-results-emoji { font-size: 3rem; margin-bottom: 12px; }
.no-results h2 { font-size: 1.3rem; font-family: 'Montserrat', sans-serif; margin-bottom: 8px; color: #1a1a2e; }
.no-results p { color: #6b7280; font-size: .875rem; max-width: 360px; margin: 0 auto 20px; }

/* =============================================================
   SIDEBAR
   ============================================================= */
.sidebar {
  display: flex; flex-direction: column; gap: 16px;
  position: sticky; top: 90px;
}
.widget {
  background: #fff; border-radius: 12px; padding: 18px;
  box-shadow: 0 1px 6px rgba(0,0,0,.07); border: 1px solid #e8eaed;
}
.widget-title {
  font-size: .68rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .12em; color: #9ca3af; margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 2px solid #f3f4f6;
  font-family: 'Inter', sans-serif;
}

/* Trending */
.trending-list { display: flex; flex-direction: column; }
.trending-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 10px 0; border-bottom: 1px solid #f9fafb;
}
.trending-item:last-child { border-bottom: none; padding-bottom: 0; }
.trending-rank {
  width: 22px; height: 22px; background: #FF6314; color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: .68rem; font-weight: 900; flex-shrink: 0; margin-top: 2px;
  font-family: 'Inter', sans-serif;
}
.trending-rank.top-3 { background: #1a1a2e; }
.trending-thumb {
  width: 68px; height: 52px; object-fit: cover; border-radius: 8px;
  flex-shrink: 0; background: #e5e7eb; display: block;
}
.trending-info { flex: 1; min-width: 0; }
.trending-title { font-size: .82rem; font-weight: 700; color: #1a1a2e; line-height: 1.3; margin-bottom: 3px; }
.trending-title a { color: inherit; text-decoration: none; }
.trending-title a:hover { color: #FF6314; }
.trending-meta { font-size: .73rem; color: #9ca3af; font-family: 'Inter', sans-serif; }

/* Newsletter */
.newsletter-widget {
  background: linear-gradient(135deg,#1a1a2e,#16213e); color: #fff; padding: 20px;
}
.newsletter-widget .widget-title {
  color: rgba(255,255,255,.4); border-bottom-color: rgba(255,255,255,.08);
}
.newsletter-widget h4 { color: #fff; font-size: .92rem; margin-bottom: 5px; font-family: 'Montserrat', sans-serif; }
.newsletter-widget p { color: rgba(255,255,255,.58); font-size: .8rem; margin-bottom: 12px; line-height: 1.55; }
.newsletter-form { display: flex; flex-direction: column; gap: 7px; }
.newsletter-form .nl-input {
  background: rgba(255,255,255,.1); border: 1.5px solid rgba(255,255,255,.18);
  color: #fff; border-radius: 8px; padding: 9px 12px;
  font-size: .875rem; font-family: 'Open Sans', sans-serif;
  outline: none; width: 100%; box-sizing: border-box;
}
.newsletter-form .nl-input::placeholder { color: rgba(255,255,255,.38); }
.newsletter-form .nl-input:focus { border-color: #FF6314; }
.newsletter-form .nl-btn {
  background: #FF6314; color: #fff; border: none; border-radius: 8px;
  padding: 10px; font-family: 'Montserrat', sans-serif; font-weight: 800;
  font-size: .84rem; cursor: pointer; transition: all .18s; width: 100%;
}
.newsletter-form .nl-btn:hover { background: #e5550d; }
.nl-success, .nl-error {
  border-radius: 7px; padding: 9px 11px; font-size: .8rem;
  font-family: 'Inter', sans-serif; display: none;
}
.nl-success { background: rgba(22,163,74,.2); border:1px solid rgba(22,163,74,.35); color: #4ade80; }
.nl-error   { background: rgba(220,38,38,.2); border:1px solid rgba(220,38,38,.35); color: #f87171; }
.nl-success.show, .nl-error.show { display: block; }

/* Submit CTA */
.submit-cta-widget {
  background: linear-gradient(135deg,#FF6314,#ff9a3c); text-align: center; padding: 22px 16px;
}
.submit-cta-widget h4 { color: #fff; font-size: .92rem; margin-bottom: 5px; font-family: 'Montserrat', sans-serif; }
.submit-cta-widget p { color: rgba(255,255,255,.8); font-size: .79rem; margin-bottom: 13px; line-height: 1.5; }
.submit-cta-widget .cta-icon { font-size: 1.7rem; margin-bottom: 8px; }

/* Tags */
.tags-cloud { display: flex; flex-wrap: wrap; gap: 7px; }
.tag-pill {
  padding: 4px 11px; background: #f3f4f6; border: 1px solid #e5e7eb;
  border-radius: 20px; font-size: .78rem; color: #374151;
  font-family: 'Inter', sans-serif; transition: all .15s;
  text-decoration: none; display: inline-block; font-weight: 600;
}
.tag-pill:hover { background: #FF6314; color: #fff; border-color: #FF6314; }

/* Social follow */
.social-follow { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.social-follow-btn {
  display: flex; align-items: center; gap: 7px; padding: 8px 10px;
  border-radius: 8px; font-size: .77rem; font-weight: 700;
  font-family: 'Inter', sans-serif; cursor: pointer; border: none;
  text-decoration: none; transition: opacity .15s; line-height: 1.3;
}
.social-follow-btn:hover { opacity: .85; }
.sf-fb { background: #1877f2; color: #fff; }
.sf-ig { background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color: #fff; }
.sf-tw { background: #000; color: #fff; }
.sf-yt { background: #ff0000; color: #fff; }

/* =============================================================
   SINGLE POST
   ============================================================= */
.single-wrap { background: #fff; border-radius: 12px; box-shadow: 0 2px 12px rgba(0,0,0,.07); overflow: hidden; border: 1px solid #e8eaed; }
.single-header { padding: 26px 28px 0; }
.single-cat-row { margin-bottom: 10px; }
.single-title { font-size: clamp(1.4rem,3vw,2rem); font-weight: 900; line-height: 1.2; margin-bottom: 16px; font-family: 'Montserrat', sans-serif; color: #1a1a2e; }
.single-meta { display: flex; align-items: center; gap: 14px; padding-bottom: 16px; border-bottom: 1px solid #f3f4f6; flex-wrap: wrap; }
.meta-author { display: flex; align-items: center; gap: 8px; text-decoration: none; color: #1a1a2e; }
.meta-author:hover .meta-author-name { color: #FF6314; }
.meta-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; background: #e5e7eb; }
.meta-author-name { font-family: 'Inter', sans-serif; font-weight: 700; font-size: .84rem; }
.meta-date, .meta-views, .meta-read-time { font-size: .78rem; color: #9ca3af; font-family: 'Inter', sans-serif; }
.single-hero-img { width: 100%; height: auto; display: block; margin-top: 18px; }
.single-content { padding: 24px 28px; font-size: .95rem; line-height: 1.78; color: #374151; }
.single-content p { margin-bottom: 1.2em; }
.single-content h2 { font-size: 1.35rem; margin: 1.8em 0 .6em; color: #1a1a2e; font-family: 'Montserrat', sans-serif; }
.single-content h3 { font-size: 1.1rem; margin: 1.5em 0 .5em; color: #1a1a2e; font-family: 'Montserrat', sans-serif; }
.single-content ul, .single-content ol { padding-left: 24px; margin-bottom: 1.2em; }
.single-content li { margin-bottom: .4em; }
.single-content blockquote { border-left: 4px solid #FF6314; padding: 12px 18px; background: #fff3ee; border-radius: 0 8px 8px 0; margin: 1.4em 0; font-style: italic; color: #6b7280; }
.single-content img { border-radius: 8px; margin: 16px 0; width: 100%; display: block; }
.single-content a { color: #FF6314; text-decoration: underline; }
.single-vote { padding: 20px 28px; background: #f9fafb; border-top: 1px solid #f3f4f6; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.points-big { text-align: center; }
.points-num { font-family: 'Montserrat', sans-serif; font-size: 2.2rem; font-weight: 900; color: #FF6314; line-height: 1; }
.points-label { font-size: .7rem; color: #9ca3af; font-family: 'Inter', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; margin-top: 3px; }
.single-vote-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.single-vote-btn { display: inline-flex; align-items: center; gap: 7px; padding: 10px 18px; border: 2px solid #e5e7eb; border-radius: 30px; background: #fff; cursor: pointer; font-family: 'Inter', sans-serif; font-weight: 700; font-size: .88rem; color: #374151; transition: all .18s; }
.single-vote-btn:hover, .single-vote-btn.voted { border-color: #FF6314; color: #FF6314; background: #fff3ee; }
.single-vote-btn.down:hover, .single-vote-btn.down.voted { border-color: #dc2626; color: #dc2626; background: #fef2f2; }
.post-tags-section { padding: 14px 28px; border-top: 1px solid #f3f4f6; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.tags-label { font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #9ca3af; font-family: 'Inter', sans-serif; }
.share-section { padding: 16px 28px; border-top: 1px solid #f3f4f6; }
.share-label { font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #9ca3af; font-family: 'Inter', sans-serif; margin-bottom: 10px; }
.share-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.share-btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: 7px; font-size: .8rem; font-weight: 700; font-family: 'Inter', sans-serif; cursor: pointer; border: none; transition: opacity .15s; text-decoration: none; }
.share-btn:hover { opacity: .84; }
.share-fb { background: #1877f2; color: #fff; } .share-tw { background: #000; color: #fff; }
.share-wa { background: #25d366; color: #fff; } .share-rd { background: #ff4500; color: #fff; }
.share-copy { background: #e5e7eb; color: #374151; } .share-copy.copied { background: #16a34a; color: #fff; }
.author-box { margin: 0 28px; padding: 18px; background: #f9fafb; border-radius: 10px; display: flex; gap: 14px; align-items: flex-start; }
.author-box-avatar { width: 60px; height: 60px; border-radius: 50%; object-fit: cover; flex-shrink: 0; background: #e5e7eb; }
.author-box-name { font-weight: 800; font-size: .95rem; color: #1a1a2e; margin-bottom: 4px; font-family: 'Montserrat', sans-serif; }
.author-box-bio { font-size: .84rem; color: #6b7280; line-height: 1.55; margin-bottom: 7px; }
.author-box-link { font-size: .8rem; font-weight: 700; color: #FF6314; font-family: 'Inter', sans-serif; text-decoration: none; }

/* =============================================================
   COMMENTS
   ============================================================= */
.comments-wrap { background: #fff; border-radius: 12px; box-shadow: 0 2px 12px rgba(0,0,0,.07); padding: 24px 28px; margin-top: 20px; border: 1px solid #e8eaed; }
.comments-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
.comments-title { font-size: 1rem; font-weight: 800; color: #1a1a2e; font-family: 'Montserrat', sans-serif; display: flex; align-items: center; gap: 9px; }
.comments-badge { background: #FF6314; color: #fff; width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 900; }
.comment-sort { display: flex; gap: 4px; }
.sort-btn { background: none; border: 1px solid #e5e7eb; border-radius: 20px; padding: 5px 12px; font-size: .76rem; font-family: 'Inter', sans-serif; font-weight: 600; cursor: pointer; color: #6b7280; transition: all .15s; }
.sort-btn.active, .sort-btn:hover { border-color: #FF6314; color: #FF6314; background: #fff3ee; }
.comment-item { display: flex; gap: 11px; padding: 13px 0; border-bottom: 1px solid #f9fafb; }
.comment-item:last-of-type { border-bottom: none; }
.comment-item.reply { margin-left: 48px; }
.ci-avatar { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; flex-shrink: 0; background: #e5e7eb; }
.ci-body { flex: 1; }
.ci-header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.ci-author { font-weight: 700; font-size: .84rem; color: #1a1a2e; font-family: 'Inter', sans-serif; text-decoration: none; }
.ci-author:hover { color: #FF6314; }
.ci-time { font-size: .73rem; color: #9ca3af; }
.ci-badge { font-size: .63rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; padding: 1px 7px; border-radius: 10px; background: #fff3ee; color: #FF6314; font-family: 'Inter', sans-serif; }
.ci-text { font-size: .875rem; line-height: 1.55; color: #374151; margin-bottom: 7px; }
.ci-actions { display: flex; align-items: center; gap: 5px; }
.ci-vote { background: none; border: 1px solid #e5e7eb; border-radius: 20px; padding: 3px 10px; font-size: .75rem; font-weight: 700; cursor: pointer; color: #6b7280; font-family: 'Inter', sans-serif; transition: all .15s; }
.ci-vote:hover { border-color: #FF6314; color: #FF6314; }
.ci-reply-btn { background: none; border: none; cursor: pointer; font-size: .75rem; color: #9ca3af; font-family: 'Inter', sans-serif; font-weight: 600; padding: 3px 7px; border-radius: 6px; transition: all .15s; }
.ci-reply-btn:hover { color: #FF6314; background: #fff3ee; }
.comment-form-section { margin-top: 22px; padding-top: 20px; border-top: 2px solid #f3f4f6; }
.cf-title { font-size: .95rem; font-weight: 800; color: #1a1a2e; margin-bottom: 14px; font-family: 'Montserrat', sans-serif; }

/* =============================================================
   PAGINATION
   ============================================================= */
.hp-pagination { display: flex; justify-content: center; gap: 5px; flex-wrap: wrap; padding: 22px 0 6px; }
.hp-pagination a, .hp-pagination span { padding: 7px 13px; border-radius: 7px; font-family: 'Inter', sans-serif; font-weight: 600; font-size: .84rem; border: 2px solid #e5e7eb; color: #374151; text-decoration: none; transition: all .15s; min-width: 38px; text-align: center; display: inline-flex; align-items: center; justify-content: center; }
.hp-pagination a:hover { border-color: #FF6314; color: #FF6314; background: #fff3ee; }
.hp-pagination .current { background: #FF6314; color: #fff; border-color: #FF6314; }

/* =============================================================
   BADGES
   ============================================================= */
.badge { display: inline-block; padding: 2px 10px; border-radius: 20px; font-size: .72rem; font-weight: 700; font-family: 'Inter', sans-serif; text-transform: uppercase; letter-spacing: .06em; line-height: 1.6; }
.badge-orange { background: #FF6314; color: #fff; }
.badge-dark { background: #1a1a2e; color: #fff; }
.badge-green { background: #dcfce7; color: #166534; }
.badge-gray { background: #f3f4f6; color: #6b7280; }

/* =============================================================
   404
   ============================================================= */
.page-404 { text-align: center; padding: 80px 20px; }
.p404-num { font-size: 7rem; font-weight: 900; color: #e5e7eb; font-family: 'Montserrat', sans-serif; line-height: 1; }
.p404-title { font-size: 1.7rem; font-weight: 800; margin-bottom: 10px; font-family: 'Montserrat', sans-serif; }
.p404-desc { color: #9ca3af; max-width: 400px; margin: 0 auto 24px; line-height: 1.6; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media(max-width: 1024px) {
  .content-sidebar-wrap { grid-template-columns: 1fr 290px; }
}
@media(max-width: 900px) {
  .content-sidebar-wrap { grid-template-columns: 1fr; }
  .sidebar { position: static; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
}
@media(max-width: 768px) {
  .site-main { padding: 18px 0 40px; }
  .single-header, .single-content, .single-vote, .post-tags-section, .share-section { padding-left: 16px; padding-right: 16px; }
  .comments-wrap { padding: 18px 16px; }
  .author-box { margin: 0 16px; flex-direction: column; }
  .sidebar { grid-template-columns: 1fr; }
}
@media(max-width: 540px) {
  .hero-stats { gap: 18px; }
  .hero-cta { flex-direction: column; align-items: center; }
  .hp-card-actions .hp-card-readmore { display: none; }
  .hp-card-title { font-size: 1.05rem; }
}

/* =============================================================
   FORCE OVERRIDES — ensure hp-card styles always win
   ============================================================= */
article.hp-card { display: block !important; }
.hp-card * { box-sizing: border-box; }
.hp-card-img { width: 100% !important; height: auto !important; display: block !important; max-height: none !important; object-fit: fill !important; }
.hp-card-footer { display: flex !important; flex-direction: row !important; align-items: center !important; flex-wrap: nowrap !important; }
.hp-vote-pill { display: inline-flex !important; flex-direction: row !important; align-items: center !important; }
.hp-vote-btn { display: inline-flex !important; flex-direction: row !important; align-items: center !important; }
.hp-card-actions { display: inline-flex !important; flex-direction: row !important; align-items: center !important; }
/* Hide any lingering old post-card elements */
.post-card-footer, .post-card-top, .post-card-title, .pc-footer, .pc-top, .pc-title,
.vote-group, .footer-actions { display: none !important; }
