/* ==========================================
   SINGLE POST TEMPLATE STYLES
   ========================================== */

/* Breadcrumbs */
.breadcrumbs {
  margin-bottom: 36px !important;
  font-family: 'poppins', -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  font-size: 13px;
  list-style: none;
  padding: 0;
}

.breadcrumbs li {
  display: inline-block;
  vertical-align: middle;
}

.breadcrumbs li:after {
  display: inline-block;
  vertical-align: middle;
  margin: 0 7px;
  content: " \203A ";
  font-family: Arial, sans-serif;
  margin-top: -3px;
}

.breadcrumbs li:last-child:after {
  display: none;
}

.breadcrumbs a {
  color: #373737;
  text-decoration: none;
}

.breadcrumbs a:hover {
  color: #17b;
  text-decoration: underline;
}

.breadcrumbs a:focus {
  text-decoration: none;
  color: inherit;
  outline: none;
}

.bread-home {
  width: 13px;
  height: auto;
  display: inline-block;
  margin-top: -3px;
  margin-right: 9px;
  opacity: 0.8;
}

/* Card AI - Main Container */
.card-ai {
  border: 0 solid #e5e5e5;
  background: #fff;
  height: auto;
  display: flex;
  margin: 0 14px;
  position: relative;
  border-radius: 24px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05), 0 1px 4px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

.card-ai::before,
.card-ai::after {
  content: '';
  position: absolute;
  z-index: 0;
  width: 300px;
  height: 300px;
  background: #b3b6ba57;
  border-radius: 50%;
  bottom: -220px;
}

.card-ai::before {
  left: -150px;
}

.card-ai::after {
  right: -150px;
}

.upp {
  margin: 8px 21px 25px 45px;
  padding-top: 40px;
  z-index: 1;
}

.col-md-6 {
  margin: 33px 0 17px;
  margin-top: 54px;
}

/* Left Column */
.center-title-mob {
  display: none;
}

.post-title-mob {
  text-align: center;
  font-size: 26px;
  margin-bottom: 10px;
  color: #333;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  border-image: linear-gradient(89deg, #a0dbfd 1%, #947bed 26%, #fb81b5 51%, #ffbd75 98%) 1;
  border-bottom: 2px solid #bacb2d !important;
}

.post-thumb {
  margin-top: 22px;
  margin-bottom: 10px;
  border-radius: 0;
  padding: 0;
  border: none;
  background: #fff0;
}

.post-thumb a {
  display: block;
}

.post-thumb img {
  display: block;
  width: auto;
  border: 4px solid #b4bdc380;
  padding: 5px;
  box-shadow: 1px 4px 5px 0 #aad1ff;
  background: #fff0;
  margin: 0 auto;
  border-radius: 22px;
}

.post-thumb a:hover img {
  opacity: 0.8;
}

.entry-categories {
  padding-top: 18px;
  text-align: center;
  font-size: 15px;
}

.link-cat-single {
  display: inline-flex !important;
  background: #fff;
  padding: 2px 15px;
  margin-right: 10px;
  border-radius: 0.25rem;
  flex-wrap: wrap;
  margin-bottom: 10px;
  color: #687483;
  text-transform: uppercase;
  border: 1px solid #cfcfcf;
  font-size: 12px;
}

.link-cat-single:hover {
  text-decoration: none;
  background: #f3f1f163;
  color: #17b;
}

.hashtaga {
  font-weight: 700;
  margin-right: 2px;
}

/* Right Column */
#pad-droi {
  text-align: center;
  margin-top: 39px;
  position: inherit;
  margin: 53px 0 23px;
  padding-left: 80px;
}

.post-summary {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  height: auto;
  flex-direction: column;
}

