.left-slice-clip
{
    clip-path: polygon(40px 0, 100% 0, 100% 50%, 100% 100%, 0 100%, 0 40px);
}
.wdt-listings-item-wrapper.type1 .wdt-listings-item-top-section a.custom-button-style {
    transition: background .3s ease, color .3s ease, opacity .3s ease, transform var(--wdt-transform-transition-duration);
    transform: perspective(0px) rotateX(0deg) rotateY(0deg) scaleX(0.2) scaleY(0.2); opacity: 0;
    transform-origin: 50px 50px;
}
.wdt-listings-item-wrapper.type1 .wdt-listings-item-top-section:hover a.custom-button-style {
    transform: perspective(0px) rotateX(0deg) rotateY(0deg) scaleX(1) scaleY(1); opacity: 1;
    transform-origin: 50px 50px;
}
.wdt-listings-item-wrapper.type1 .wdt-listings-item-top-section a.custom-button-style:hover {
    color: var(--wdtAccentTxtColor); 
    transform: perspective(var(--wdt-transform-perspective)) rotateX(var(--wdt-transform-rotateX)) rotateY(var(--wdt-transform-rotateY)) 
    scaleX(var(--wdt-transform-scale)) scaleY(var(--wdt-transform-scale)); }

.wdt-listings-item-wrapper.type1 .wdt-listings-item-top-section .wdt-listings-taxonomy-list a,
.wdt-listings-item-wrapper.type1 .wdt-listings-item-top-section a:not(.custom-button-style):hover { color: var(--wdtPrimaryColor); }

    .navbar .attr-right .attr-nav li.tracing a::after {
        position: absolute;
        left: 0;
        top: 0;
        content: "";
        height: 100%;
        right: 0;
        background: var(--color-primary);
        z-index: -1;
        clip-path: polygon(6% 0, 100% 0, 100% 100%, 0 100%, 0 24%);
    }
/* ===============================
			HEADING
=============================== */

