/* ==========================================================================
   K.I.S.S. IELTS — Blog Articles Stylesheet
   Ported from EasyBlog custom.css → Joomla native article selectors
   See reference/easyblog/css-analysis.md for full mapping documentation
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Custom Properties (Design Tokens)
   -------------------------------------------------------------------------- */
:root {
  /* Brand Colors */
  --kiss-blue: #4ba3db;
  --kiss-purple: #9448EF;
  --kiss-pink: #fb02bd;
  --kiss-pink-alpha: #fb02bdab;
  --kiss-yellow: #F9F905;
  --kiss-red: #D41C1C;
  --kiss-body: #393939;
  --kiss-body-alt: #0a0a0ade;
  --kiss-quote-blue: #0f61f6;
  --kiss-jumbotron-bg: #9448EF4A;

  /* Typography */
  --kiss-font: "Microsoft YaHei", sans-serif;
  --kiss-body-size: 18px;
  --kiss-body-line-height: 30px;
  --kiss-h1-size: 38px;
  --kiss-h2-size: 30px;
  --kiss-h3-size: 28px;
  --kiss-title-size: 34px;
  --kiss-date-size: 12px;
}

/* --------------------------------------------------------------------------
   Article Container
   -------------------------------------------------------------------------- */
.com-content-article .item-page {
  font-family: var(--kiss-font);
  font-size: var(--kiss-body-size);
  line-height: var(--kiss-body-line-height);
  color: var(--kiss-body);
  font-weight: 400;
}

/* --------------------------------------------------------------------------
   Article Header
   -------------------------------------------------------------------------- */
.item-page .page-header {
  text-align: center;
  text-transform: uppercase;
  margin: 5px 0 0;
  padding: 0 0 15px;
}

.item-page .page-header h2 {
  font-family: var(--kiss-font);
  font-size: var(--kiss-title-size);
  color: var(--kiss-blue);
  margin: 10px 0;
}

/* --------------------------------------------------------------------------
   Article Meta (Date, Author)
   -------------------------------------------------------------------------- */
.item-page .article-info time {
  font-size: var(--kiss-date-size);
  text-align: center;
}

.item-page .article-info .createdby {
  text-transform: uppercase;
  width: auto;
  margin: 0 auto;
  display: inline;
}

.item-page .article-info .createdby img {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid #e5e5e5;
  padding: 2px;
}

/* --------------------------------------------------------------------------
   Article Body — Typography
   -------------------------------------------------------------------------- */
.item-page .item-content p {
  font-family: var(--kiss-font);
  font-size: inherit;
  line-height: var(--kiss-body-line-height);
  color: var(--kiss-body-alt);
  font-weight: 400;
  margin-bottom: 0.6em;
}

.item-page .item-content ol,
.item-page .item-content ul {
  font-family: var(--kiss-font);
  font-size: inherit;
  line-height: var(--kiss-body-line-height);
  color: var(--kiss-body-alt);
  font-weight: 400;
  margin-bottom: 1.6em;
}

/* --------------------------------------------------------------------------
   Headings
   -------------------------------------------------------------------------- */
.item-page .item-content h1 {
  font-size: var(--kiss-h1-size);
  color: var(--kiss-blue);
}

.item-page .item-content h2 {
  font-size: var(--kiss-h2-size);
  color: var(--kiss-blue);
}

.item-page .item-content h3 {
  font-size: var(--kiss-h3-size);
  color: var(--kiss-blue);
}

/* --------------------------------------------------------------------------
   Hyperlinks
   -------------------------------------------------------------------------- */
.item-page .item-content a {
  text-decoration: none;
  background-position: 0 1.2em;
  background-repeat: repeat-x;
  background-size: 100% 1px;
  color: var(--kiss-blue);
  font-weight: 600;
}

/* --------------------------------------------------------------------------
   Images
   -------------------------------------------------------------------------- */
.item-page .blog-image {
  text-align: center;
  margin: 1.5em 0;
}

.item-page .blog-image img {
  max-width: 100%;
  height: auto;
  border-radius: 2px;
}