.longo-title {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.site-icon-singly {
  vertical-align: bottom;
  margin-right: 4px;
  background-size: 16px 16px;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 4px;
}

.post-title-ticle {
  font-size: 26px;
  margin-bottom: 10px;
  font-weight: 700;
  text-decoration: none;
  text-decoration-color: #bacb2d;
  text-decoration-style: double;
  color: #3f4a4f;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 308px;
  border-image: linear-gradient(89deg, #a0dbfd 1%, #947bed 26%, #fb81b5 51%, #ffbd75 98%) 1;
  border-bottom: 2px solid #bacb2d !important;
}

.ranking-single {
  position: absolute;
  top: 19px;
  left: 22px;
}

.number-rk {
  background: #fff;
  border: 1px solid #fff0;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  border-bottom: 5px solid #b1b1b1;
  font-size: 15px;
  padding-left: 11px;
  padding-right: 11px;
  z-index: 993;
  font-weight: 700;
  color: #2e2e2e;
  border-radius: 15px;
  padding-top: 7px;
  padding-bottom: 5px;
}

.link-rank-cat {
  text-decoration: underline;
}

/* Meta Section */
.post-meta {
  font-size: 14px;
  color: #797474;
  margin-bottom: 20px;
  margin-top: 10px;
}

.contor-descr {
  margin: 0;
  padding: 1.5rem;
  background: #fff;
  border-radius: 12px;
  font-size: 1.1rem;
  line-height: 1.6;
  color: #2d3436;
  border-left: 4px solid #6caaea;
  font-size: 15.5px;
  background: #f8fafc;
  margin-top: 20px;
}

.global-description {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  align-content: center;
  flex-direction: row;
}

.desc-text {
  border-bottom: 1px solid #efefef;
  margin-bottom: 12px;
  line-height: 2;
  padding: 6px;
  width: 100%;
  padding-bottom: 25px;
}

.like-button {
  opacity: 0.8;
  color: #2a4a59;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  border: 1px solid #fff0;
  background: #fff0;
  display: inline-flex;
  align-items: center;
  position: initial;
  padding-left: 0;
  top: 5px;
  right: 437px;
}

.like-button:hover {
  opacity: 1;
  filter: invert(0) hue-rotate(292deg) drop-shadow(0 0 10px #03A9F4);
}

.flsing4 {
  width: 15px !important;
  height: auto !important;
}

.numbers-upvote {
  margin-left: 5px;
  font-size: 14px;
  font-weight: 700;
  color: #021e43;
}

/* Pricing Badge */
.website-type-Free-descr,
.website-type-Freemium-descr,
.website-type-Paid-descr,
.website-type-Premium-descr {
  text-decoration: none;
  transition: 0.3s ease all;
  z-index: 1;
  height: auto;
  flex-wrap: nowrap;
  align-content: flex-end;
  top: 13px;
  left: 50%;
  right: 50%;
  margin-right: -29px;
  color: #1a1a19;
  font-size: 13px;
  margin-top: -4px;
  padding: 0.1em 2em;
  letter-spacing: 2px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.licone-color-Free {
  background: #10b981;
  width: 13px;
  height: 6px;
  margin-right: 5px;
  display: inline-flex;
  border-radius: 99px;
}

.licone-color-Freemium {
  background: #d18e2a;
  width: 13px;
  height: 6px;
  margin-right: 5px;
  display: inline-flex;
  border-radius: 99px;
}

.licone-color-Paid {
  background: #ef4444;
  width: 13px;
  height: 6px;
  margin-right: 5px;
  display: inline-flex;
  border-radius: 99px;
}

.licone-color-Premium {
  background: #8b5cf6;
  width: 13px;
  height: 6px;
  margin-right: 5px;
  display: inline-flex;
  border-radius: 99px;
}

/* Rating */
.rating {
  opacity: 0.7;
}

/* Rating Inline - 50% smaller */
.rating-inline {
  transform: scale(0.5) !important;
  transform-origin: left center !important;
  margin-right: -40px;
}

.rating-inline .kksr-legend {
  display: none !important;
}

.rating-inline .kksr-icon,
.rating-inline .kksr-star .kksr-icon,
.rating-inline .kk-star-ratings .kksr-icon {
  width: 12px !important;
  height: 12px !important;
}

.rating-inline .kksr-star,
.rating-inline .kk-star-ratings .kksr-star {
  padding-right: 2px !important;
}

.rating-inline .kk-star-ratings {
  transform: scale(0.5) !important;
  transform-origin: left center !important;
}

/* Header Right Group - Flex layout */
.header-right-group {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

/* Favorite Button Inline */
.sharebutton-inline {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  margin-left: auto;
}

.sharebutton-inline .image-sharelist1 {
  width: 24px;
  height: 24px;
  opacity: 0.4;
  transition: opacity 0.2s;
}

.sharebutton-inline .image-sharelist1:hover {
  opacity: 0.8;
}

/* Card Header Top */
.card-header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  position: relative;
}

#rating-single {
  display: flex;
  justify-content: center;
  align-items: center;
  position: initial;
  margin: 0 0 10px 0;
  top: 5px;
  right: 642px;
}

/* Favorite Button */
.mob320 {
  background: #fff0;
  border: none;
  cursor: pointer;
}

.image-sharelist1 {
  width: 43px;
  margin-right: 6px;
  filter: brightness(3) invert(1) hue-rotate(203deg);
  opacity: 0.15;
}

.image-sharelist1:hover {
  opacity: 0.5;
  filter: brightness(1) invert(1) hue-rotate(330deg);
}

.altshr {
  width: 24px;
  filter: brightness(3) invert(1) hue-rotate(203deg);
  opacity: 0.5;
}

.altshr:hover {
  filter: brightness(3) invert(1) hue-rotate(203deg);
  opacity: 0.65;
}

/* Demo Git Plus (spacing element) */
.demo-git-plus {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  margin: 4px;
  border: none;
  border-radius: 4px;
  color: #2f2d2d;
  text-decoration: none;
  transition: background-color 0.3s ease;
  flex-direction: row;
  justify-content: center;
}

/* Visit Button */
.visit-divy {
  display: inline-flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0 13px;
}

.button-plus2 {
  letter-spacing: 2px;
  text-transform: uppercase;
  display: block;
  text-align: center;
  font-weight: 700;
  padding: 0.7em 2em;
  border-radius: 2px;
  position: relative;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.1);
  color: #fff;
  text-decoration: none;
  transition: 0.3s ease all;
  z-index: 1;
  height: auto;
  background: #337ab7;
  margin-top: 0;
  margin-left: auto;
  margin-right: auto;
  border-radius: 5px;
  font-size: 13px;
  background: linear-gradient(135deg, #1979c4, #6a9ed2);
  border: none;
  cursor: pointer;
}

.button-plus2:before {
  transition: 0.5s all ease;
  position: absolute;
  top: 0;
  left: 50%;
  right: 50%;
  bottom: 0;
  opacity: 0;
  content: '';
  background-color: #3989cd;
  z-index: -1;
}

.button-plus2:hover,
.button-plus2:focus {
  color: #fff;
  text-decoration: none;
}

.button-plus2:hover:before,
.button-plus2:focus:before {
  transition: 0.5s all ease;
  left: 0;
  right: 0;
  opacity: 1;
}

.icon-linkwi {
  width: 16px;
  height: 16px;
  margin-right: 5px;
  filter: invert(1) hue-rotate(180deg);
}

/* Random Dice */
.dicedice {
  bottom: 10px;
  opacity: 0.6;
  position: absolute;
  right: 10px;
  transition: transform 0.1s;
}

.dicedice:active {
  animation: shake 0.5s;
  animation-iteration-count: 1;
}

.dicedice:hover {
  opacity: 0.9;
}

@keyframes shake {
  10%, 90% {
    transform: translate3d(-1px, 0, 0);
  }
  20%, 80% {
    transform: translate3d(2px, 0, 0);
  }
  30%, 50%, 70% {
    transform: translate3d(-4px, 0, 0);
  }
  40%, 60% {
    transform: translate3d(4px, 0, 0);
  }
}

/* Date/Badge Area */
.date-ai {
  bottom: 10px;
  opacity: 0.8;
  position: absolute;
  left: 20px;
  color: #464a4d;
}

/* Social Share PC */
.social-share-article-pc {
  display: flex;
  list-style: none;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 10px;
  right: 29px;
}

.share-modal-contents {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-left: 1rem;
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
}

.no-underline-link:hover {
  text-decoration: none;
}

.image-light {
  opacity: 1;
  width: 16px;
  height: 16px;
  margin-right: 5px;
}

.image-light:hover {
  opacity: 0.9;
  filter: none;
}

.vue-ai {
  z-index: 1;
  padding-left: 0.75rem;
  margin-left: 0.5rem;
  border-left: 1px solid #e2e8f0;
  color: #64748b;
  font-size: 0.8rem;
}

.arrow-trendy {
  width: 18px;
  height: auto;
  display: inline-block;
  margin-right: 5px;
  margin-top: -2px;
  display: inline-flex !important;
  margin-right: 10px;
  opacity: 0.6;
}

/* Responsive Styles */
@media only screen and (max-width: 1280px) {
  .col-md-6 {
    margin-top: 103px;
  }
}

@media only screen and (max-width: 1200px) {
  .share-modal-contents {
    display: block;
  }
  .like-button {
    right: 299px;
  }
  #rating-single {
    right: 500px;
  }
  .post-thumb {
    margin-top: 25px;
  }
  .vue-ai {
    margin-top: 25px !important;
    top: 206px !important;
  }
  .social-share-article-pc {
    position: initial;
    margin-top: 23px;
  }
}

@media only screen and (max-width: 991px) {
  .like-button {
    right: 191px;
  }
  #rating-single {
    right: 387px;
  }
  .demo-git-plus {
    left: -171px;
  }
  .post-thumb-con {
    margin-top: 71px;
  }
  .dicedice {
    bottom: 15px;
    opacity: 0.6;
    position: absolute;
    left: 13px;
  }
  .social-share-article-pc {
    display: none !important;
  }
  .upp {
    margin: -16px 0 13px !important;
  }
  .vue-ai {
    top: 152px !important;
  }
  .ranking-single {
    top: 85px;
    left: 67px;
  }
  .post-summary {
    flex-direction: row;
  }
  .post-title-ticle {
    margin-bottom: 0;
    padding-left: 5px;
  }
  .longo-title {
    display: flex;
    flex-direction: row;
    align-items: center;
  }
  .website-type-Free-descr,
  .website-type-Freemium-descr,
  .website-type-Paid-descr,
  .website-type-Premium-descr {
    position: absolute;
    width: max-content;
  }
  .col-md-6 {
    margin-top: 94px;
  }
  .upp {
    margin: -16px 16px 13px !important;
    padding-top: 0;
  }
  #pad-droi {
    padding-left: 10px;
    margin: 106px 0 23px;
  }
}