/* Center */
.align-center .ts-subtitle {justify-content: center;}
.align-right .ts-subtitle {
    align-items: center !important;
    justify-content: start;
}
.align-right .ts-subtitle {
    align-items: center !important;
    justify-content: end;
}
.align-center .ts-subtitle {
    align-items: center !important;
    justify-content: center;
}
.ts-dual-heading{position:relative}
.ts-separator{display:block;margin:10px 0}
.ts-heading-title.gradient span {
background: inherit;
background-clip: text;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
.ts-separator{
margin:15px auto;
position:relative;
}
.ts-dual-heading{
    position:relative;
}
.ts-heading-title{
    font-weight:700;
    line-height:1.3;
	overflow: hidden;
}
/* Highlight styles */
.ts-heading-title span{
    position:relative;
	display: inline-block;
}
/* Solid color */
.ts-dual-heading.highlight-color span{
    color:#ff5e57;
}
/* Background */
.ts-dual-heading.highlight-background span{
    background:#ffeaa7;
    padding:2px 6px;
    border-radius:4px;
}
/* Underline */
.ts-dual-heading.highlight-underline span:after{
    content:'';
    position:absolute;
    left:0;
    bottom:-3px;
    width:100%;
    height:3px;
    background:#ff5e57;
}

/* Gradient highlight */
.ts-dual-heading.highlight-gradient span{
    background:linear-gradient(90deg,#ff7e5f,#feb47b);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

/* Separator Premium Styles */
.ts-separator{
    margin:15px auto;
}

/* Line + Dot */
.ts-separator.style2{
    width:80px;
    height:2px;
    background:#333;
    position:relative;
}
.ts-separator.style2:after{
    content:'';
    width:10px;
    height:10px;
    background:#333;
    border-radius:50%;
    position:absolute;
    top:-4px;
    left:50%;
    transform:translateX(-50%);
}

/* Double Line */
.ts-separator.style3{
    width:70px;
    border-top:2px solid #333;
    border-bottom:2px solid #333;
    height:6px;
}

/* Animated Line */
.ts-separator.style5{
    width:0;
    height:3px;
    background:#ff5e57;
    animation:growLine 1s ease forwards;
}
.ts-separator{
    text-align:center;
    margin:15px 0;
}

.ts-separator svg{
    display:inline-block;
    height:auto;
}

/* Smooth animation (premium feel) */
.ts-separator svg path{
    transition: all 0.3s ease;
}

/* Hover effect */
.ts-dual-heading:hover .ts-separator svg path{
    opacity:0.7;
    transform:scale(1.05);
}

/* Icon separator */
.ts-separator i{
    display:inline-block;
    transition:0.3s;
}

.ts-dual-heading:hover .ts-separator i{
    transform:translateY(-3px);
}
.ts-separator svg{
    width:100%;
    height:100%;
}
@keyframes growLine{
    to{width:100px;}
}
.ts-title-effect{
    display:inline-block;
    overflow:hidden;
}

.ts-title-effect .char,
.ts-title-effect .word{
    display:inline-block;
}
/* ===============================
			ANIM 1
=============================== */

.ts-anim-text .word,
.ts-anim-text .char {
  display: inline-block;
}
.ts-highlight-text {
  position: relative;
  display: inline-block;
  z-index:3;
}

.ts-highlight-text .ts-text-base {
  color: #999;
}

.ts-text-fill {
  position: absolute !important;
  left: 0;
  top: 0;
  transform: scaleX(0);
  transform-origin: left;
  white-space: nowrap;
}
.ts-line {
  display: block;
  will-change: transform;
}
/* ===============================
			HEADING
=============================== */
.ts-separator-wrap {position: relative;
    display: inline-block;
	margin:0 auto;}
.ts-separator-wrap svg {width:100% !important; height:auto !important}
.ts-liner-divider {
    display: flex;
    align-items: flex-start;
    text-align: left;
}
.ts-liner-divider:after {
    content: "";
    flex-grow: 1;
    height: 1px;
    background: #D66853;
    min-width: 20px;
    margin: auto;
	margin-left: 20px;
}
.nx-step1-item:before, .nx-step1-item:after {
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    content: "";
    height: 100%;
    position: absolute;
    background-color: #fff;
    -webkit-transition: all 500ms ease-in-out;
    transition: all 500ms ease-in-out;
    clip-path: polygon(4.762% 0.156%, 9.975% 0.156%, 9.975% 0.156%, 10.434% 0.186%, 10.883% 0.274%, 11.321% 0.418%, 11.744% 0.616%, 12.15% 0.866%, 12.536% 1.167%, 12.898% 1.515%, 13.235% 1.91%, 13.542% 2.349%, 13.818% 2.831%, 15.747% 6.564%, 15.747% 6.564%, 16.037% 7.07%, 16.36% 7.531%, 16.714% 7.946%, 17.095% 8.313%, 17.5% 8.629%, 17.927% 8.892%, 18.372% 9.1%, 18.832% 9.251%, 19.305% 9.344%, 19.787% 9.375%, 28.725% 9.375%, 28.725% 9.375%, 29.207% 9.344%, 29.68% 9.251%, 30.14% 9.1%, 30.585% 8.892%, 31.012% 8.629%, 31.417% 8.313%, 31.798% 7.946%, 32.152% 7.531%, 32.475% 7.07%, 32.765% 6.564%, 34.694% 2.831%, 34.694% 2.831%, 34.97% 2.349%, 35.277% 1.91%, 35.614% 1.515%, 35.976% 1.167%, 36.362% 0.866%, 36.768% 0.616%, 37.191% 0.418%, 37.629% 0.274%, 38.078% 0.186%, 38.537% 0.156%, 95.238% 0.156%, 95.238% 0.156%, 95.991% 0.236%, 96.706% 0.467%, 97.372% 0.836%, 97.98% 1.332%, 98.521% 1.941%, 98.985% 2.651%, 99.363% 3.45%, 99.644% 4.324%, 99.82% 5.262%, 99.881% 6.25%, 99.881% 93.75%, 99.881% 93.75%, 99.82% 94.738%, 99.644% 95.676%, 99.363% 96.55%, 98.985% 97.349%, 98.521% 98.059%, 97.98% 98.668%, 97.372% 99.164%, 96.706% 99.533%, 95.991% 99.764%, 95.238% 99.844%, 4.762% 99.844%, 4.762% 99.844%, 4.009% 99.764%, 3.294% 99.533%, 2.628% 99.164%, 2.02% 98.668%, 1.479% 98.059%, 1.015% 97.349%, 0.637% 96.55%, 0.356% 95.676%, 0.18% 94.738%, 0.119% 93.75%, 0.119% 6.25%, 0.119% 6.25%, 0.18% 5.262%, 0.356% 4.324%, 0.637% 3.45%, 1.015% 2.651%, 1.479% 1.941%, 2.02% 1.332%, 2.628% 0.836%, 3.294% 0.467%, 4.009% 0.236%, 4.762% 0.156%);
}
/* =====================================
			Button
===================================== */
.ts-btn-reveal {
padding:40px 0;
text-align:center;
width:100px; 
height:100px;
background:#000;
border-radius:50%;
color:#fff;
}
.ts-btn-reveal:Hover
{
	background:var(theme-color); color:#fff;
}
/* =====================================
			TESTIMONIALS
===================================== */
.ts-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

@media (max-width: 1024px) {
  .ts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .ts-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}
.ts-grid-item.ts-hide {
  pointer-events: none;
}
/* ==========================
		  FILTER
========================== */
.ts-filter-bar {margin:20px 0; 
display:inline-flex; 
gap:20px; padding:15px 25px; 
border:1px solid var(--theme-color); 
border-radius:95px;
position:relative !important;
}
.ts-filter-bar button {
  cursor: pointer;
  padding:15px 25px; background: var(--dark-color); color:#fff; border-radius:35px;
}
.ts-filter-bar button.active {

  background: var(--theme-color);
  color: #fff;
}
.ts-no-result {
  margin-top: 20px;
  text-align: center;
  font-weight: 500;
}
/* ==========================
		  Popup
========================== */
.ts-image-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  z-index: 9999;
}

.ts-image-popup.active {
  opacity: 1;
  visibility: visible;
}
.ts-image-popup-inner {  background:#111; 
  padding:20px;}
.ts-image-popup img {
  max-width: 90%;
  max-height: 90%;
  object-fit: contain;
}

.ts-img-close {
  position: absolute;
  top: 20px;
  right: 30px;
  font-size: 30px;
  color: #fff;
  cursor: pointer;
}
.ts-img-popup {
  cursor: zoom-in;
}
.ts-image-popup img {
  transform: scale(0.9);
  transition: 0.3s;
}

.ts-image-popup.active img {
  transform: scale(1);
}
/* ==========================
		  Rating
========================== */
.ts-rating {
  color: #f5a623;
}
/* ==========================
		  Social
========================== */
.ts-socials a {
  margin-right: 10px;
  width:40px; height:40px;    display: inline-flex;
}
.ts-socials a img {width:100%; height:100%;}
/* ==========================
		  Thumb
========================== */
.ts-thumb img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
}
/* ==========================
		  Contentd
========================== */
.ts-full-content {
  position: fixed;
  top: 0;
  right: -100%;
  width: 400px;
  height: 100%;
  background: #fff;
  z-index: 9999;
  transition: right 0.4s ease;
  box-shadow: -10px 0 30px rgba(0,0,0,0.1);
}

.ts-full-content.active {
  right: 0;
}

.ts-panel-inner {
  padding: 30px;
  overflow-y: auto;
  height: 100%;
}

.ts-close-btn {
  position: absolute;
  top: 15px;
  right: 20px;
  font-size: 24px;
  cursor: pointer;
}

.ts-readmore-btn {
  margin-top: 10px;
  cursor: pointer;
}
.ts-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  opacity: 0;
  pointer-events: none;
  transition: 0.3s;
}