.item-page .blog-image figcaption {
  font-weight: bolder;
  margin-top: 0.5em;
  font-size: 0.9em;
  color: var(--kiss-body);
}

/* --------------------------------------------------------------------------
   Cover Image
   -------------------------------------------------------------------------- */
@media screen and (min-width: 938px) {
  .item-page .blog-cover-image {
    width: 100%;
    height: 500px;
    object-fit: cover;
  }
}

/* --------------------------------------------------------------------------
   CTA Buttons
   -------------------------------------------------------------------------- */
.item-page .blog-cta {
  display: inline-block;
  background-color: var(--kiss-pink-alpha);
  font: normal bold 20px/30px var(--kiss-font);
  padding: 10px 20px;
  color: #fff;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.item-page .blog-cta:hover {
  background-color: var(--kiss-pink);
}

/* --------------------------------------------------------------------------
   Blockquotes
   -------------------------------------------------------------------------- */
.item-page blockquote {
  text-align: right;
  border-right: 5px solid var(--kiss-quote-blue);
  border-left: none;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--kiss-quote-blue);
  padding: 1em 1.5em;
  margin: 1.5em 0;
}

.item-page blockquote p {
  font-size: 18px;
  font-weight: 300;
  line-height: 1.6;
  color: var(--kiss-quote-blue);
}

/* --------------------------------------------------------------------------
   Jumbotron (Featured Content Sections)
   -------------------------------------------------------------------------- */
.item-page .blog-jumbotron {
  background-color: var(--kiss-jumbotron-bg);
  padding: 2em;
  text-align: center;
  border-radius: 8px;
  margin: 1.5em 0;
}

/* --------------------------------------------------------------------------
   Video Embeds (YouTube)
   -------------------------------------------------------------------------- */
.item-page .video-embed {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  height: 0;
  overflow: hidden;
  margin: 1.5em 0;
}

.item-page .video-embed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* --------------------------------------------------------------------------
   Tables
   -------------------------------------------------------------------------- */
.item-page .item-content table {
  width: 100%;
  table-layout: fixed;
  margin: 1em 0;
}

.item-page .item-content .table-responsive {
  overflow-x: inherit;
}

/* --------------------------------------------------------------------------
   Horizontal Rules (Blog Dividers)
   -------------------------------------------------------------------------- */
.item-page .blog-divider,
.item-page hr {
  border: none;
  border-top: 1px solid #e5e5e5;
  margin: 2em 0;
}

/* --------------------------------------------------------------------------
   Columns (CSS Grid)
   -------------------------------------------------------------------------- */
.item-page .blog-columns {
  display: grid;
  gap: 1.5em;
  margin: 1.5em 0;
}

.item-page .blog-columns[data-cols="2"] {
  grid-template-columns: 1fr 1fr;
}

.item-page .blog-columns[data-cols="3"] {
  grid-template-columns: 1fr 1fr 1fr;
}