@media only screen and (max-width: 767px) {
  .website-type-Free-descr,
  .website-type-Freemium-descr,
  .website-type-Paid-descr,
  .website-type-Premium-descr {
    position: initial;
    width: auto;
    transform: unset;
    margin-bottom: 0;
    margin-left: 0;
  }
  .post-meta {
    margin-bottom: 47px;
  }
  .col-md-6 {
    margin-top: 24px;
  }
  .site-icon-singly {
    display: none;
  }
  .center-title-mob {
    display: flex;
    justify-content: center;
  }
  .like-button {
    left: 17px;
    top: 12px;
  }
  #rating-single {
    position: inherit;
  }
  .demo-git-plus {
    display: none;
  }
  .card-ai {
    margin: 0 14px !important;
  }
  .post-thumb-con {
    margin-top: 0 !important;
  }
  #pad-droi {
    margin: 39px 6px 24px 17px !important;
    padding-left: 0 !important;
  }
  .vue-ai {
    display: none;
  }
  .dicedice {
    display: none;
  }
  .post-summary {
    margin-top: -20px;
  }
  .post-title-mob {
    display: block !important;
    margin-top: 32px;
    max-width: 299px;
    white-space: wrap;
    line-height: 1.5;
    padding: 20px;
    position: relative;
  }
  .post-title-ticle {
    display: none;
  }
  .post-summary {
    width: auto;
  }
  .ranking-single {
    position: initial;
    margin-bottom: 16px;
    display: flex;
    flex-direction: column;
  }
}