.ts-overlay.active {
  opacity: 1;
  pointer-events: all;
}
/* Card */
.ts-testimonial-card-inner {
  padding: 24px;
  border-radius: 16px;
  background: #fff;
  transition: 0.3s ease;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.ts-card-top {
  display: flex;
  gap: 15px;
  align-items: center;
}

.ts-avatar {
  width: 60px;
  height: 60px;
  flex-shrink: 0; 
}

.ts-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover; 
  border-radius: 50%;
  display: block;
}
.ts-avatar img,
.ts-panel-image img {
  aspect-ratio: 1/1;
}
.ts-avatar img {
  border: 2px solid #fff;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.ts-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Panel */
.ts-global-panel {
  position: fixed;
  top: 0;
  right: -100%;
  width: 480px;
  height: 100%;
  background: #fff;
  z-index: 9999;
}

.ts-panel-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  opacity: 0;
  pointer-events: none;
}

/* Active states */
.ts-panel-overlay.active {
  opacity: 1;
  pointer-events: all;
}
.ts-department {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  background: #f5f5f5;
  font-size: 12px;
  font-weight: 500;
      max-width: 45px;
}
.ts-department img {max-width:40px; height:auto;}
.ts-testimonial-card-inner {
  transition: 0.3s ease;
}

.ts-rating {
  color: #ffb400;
  letter-spacing: 2px;
  font-size: 14px;
}
.ts-testimonial-card-inner {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
  height:100%}