@media (max-width: 767px) {
  .item-page .blog-columns {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------------------------
   Sections
   -------------------------------------------------------------------------- */
.item-page .blog-section {
  margin: 1.5em 0;
}

/* --------------------------------------------------------------------------
   Accordion (Details/Summary)
   -------------------------------------------------------------------------- */
.item-page details {
  margin: 0.5em 0;
  border: 1px solid #e5e5e5;
  border-radius: 4px;
  padding: 0.5em 1em;
}

.item-page details summary {
  cursor: pointer;
  font-weight: 600;
  padding: 0.5em 0;
}

.item-page details[open] summary {
  margin-bottom: 0.5em;
  border-bottom: 1px solid #e5e5e5;
}

/* --------------------------------------------------------------------------
   Custom Highlight Elements (ported from <m1> and <m2>)
   -------------------------------------------------------------------------- */

/* kiss-highlight-1: Large highlighted text (was <m1>) */
.item-page .kiss-highlight-1 {
  color: #1b1313;
  text-transform: inherit;
  font-size: 1.9em;
  line-height: 1.4;
  font-weight: bolder;
}

@media (min-width: 40em) {
  .item-page .kiss-highlight-1 {
    background: none;
  }
}

.item-page .kiss-highlight-1 span {
  margin-bottom: 0.5em;
  padding: 0.5em;
}

@media (min-width: 40em) {
  .item-page .kiss-highlight-1 span {
    display: inline-block;
    background: var(--kiss-yellow);
  }
}

/* kiss-highlight-2: Uppercase highlighted text (was <m2>) */
.item-page .kiss-highlight-2 {
  color: white;
  background: var(--kiss-yellow);
  text-transform: uppercase;
  font-size: 1.6em;
  line-height: 1.1;
  font-weight: 900;
}

@media (min-width: 40em) {
  .item-page .kiss-highlight-2 {
    background: none;
  }
}

.item-page .kiss-highlight-2 span {
  margin-bottom: 0.1em;
  padding: 0.1em;
  background: var(--kiss-red);
}

@media (min-width: 40em) {
  .item-page .kiss-highlight-2 span {
    display: inline-block;
    background: var(--kiss-red);
  }
}

/* --------------------------------------------------------------------------
   Drop Cap
   -------------------------------------------------------------------------- */
@media (min-width: 767px) {
  .item-page .blog-dropcap {
    font-family: var(--kiss-font);
    font-weight: 600;
    font-style: normal;
    font-size: 5.3em;
    color: #000000;
    float: left;
    line-height: 0.7em;
    margin: 0 0.05em 0.1em 0;
  }
}

.item-page .blog-dropcap-auto:first-letter {
  font-family: var(--kiss-font);
  font-weight: 600;
  font-style: normal;
  font-size: 5em;
  color: #000000;
  float: left;
  line-height: 0.9em;
  margin: 0 0.05em 0 0;
}

/* --------------------------------------------------------------------------
   Hide EasySocial widgets (Share, Reactions, Comments)
   -------------------------------------------------------------------------- */
.item-page > #es,
.item-page .es-sharer-btn,
.item-page .es-reactions-btn,
.item-page .es-comments-blk {
  display: none !important;
}

/* ==========================================================================
   Listing page card styles have been moved to custom.css
   to avoid CSS conflicts with T3 template.css global selectors
   (.image-wrap, .intro-wrap, .article-wrap, .items-row .item)
   See: theme/listing-cards.css (source) → custom.css (deployed)
   ========================================================================== */

/* ==========================================================================
   K.I.S.S. IELTS — Success Stories Listing Page Cards
   Appended to custom.css (loaded last, highest cascade priority)
   All selectors scoped under #t3-content div.blog for specificity
   ========================================================================== */

/* --------------------------------------------------------------------------
   Animations
   -------------------------------------------------------------------------- */
@keyframes kissCardIn {
  from { opacity: 0; transform: translateY(24px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes kissGradient {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* --------------------------------------------------------------------------
   Page container — soft gradient background
   -------------------------------------------------------------------------- */
#t3-content div.blog {
  background: linear-gradient(180deg, #f5f0ff 0%, #fafbff 50%, #f8f9fc 100%) !important;
  padding: 36px 0 20px !important;
}

/* --------------------------------------------------------------------------
   Page header — purple hero banner
   -------------------------------------------------------------------------- */
#t3-content div.blog > .page-header {
  text-align: center !important;
  margin: 0 0 36px !important;
  padding: 32px 20px 28px !important;
  background: linear-gradient(135deg, #9448EF 0%, #7b3fe4 40%, #4ba3db 100%) !important;
  background-size: 200% 200% !important;
  animation: kissGradient 8s ease infinite;
  border-radius: 18px !important;
  border: none !important;
  box-shadow: 0 8px 28px rgba(148, 72, 239, 0.22) !important;
  position: relative;
  overflow: hidden;
}

#t3-content div.blog > .page-header h2 {
  font-family: "Microsoft YaHei", sans-serif !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  color: #fff !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  margin: 0 !important;
  position: relative;
  z-index: 1;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
}

/* --------------------------------------------------------------------------
   GRID RESET — Override Bootstrap .row + .col-md-6 float layout
   -------------------------------------------------------------------------- */

/* Kill .row clearfix pseudo-elements (they break CSS Grid) */
#t3-content div.blog div.items-row.row::before,
#t3-content div.blog div.items-row.row::after {
  display: none !important;
  content: none !important;
}

/* Force CSS Grid on .items-row */
#t3-content div.blog div.items-row {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 24px !important;
  margin: 0 0 24px 0 !important;
  padding: 0 !important;
  float: none !important;
}

/* Kill Bootstrap .col-md-6 float and fixed width */
#t3-content div.blog div.items-row > div {
  float: none !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  min-height: 0 !important;
  animation: kissCardIn 0.5s ease both;
}

/* Stagger entrance animation per card */
#t3-content div.blog div.items-row > div:nth-child(1) { animation-delay: 0.05s; }
#t3-content div.blog div.items-row > div:nth-child(2) { animation-delay: 0.12s; }

/* KEY FIX: .item must fill its grid cell (was 367px in 598px cell) */
#t3-content div.blog div.items-row div.item {
  width: 100% !important;
  border: none !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  border-radius: 0 !important;
  min-height: 0 !important;
}

/* .system-unpublished wrapper — kill its styling */
#t3-content div.blog .system-unpublished {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  width: 100% !important;
}