@media (max-width: 500px) {
  .website-type-Free-descr,
  .website-type-Freemium-descr,
  .website-type-Paid-descr,
  .website-type-Premium-descr {
    position: absolute;
    width: max-content;
  }
}

@media only screen and (max-width: 365px) {
  .button-plus2 {
    width: 100%;
    white-space: normal;
  }
  .global-description {
    justify-content: space-around;
  }
  .contor-descr {
    border: none;
    box-shadow: none;
    border-top: 1px solid #e5e5e5;
    border-radius: 0;
  }
}

@media (max-width: 320px) {
  .mob320 {
    display: none;
  }
}

/* Social Share Mobile */
.social-share-article {
  display: none;
  list-style: none;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 20px 0 10px 0;
}

.social-share-article b {
  font-weight: 700;
  margin-right: 10px;
}

.social-share-article li {
  display: inline-block;
}

.arrow-mob {
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #4a4a4a;
  margin: 0 auto;
}

@media only screen and (max-width: 991px) {
  .social-share-article {
    display: flex;
  }
}

/* Content Area */
.post-ct {
  margin-top: 40px;
  padding: 0 20px;
}

.entry-content {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

.entry-content p {
  margin-bottom: 20px;
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
  margin-top: 30px;
  margin-bottom: 15px;
  font-weight: 700;
  color: #2c3e50;
}

.entry-content ul,
.entry-content ol {
  margin-bottom: 20px;
  padding-left: 30px;
}

.entry-content li {
  margin-bottom: 10px;
}

.entry-content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: 20px 0;
}