.ts-testimonial-inner {
  border: 2px solid red;
  min-height: 50px;
}
/* ============================
			SWIPER
============================ */
.ts-tts-marquee { overflow: hidden; }
.ts-tts-marquee-track {
  display: flex;
  gap: 20px;
  will-change: transform;
}
.ts-tts-marquee-track > * {
  flex: 0 0 auto;
  width: 320px; /* 🔥 fixed width (adjust as needed) */
}
/* ============================
			SWIPER
============================ */
.ts-swiper {
    position: relative !important;
    width: 100%;
    overflow: hidden;
}
.ts-swiper .swiper-wrapper {
    display: flex;
}

.ts-swiper .swiper-slide {
    height: auto;
}
.ts-swiper-prev,
.ts-swiper-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  cursor: pointer;
}

.ts-swiper-prev { left: -20px; }
.ts-swiper-next { right: -20px; }
/* ============================
			MARQUEE
============================ */
.ts-marquee {
    overflow: hidden;
    width: 100%;
    position: relative;
}

.ts-marquee-track {
    display: flex;
    width: max-content;
}

.ts-marquee-track > * {
    flex: 0 0 auto;
}
/* ============================
			Button
============================ */
.ts-btn-wrap{display:flex}
.btn-align-center {
    align-items: center;
    justify-content: center;
}
.ts-theme-btn
{
    display:inline-flex;
    align-items:center;
    text-decoration:none;
    transition:0.3s ease;
}

.ts-theme-btn.full{width:100%;justify-content:center}
.ts-theme-btn.grow:hover{transform:scale(1.05)}
.ts-theme-btn.slide:hover{transform:translateY(-5px)}
.ts-theme-btn.pulse:hover{animation:pulse 0.6s}

@keyframes pulse{
    0%{transform:scale(1)}
    50%{transform:scale(1.08)}
    100%{transform:scale(1)}
}

.ts-btn-style1 {
  display: inline-flex;
  align-items: center;
  gap: 0px;
  position: relative;
  transition: all 400ms ease;
  background: var(--theme-color);
  color: var(--white-color);
  gap: 10px;
  border-radius: 40px;
  padding: 10px 20px;
}
.ts-btn-style1:hover {
  padding-right: 38px;
  gap: 0;
  color: var(--white-color);
}
.ts-btn-style1:hover .ts-btn-text {
transform: translateX(40px);	
}
.ts-btn-style1:hover .ts-btn-arrow-left {
  scale: 1;
}
.ts-btn-style1:hover .ts-btn-arrow-right {
  scale: 0;
}
.ts-btn-style1 .ts-btn-text {
  font-weight: 400;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: 0.4s;
}