/* --------------------------------------------------------------------------
   Card container — clean white card with rounded corners
   -------------------------------------------------------------------------- */
#t3-content div.blog article.article-wrap {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: auto !important;
  background: #fff !important;
  border-radius: 16px !important;
  border: 1px solid rgba(0, 0, 0, 0.06) !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05), 0 1px 3px rgba(0, 0, 0, 0.03) !important;
  overflow: hidden !important;
  transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease !important;
  position: relative !important;
}

#t3-content div.blog article.article-wrap:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 36px rgba(148, 72, 239, 0.13), 0 4px 10px rgba(0, 0, 0, 0.05) !important;
  border-color: rgba(148, 72, 239, 0.12) !important;
}

/* Gradient accent bar — visible on hover */
#t3-content div.blog article.article-wrap::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  width: auto !important;
  background: linear-gradient(90deg, #9448EF, #fb02bd, #4ba3db) !important;
  opacity: 0;
  transition: opacity 0.35s ease;
  z-index: 3;
  display: block !important;
  clear: none !important;
}

#t3-content div.blog article.article-wrap:hover::before {
  opacity: 1;
}

/* .article-inner flex column */
#t3-content div.blog .article-inner {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

/* --------------------------------------------------------------------------
   Featured Image — fixed aspect ratio for uniform card sizing
   -------------------------------------------------------------------------- */

/* Kill T3 .image-wrap clearfix and margin */
#t3-content div.blog div.image-wrap::before {
  display: none !important;
}

#t3-content div.blog div.image-wrap {
  position: relative !important;
  overflow: hidden !important;
  margin: 0 !important;
  background: linear-gradient(135deg, #ede5ff 0%, #e8f0ff 100%) !important;
  aspect-ratio: 16 / 10 !important;
  border-radius: 0 !important;
  border-bottom: none !important;
}

/* Gradient overlay on image for depth */
#t3-content div.blog div.image-wrap::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, transparent 60%, rgba(0, 0, 0, 0.06) 100%) !important;
  pointer-events: none !important;
  z-index: 1;
  display: block !important;
  clear: none !important;
  width: auto !important;
  height: auto !important;
}

/* Image — fill the aspect-ratio box */
#t3-content div.blog div.image-wrap .pull-left.item-image {
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  height: 100% !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
}

#t3-content div.blog div.image-wrap .pull-left.item-image a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  line-height: 0 !important;
}

#t3-content div.blog div.image-wrap .pull-left.item-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
  transition: transform 0.45s ease;
}

#t3-content div.blog article.article-wrap:hover div.image-wrap img {
  transform: scale(1.05);
}

/* Category badge — override T3 green/bottom with purple/top */
#t3-content div.blog div.image-wrap .category-name {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  bottom: auto !important;
  background: rgba(148, 72, 239, 0.9) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  box-shadow: 0 2px 8px rgba(148, 72, 239, 0.3) !important;
  z-index: 2 !important;
  line-height: 1.5 !important;
  height: auto !important;
  display: inline-block !important;
}