.entry-content a {
  color: #337ab7;
  text-decoration: underline;
}

.entry-content a:hover {
  color: #23527c;
}

/* ==========================================
   GRID SHORTCODE STYLES
   ========================================== */

/* AI Tools Grid Styles */
.xc-ai-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 36px 25px;
  width: 100%;
  padding-top: 44px;
}

.xc-ai-grid[data-columns="3"] {
  grid-template-columns: repeat(3, 1fr);
}

.xc-ai-grid[data-columns="2"] {
  grid-template-columns: repeat(2, 1fr);
}

.xc-ai-grid[data-columns="1"] {
  grid-template-columns: repeat(1, 1fr);
}

/* Card Item */
.xc-ai-card {
  border: 1px solid #e6e6e6;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  background: #fff;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.xc-ai-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 2px 10px rgba(251, 101, 212, 0.43);
}

/* First Featured Card */
.xc-ai-card.xc-ai-featured {
  border: 0;
  box-shadow: 0 6px 12px rgba(255, 215, 0, 0.3), 0 2px 8px rgba(0, 0, 0, 0.05);
  border-radius: 15px;
}

.xc-ai-card.xc-ai-featured:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 18px rgba(255, 215, 0, 0.4), 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Ribbon - Best/Featured */
.xc-ai-ribbon {
  position: absolute;
  top: -4px;
  right: -41px;
  width: 119px;
  height: 36px;
  background: linear-gradient(135deg, #ffc368 25%, #FF9800 25%);
  background-size: 3px 32px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  line-height: 30px;
  text-transform: uppercase;
  transform: rotate(45deg);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  z-index: 15;
  padding-top: 5px;
}

.xc-ai-ribbon::before {
  content: "TOP";
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3);
}

/* Ribbon - Default */
.ribbon-best8 {
  position: absolute;
  top: -4px;
  right: -58px;
  width: 119px;
  height: 36px;
  background: linear-gradient(135deg, #ebebeb, #ffffff);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  line-height: 30px;
  text-transform: uppercase;
  transform: rotate(45deg);
  z-index: 15;
  padding-top: 5px;
}

.ribbon-best8::before {
  content: "";
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3);
}

/* Card Content */
.xc-ai-content {
  padding: 20px;
  position: relative;
}

/* Featured Badge */
.xc-ai-badge {
  position: absolute;
  padding: 1px 9px 2px 5px;
  color: #000;
  right: 0;
  top: 0;
  font-size: 11px;
  left: 0;
  background: #fff5f9;
  display: flex;
  align-items: center;
  gap: 2px;
}