.ts-btn-style1 .ts-btn-arrow-left,
.ts-btn-style1 .ts-btn-arrow-right {
  height: 40px;
  line-height: 40px;
  width: 40px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--theme-color2);
  color: var(--theme-color2-text-color);
  border-radius: 50%;
  transition: 0.4s;
  text-align: center;
}
.ts-btn-style1 .ts-btn-arrow-left i,
.ts-btn-style1 .ts-btn-arrow-right i,
.ts-btn-style1 .ts-btn-arrow-left svg,
.ts-btn-style1 .ts-btn-arrow-right svg {
  rotate: -30deg;
  width:20px;
  height:20px;
  font-size:16px;
  fill: #fff;
  color:#fff;
}
.ts-btn-style1 .ts-btn-arrow-left {
  scale: 0;
  right: auto;
  position: absolute;
}

.ts-btn-style2 {
    position: relative;
    overflow: hidden;
    border: 1px solid #111;
    color: #111;
    background: transparent;
}

.ts-btn-style2::before {
    content: "";
    position: absolute;
    inset: 0;
    background: #111;
    transform: translateX(-100%);
    transition: transform 0.4s ease;
    z-index: 0;
}

.ts-btn-style2:hover::before {
    transform: translateX(0);
}

.ts-btn-style2 span {
    position: relative;
    z-index: 1;
}

.ts-btn-style2:hover {
    color: #fff;
}
.ts-btn-style3 {
    position: relative;
    background: transparent;
    color: #111;
    border: 1px solid #111;
    overflow: hidden;
}

.ts-btn-style3::before,
.ts-btn-style3::after {
    content: "";
    position: absolute;
    background: #111;
    transition: all 0.4s ease;
}

.ts-btn-style3::before {
    height: 2px;
    width: 0;
    top: 0;
    left: 0;
}

.ts-btn-style3::after {
    width: 2px;
    height: 0;
    bottom: 0;
    right: 0;
}

.ts-btn-style3:hover::before {
    width: 100%;
}

.ts-btn-style3:hover::after {
    height: 100%;
}
.ts-theme-btn.ts-btn-limpa {
    position: relative;
    display: inline-block;
    overflow: hidden;
    padding: 14px 28px;
    color: #000;
    text-decoration: none;
	    line-height: 1;
}

/* inner flex */
.ts-theme-btn-inner {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    z-index: 2;
}

/* background fill */
.ts-theme-btn.ts-btn-limpa::before {
    content: "";
    position: absolute;
    inset: 0;
    background: #000;

    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.5s cubic-bezier(.77,0,.175,1);
    z-index: 1;
}

.ts-theme-btn.ts-btn-limpa:hover::before {
    transform: scaleX(1);
    transform-origin: left;
}

/* TEXT LAYERS */
.ts-theme-btn.ts-btn-limpa .ts-btn-text {
    position: relative;
    display: inline-block;
    transition: transform 0.4s cubic-bezier(.77,0,.175,1),
                opacity 0.3s ease;
}

/* default text */
.ts-theme-btn.ts-btn-limpa .text-default {
    color: currentColor;
}

/* hover text (starts hidden below) */
.ts-theme-btn.ts-btn-limpa .text-hover {
    position: absolute;
    right: 0;
    color: #fff;
    transform: translateY(100%);
    opacity: 0;
}

/* text animation */
.ts-theme-btn.ts-btn-limpa:hover .text-default {
    transform: translateY(-100%);
    opacity: 0;
}

.ts-theme-btn.ts-btn-limpa:hover .text-hover {
    transform: translateY(0);
    opacity: 1;
}

/* ICON */
.ts-theme-btn.ts-btn-limpa .ts-btn-icon {
    display: inline-flex;
    transition: transform 0.4s cubic-bezier(.77,0,.175,1);
	    align-items: center;
    justify-content: center;
}

/* arrow slide */
.ts-theme-btn.ts-btn-limpa:hover .ts-btn-icon {
    transform: translateX(-2px);
}