#t3-content div.blog div.image-wrap .category-name a,
#t3-content div.blog div.image-wrap .category-name a span {
  color: #fff !important;
  text-decoration: none !important;
  padding: 0 !important;
  height: auto !important;
  line-height: inherit !important;
  font-size: inherit !important;
}

/* --------------------------------------------------------------------------
   Card body — title + intro text
   -------------------------------------------------------------------------- */

/* Override T3 .intro-wrap padding: 36px */
#t3-content div.blog div.intro-wrap {
  padding: 18px 20px 0 !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Title */
#t3-content div.blog .article-header {
  margin-bottom: 6px !important;
}

#t3-content div.blog .article-header .article-title {
  font-family: "Microsoft YaHei", sans-serif !important;
  font-size: 15.5px !important;
  font-weight: 700 !important;
  line-height: 1.5 !important;
  margin: 0 0 6px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden !important;
}

#t3-content div.blog .article-header .article-title a {
  color: #1a1a2e !important;
  text-decoration: none !important;
  transition: color 0.25s ease;
}

#t3-content div.blog .article-header .article-title a:hover {
  color: #9448EF !important;
}

/* h2 fallback */
#t3-content div.blog div.intro-wrap h2 {
  font-family: "Microsoft YaHei", sans-serif !important;
  font-size: 15.5px !important;
  font-weight: 700 !important;
  line-height: 1.5 !important;
  margin: 0 0 6px !important;
}

#t3-content div.blog div.intro-wrap h2 a {
  color: #1a1a2e !important;
  text-decoration: none !important;
}

#t3-content div.blog div.intro-wrap h2 a:hover {
  color: #9448EF !important;
}

/* --------------------------------------------------------------------------
   Intro content — clip to 3 lines, hide all complex blocks
   -------------------------------------------------------------------------- */
#t3-content div.blog .article-intro {
  font-family: "Microsoft YaHei", sans-serif !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  color: #666 !important;
  max-height: 66px !important;
  overflow: hidden !important;
  position: relative !important;
  margin: 0 !important;
  flex: 1;
}

/* Fade-out gradient */
#t3-content div.blog .article-intro::after {
  content: "" !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 26px !important;
  background: linear-gradient(transparent, #fff) !important;
  pointer-events: none !important;
}

/* Normalize all inner text */
#t3-content div.blog .article-intro p,
#t3-content div.blog .article-intro span,
#t3-content div.blog .article-intro div,
#t3-content div.blog .article-intro td,
#t3-content div.blog .article-intro th,
#t3-content div.blog .article-intro li {
  font-size: 13px !important;
  line-height: 1.7 !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #666 !important;
  font-weight: 400 !important;
}

/* Hide all complex/rich blocks in card preview */
#t3-content div.blog .article-intro table,
#t3-content div.blog .article-intro .blog-columns,
#t3-content div.blog .article-intro .blog-section,
#t3-content div.blog .article-intro .blog-jumbotron,
#t3-content div.blog .article-intro .video-embed,
#t3-content div.blog .article-intro .blog-image,
#t3-content div.blog .article-intro .blog-cta,
#t3-content div.blog .article-intro figure,
#t3-content div.blog .article-intro img,
#t3-content div.blog .article-intro iframe,
#t3-content div.blog .article-intro hr,
#t3-content div.blog .article-intro .blog-divider,
#t3-content div.blog .article-intro details,
#t3-content div.blog .article-intro ul,
#t3-content div.blog .article-intro ol,
#t3-content div.blog .article-intro .kiss-highlight-1,
#t3-content div.blog .article-intro .kiss-highlight-2 {
  display: none !important;
}

/* --------------------------------------------------------------------------
   Read More button — pink pill
   -------------------------------------------------------------------------- */
#t3-content div.blog section.readmore {
  padding: 14px 20px 18px !important;
  margin-top: auto !important;
}

#t3-content div.blog section.readmore a.link-readmore {
  display: inline-block !important;
  background: linear-gradient(135deg, #fb02bd 0%, #d946a8 100%) !important;
  color: #fff !important;
  font-family: "Microsoft YaHei", sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 8px 20px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  letter-spacing: 0.3px !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 3px 10px rgba(251, 2, 189, 0.2) !important;
}