.xc-ai-star {
  animation: xc-ai-spin 13s linear infinite;
  display: inline-block;
  font-size: 21px;
  background: linear-gradient(89deg, #a0dbfd 1%, #947bed 15%, #fb81b5 35%, #ffbd75 60%, #ffbd75 98%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}

.xc-ai-badge-text {
  font-size: 11px;
  font-weight: 700;
  color: #FF4081;
  background: linear-gradient(108deg, #0a8bee, #b54ac8 34%, #e52c4e 68%, #ec901c);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}

/* Title Section */
.xc-ai-header {
  display: flex;
  align-items: center;
  margin-top: 18px;
  gap: 7px;
}

.xc-ai-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
  background: #f0f0f0;
}

.xc-ai-title {
  font-size: 15px;
  color: #3f4a4f;
  padding: 10px 0 5px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  position: relative;
  text-decoration: none;
  flex: 1;
  overflow: hidden;
}

.xc-ai-title:hover {
  color: #000;
}

.xc-ai-title::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: linear-gradient(89deg, #a0dbfd 1%, #947bed 26%, #fb81b5 51%, #ffbd75 98%);
}

.xc-ai-verified {
  width: 16px;
  height: 16px;
  vertical-align: middle;
  margin-left: 4px;
}

/* Description */
.xc-ai-description {
  font-size: 12.5px;
  color: #333;
  margin-top: 20px;
  text-align: center;
  overflow: hidden;
  letter-spacing: 0.3px;
  line-height: 1.6;
  height: 84px;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.xc-ai-highlight {
  background-color: #fee2e2;
  color: #ef4444;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 6px;
  text-transform: uppercase;
}

/* Visit Button */
.xc-ai-button {
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  display: block;
  text-align: center;
  font-weight: 700;
  padding: 0.7em 2em;
  border-radius: 5px;
  position: relative;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.1);
  color: #fff;
  text-decoration: none;
  transition: 0.3s ease all;
  z-index: 1;
  background: #337ab7;
  margin: 20px auto 0;
  width: fit-content;
  border: none;
  cursor: pointer;
}

.xc-ai-button:before {
  transition: 0.5s all ease;
  position: absolute;
  top: 0;
  left: 50%;
  right: 50%;
  bottom: 0;
  opacity: 0;
  content: '';
  background-color: rgba(84, 143, 193, 0.56);
  z-index: -1;
  border-radius: 5px;
}

.xc-ai-button:hover,
.xc-ai-button:focus {
  color: #fff;
  text-decoration: none;
}

.xc-ai-button:hover:before,
.xc-ai-button:focus:before {
  transition: 0.5s all ease;
  left: 0;
  right: 0;
  opacity: 1;
}

.xc-ai-button-icon {
  width: 16px;
  height: 16px;
  margin-right: 5px;
  vertical-align: middle;
}

/* Responsive */
@media only screen and (max-width: 1200px) {
  .xc-ai-grid,
  .xc-ai-grid[data-columns="4"],
  .xc-ai-grid[data-columns="3"] {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media only screen and (max-width: 767px) {
  .xc-ai-grid,
  .xc-ai-grid[data-columns="4"],
  .xc-ai-grid[data-columns="3"],
  .xc-ai-grid[data-columns="2"] {
    grid-template-columns: repeat(1, 1fr);
    padding: 33px 17px;
  }

  .xc-ai-description {
    font-size: 13.5px;
  }
}

/* Animations */
@keyframes xc-ai-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* ========================================
   AI Tools List (Vertical) - Match Site
   ======================================== */

.blog-list {
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  padding: 16px;
  display: flex;
  flex-direction: column;
  height: 100%;
  margin-bottom: 20px;
}

.blog-list .title-list {
  display: inline-flex;
  align-items: center;
  font-size: 15px;
  font-weight: 700;
  color: #2c3e50;
  padding-bottom: 10px;
  margin-bottom: 12px;
  border-bottom: 1px solid #eee;
  text-decoration: none;
}

.blog-list .title-list:hover {
  color: #3498db;
}

.blog-list .site-icon2 {
  width: 21px;
  height: 21px;
  margin-right: 7px;
  border-radius: 50%;
  background-size: 21px 21px;
  background-position: center;
  background-repeat: no-repeat;
  display: inline-block;
}

.blog-list .link-list {
  background: #fafafa;
  color: #9f9f9f;
  overflow-y: auto;
  overflow-x: hidden;
  padding-top: 10px;
  position: relative;
  max-height: 320px;
  border-radius: 10px;
  margin: 0;
  flex: 1;
}

.blog-list .link-list.lastmob {
  overflow-y: auto;
  max-height: 298px;
  padding-top: 0;
}

.blog-list .link-list ol {
  list-style: none;
  margin: 0;
  padding: 0;
  padding-left: 0;
  padding-top: 0px;
}

.blog-list .link-list li {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  transition: background 0.15s ease;
}

.blog-list .link-list li:hover {
  background: rgba(255,255,255,0.5);
}

.blog-list .tools-day {
  color: #ffd700;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
  width: 18px;
  text-align: center;
}

.blog-list .site-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
  display: inline-block;
}

.blog-list .stop-wordy-pop {
  flex: 1;
  font-size: 13px;
  color: #555;
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3;
}

.blog-list .stop-wordy-pop:hover {
  color: #000;
}

.blog-list .stopwordlast {
  font-weight: 400;
}

.blog-list .site-review2 {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  margin-left: auto;
}

.blog-list .site-review2 img {
  width: auto;
  height: 14px;
  display: block;
}

.blog-list .all-cat {
  display: inline-block;
  width: 100%;
  margin-top: 12px;
  padding: 9px 14px;
  background: #f8f8f8;
  color: #555;
  text-decoration: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid #ddd;
  transition: all 0.2s ease;
  text-align: center;
  box-sizing: border-box;
}

.blog-list .all-cat:hover {
  background: #ebebeb;
  border-color: #bbb;
  color: #222;
  text-decoration: none;
}

/* Single Featured Post (sfp-) */
.sfp-wrapper{padding-top:28px;margin-bottom:41px;width:100%;}
.sfp-card{background:#fff;border:1px solid #fce7f3;border-left:4px solid #db2777;border-radius:16px;padding:24px 30px;position:relative;box-shadow:0 4px 6px -1px rgb(0 0 0 / .03);display:flex;align-items:center;gap:25px;}
.sfp-card:hover{box-shadow:0 12px 20px -5px rgb(219 39 119 / .1);}
.sfp-badge{position:absolute;top:-12px;right:30px;background:#fff;color:#9d174d;border:1px solid #fbcfe8;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 12px;border-radius:50px;box-shadow:0 2px 4px rgb(0 0 0 / .05);z-index:10;display:flex;align-items:center;gap:5px;}
.sfp-star{color:#db2777;font-size:.9em;}
.sfp-content{display:flex;align-items:center;width:100%;gap:20px;}
.sfp-icon-box{position:relative;flex-shrink:0;}
.sfp-icon{width:64px;height:64px;border-radius:14px;object-fit:cover;border:1px solid #f1f5f9;box-shadow:0 2px 5px rgb(0 0 0 / .05);background:#fff;}
.sfp-verif{position:absolute;bottom:-5px;right:-5px;width:22px;height:22px;border-radius:50%;border:2px solid #fff;background:#fff;z-index:2;box-shadow:0 2px 4px rgb(0 0 0 / .1);}
.sfp-info{flex-grow:1;min-width:0;}
.sfp-title{margin:0 0 5px;font-size:1.25rem;font-weight:800;line-height:1.2;padding-bottom:4px;display:block;}
.sfp-title a{color:#1e293b;text-decoration:none;}
.sfp-title a:hover{color:#db2777;}
.sfp-desc{font-size:.95rem;color:#475569;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.sfp-actions{flex-shrink:0;display:flex;align-items:center;gap:12px;margin-left:10px;height:44px;}
.sfp-like-wrap{display:flex;align-items:center;}
.sfp-like{position:relative!important;top:auto!important;bottom:auto!important;left:auto!important;right:auto!important;margin:0!important;height:44px!important;min-width:70px!important;padding:0 15px!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:12px!important;color:#475569!important;cursor:pointer;box-shadow:0 1px 2px rgb(0 0 0 / .05)!important;}
.sfp-like:hover{background:#f8fafc!important;border-color:#cbd5e1!important;filter:none;}
.sfp-like img{width:14px!important;height:auto!important;margin:0!important;opacity:.7;}
.sfp-like:hover img{opacity:1;}
.sfp-like-wrap .numbers-upvote{font-size:.95rem!important;font-weight:700!important;line-height:1!important;margin:0!important;color:inherit!important;}
.sfp-btn{height:44px;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#db2777 0%,#be185d 100%);color:#fff;padding:0 20px;border-radius:12px;font-weight:600;font-size:.95rem;text-decoration:none;white-space:nowrap;box-shadow:0 4px 10px rgb(219 39 119 / .25);border:none;}
.sfp-btn:hover{background:linear-gradient(135deg,#be185d 0%,#9d174d 100%);box-shadow:0 6px 15px rgb(219 39 119 / .35);color:#fff;text-decoration:none;}
.sfp-btn svg{width:18px;height:18px;}
@media only screen and (max-width:768px){
.sfp-card{padding:40px 20px 25px;flex-direction:column;text-align:center;}
.sfp-title{display:flex;justify-content:center;}
.sfp-content{flex-direction:column;gap:15px;}
.sfp-info{text-align:center;margin-bottom:5px;}
.sfp-desc{text-align:center;-webkit-line-clamp:3;}
.sfp-actions{width:100%;margin-left:0;justify-content:center;flex-wrap:wrap;gap:15px;}
.sfp-badge{right:50%;transform:translateX(50%);white-space:nowrap;}
}

/* Category Separators */
.sepa-catt-top{height:10px;background:#d3d3d3;display:none;}
.sepa-catt{height:10px;background:#d3d3d3;margin:25px 0 100px;}
@media only screen and (max-width:650px){
.sepa-catt-top{display:block;}
.sepa-catt{display:none;}
}