/* STYLE 2 tweaks */
.ts-btn.style2 {
    border: 1px solid #000;
}

/* optional: smoother text rendering */
.ts-theme-btn,
.ts-theme-btn * {
    backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
}

/* =========================
			Price Menu
   ========================= */
.ts-items .row {
    display: flex;
    flex-wrap: wrap;
}

.ts-items .col-md-4,
.ts-items .col-md-6,
.ts-items .col-md-3,
.ts-items .col-md-12 {
    display: flex;
}
.ts-price-yearly { display: none; }
.yearly-active .ts-price-monthly { display: none; }
.yearly-active .ts-price-yearly { display: inline; }

/* toggle switch */
.ts-pricing-toggle {    margin: 60px auto;}
.ts-save-badge {
    display: none;
    background: #16a34a;
    color: #fff;
    font-size: 12px;
    padding: 3px 8px;
    border-radius: 20px;
    margin-bottom: 10px;
    display: inline-block;
}

.yearly-active .ts-save-badge {
    display: inline-block;
}
/* ====================================
				Tilt 
=====================================*/
.ts-tilt {
    transform-style: preserve-3d;
    will-change: transform;
}

.ts-tilt:hover {
    box-shadow: 0 25px 60px rgba(0,0,0,0.2);
}
/* ====================================
				Switch 
=====================================*/
.ts-pricing-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
}

.ts-switch {
    position: relative;
    width: 60px;
    height: 28px;
}

.ts-switch input { display: none; }

.ts-slider {
    position: absolute;
    inset: 0;
    background: #ddd;
    border-radius: 30px;
    transition: 0.3s;
}

.ts-slider::before {
    content: "";
    position: absolute;
    width: 26px;
    height: 26px;
    left: 1px;
    top: 1px;
    background: linear-gradient(45deg, #4CAF50, #00c853);
    border-radius: 50%;
    transition: 0.3s;
}

input:checked + .ts-slider::before {
    transform: translateX(32px);
}

input:checked + .ts-slider {
    background: #c8f7c5;
}
/* ====================================
				Ribbon 
=====================================*/
.ts-ribbon {
    position: absolute;
    top: 15px;
    right: -40px;
    background: #ff4d4f;
    color: #fff;
    padding: 5px 40px;
    transform: rotate(45deg);
    font-size: 12px;
    font-weight: 600;
}
/* ====================================
				CARD 
=====================================*/
.ts-card {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.ts-card .ts-btn {
    margin-top: auto;
}
.ts-card.is-featured {
    transform:none !important;
    box-shadow: 0 20px 50px rgba(0,0,0,0.15);
    border: 2px solid #4CAF50;
    z-index: 2;
}
.ts-card.is-featured {
    will-change: transform;
}
.ts-card.is-featured:hover {
    transform: scale(1.08);
}
.ts-card.is-featured {
    position: relative;
    z-index: 1;
}

.ts-card.is-featured::before {
    content: "";
    position: absolute;
    inset: -2px;
    background: linear-gradient(45deg, #00f5ff, #7c3aed, #ff4d4f);
    border-radius: 12px;
    z-index: -1;
    filter: blur(12px);
    opacity: 0.7;
}

.ts-card.is-featured {
    background: #fff;
    border-radius: 12px;
}
/* ====================================
				Features 
=====================================*/
.ts-features li {
    position: relative;
    padding-left: 5px;
}

.ts-features li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 0;
    height: 2px;
    background: currentColor;
    transition: width 0.3s;
}

.ts-features li:hover::before {
    width: 20px;
}
.ts-featured-badge {
    position: absolute;
    top: 15px;
    right: 15px;
    background: #4CAF50;
    color: #fff;
    padding: 4px 10px;
    font-size: 12px;
    border-radius: 20px;
}
.ts-features li {
    transition: all 0.3s ease;
}

.ts-features li:hover {
    transform: translateX(5px);
}

.ts-features li:hover .ts-feature-icon i {
    transform: scale(1.2);
}

.ts-feature-icon i {
    transition: all 0.3s ease;
}
/* ====================================
				Menu 
=====================================*/
.ts-menu {
  max-width: 700px;
}

.ts-menu-title {
  font-size: 28px;
  margin-bottom: 20px;
  font-weight: 600;
}

.ts-menu-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.ts-menu-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
}

.ts-menu-left {
  display: flex;
  gap: 10px;
}

.ts-menu-icon {
  font-size: 16px;
  margin-top: 4px;
}

.ts-menu-content {
  display: flex;
  flex-direction: column;
}

.ts-menu-name {
  font-size: 16px;
  font-weight: 600;
  margin: 0;
}

.ts-menu-desc {
  font-size: 13px;
  opacity: 0.6;
}

.ts-menu-price {
  font-size: 16px;
  font-weight: 600;
  white-space: nowrap;
}
.ts-menu-item {
  position: relative;
}

.ts-menu-item::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  border-bottom: 1px dotted #ccc;
}
.ts-menu .ts-item {
  display: flex;
  gap: 15px;
  align-items: flex-start;
  border-bottom: 1px dashed #ddd;
  padding-bottom: 12px;
}