#t3-content div.blog section.readmore a.link-readmore:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(251, 2, 189, 0.3) !important;
}

/* Replace Chinese readmore text with short label */
#t3-content div.blog section.readmore a.link-readmore span {
  display: none !important;
}

#t3-content div.blog section.readmore a.link-readmore::after {
  content: "Continue reading \2192" !important;
}

/* --------------------------------------------------------------------------
   Card footer — date
   -------------------------------------------------------------------------- */

/* Override T3 .article-wrap .article-footer { padding: 24px 36px; border-top: 1px solid #d8e1e4 } */
#t3-content div.blog article.article-wrap .article-footer {
  border-top: 1px solid rgba(0, 0, 0, 0.05) !important;
  padding: 10px 20px 14px !important;
  margin: 0 !important;
}

#t3-content div.blog .article-footer .article-info {
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
}

#t3-content div.blog .article-footer time {
  font-size: 12px !important;
  color: #b0b0b0 !important;
  font-weight: 400 !important;
}

#t3-content div.blog .article-footer .article-info-term {
  display: none !important;
}

/* --------------------------------------------------------------------------
   Pagination
   -------------------------------------------------------------------------- */
#t3-content div.blog .pagination li.active span {
  background: #9448EF !important;
  border-color: #9448EF !important;
  color: #fff !important;
}

/* --------------------------------------------------------------------------
   Lone last card — same width as paired cards (span 1 column, not full width)
   -------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
   Responsive — tablet (768–991px)
   -------------------------------------------------------------------------- */
@media (max-width: 991px) and (min-width: 768px) {
  #t3-content div.blog div.items-row {
    gap: 18px !important;
  }

  #t3-content div.blog div.intro-wrap {
    padding: 14px 16px 0 !important;
  }

  #t3-content div.blog .article-header .article-title,
  #t3-content div.blog div.intro-wrap h2 {
    font-size: 14px !important;
  }

  #t3-content div.blog section.readmore {
    padding: 12px 16px 14px !important;
  }

  #t3-content div.blog article.article-wrap .article-footer {
    padding: 8px 16px 12px !important;
  }
}

/* --------------------------------------------------------------------------
   Responsive — mobile (≤767px) single column
   -------------------------------------------------------------------------- */
@media (max-width: 767px) {
  #t3-content div.blog {
    padding: 16px 0 10px !important;
  }

  #t3-content div.blog > .page-header {
    margin: 0 10px 20px !important;
    padding: 22px 16px !important;
    border-radius: 14px !important;
  }

  #t3-content div.blog > .page-header h2 {
    font-size: 20px !important;
    letter-spacing: 1px !important;
  }

  #t3-content div.blog div.items-row {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    padding: 0 10px !important;
  }

  #t3-content div.blog div.image-wrap {
    aspect-ratio: 16 / 9 !important;
  }

  #t3-content div.blog .article-header .article-title,
  #t3-content div.blog div.intro-wrap h2 {
    font-size: 15px !important;
  }

  #t3-content div.blog div.intro-wrap {
    padding: 16px 16px 0 !important;
  }

  #t3-content div.blog section.readmore {
    padding: 12px 16px 16px !important;
  }

  #t3-content div.blog article.article-wrap .article-footer {
    padding: 8px 16px 12px !important;
  }

  /* Disable hover effects on touch */
  #t3-content div.blog article.article-wrap:hover {
    transform: none !important;
  }
}

/* --------------------------------------------------------------------------
   Responsive — small mobile (≤400px)
   -------------------------------------------------------------------------- */
@media (max-width: 400px) {
  #t3-content div.blog div.items-row {
    padding: 0 6px !important;
    gap: 14px !important;
  }

  #t3-content div.blog .article-header .article-title,
  #t3-content div.blog div.intro-wrap h2 {
    font-size: 14.5px !important;
  }

  #t3-content div.blog .article-intro {
    font-size: 12.5px !important;
  }
}