.ts-menu .ts-top {
  display: flex;
  gap: 10px;
  align-items: center;
}

.ts-menu .ts-price {
  margin-left: auto;
  font-weight: 600;
}
/* ====================================
				Card 
=====================================*/
.ts-card {
  display: flex;
  gap: 30px;perspective: 900px;
}

.ts-card .ts-section {
  flex: 1;
  background: #fff;
  border-radius: 20px;
  padding: 30px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.ts-card .ts-price {
  font-size: 22px;
  font-weight: bold;
}
.ts-card .ts-badge {
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 4px;
}

.ts-veg { background: #e6f7e6; color: green; }
.ts-nonveg { background: #ffe6e6; color: red; }
.ts-spicy { background: #fff3cd; color: orange; }
/* wrapper */
/* card */
.ts-card .ts-item {
    --r: 30px;
    --s: 40px;	
-webkit-clip-path: shape(from 0 0, hline to calc(100% - var(--s) - 2 * var(--r)), arc by var(--r) var(--r) of var(--r) cw, arc by var(--s) var(--s) of var(--s), arc by var(--r) var(--r) of var(--r) cw, vline to 100%, hline to 0);
    clip-path: shape(from 0 0, hline to calc(100% - var(--s) - 2 * var(--r)), arc by var(--r) var(--r) of var(--r) cw, arc by var(--s) var(--s) of var(--s), arc by var(--r) var(--r) of var(--r) cw, vline to 100%, hline to 0);
  border-radius: 20px;
  padding: 30px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  transition: box-shadow 0.3s ease; /* FIXED */
  text-align: center;
}

/* featured */
.ts-card .ts-item.is-featured {
  background: #1e2a78;
  color: #fff;
  box-shadow: 0 20px 50px rgba(0,0,0,0.15);
}

/* title */
.ts-card .ts-title {
  font-size: 18px;
  margin-bottom: 10px;
}

/* price */
.ts-price-wrap {
  font-size: 32px;
  font-weight: bold;
}

.ts-duration {
  font-size: 14px;
  opacity: 0.6;
}

/* button */
.ts-btn {
  display: inline-block;
  margin: 20px 0;
  padding: 10px 20px;
  border-radius: 30px;
  background: #eef2ff;
  text-decoration: none;
}

.ts-item.is-featured .ts-btn {
  background: #fff;
  color: #1e2a78;
}

/* ====================================
				Features 
=====================================*/
.ts-features {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* left/right layout */
.ts-features.left li,
.ts-features.right li {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* right icon */
.ts-features.right li {
    justify-content: space-between;
}

/* top layout */
.ts-features.top li {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

/* divider */
.ts-features.divider li {
    padding: 10px 0;
}

/* last item no border */
.ts-features.divider li:last-child {
    border-bottom: none;
}
.ts-features li svg {width:15px;}


.ts-check {
  color: green;
}
