
:root {
    /* Colors */
    --color-primary: #3491ef;
    --color-primary-dark: #104899;
    --color-success: #12b031;
    --color-success-dark: #0fa52a;
    --color-danger: #ef0e0e;
    --color-warning: #ffe59c;
    --color-warning-dark: #fcce5e;
    --color-dark: #212529;
    --color-light: #f8f9fa;
    --color-gray: #6c757d;
    --color-gray-light: #e9ecef;
	--color-yellow-light: #fffced;
    

    
    /* Typography */
    --font-family: 'Poppins', sans-serif;
    --font-size-xs: 0.875rem;
    --font-size-sm: 1rem;
    --font-size-md: 1.25rem;
    --font-size-lg: 1.5rem;
    --font-size-xl: 2rem;
    --font-size-xxl: 2.5rem;
    
    /* Borders */
    --border-radius: 0.5rem;
    --border-radius-lg: 1rem;
    --border-radius-xl: 1.5rem;
    
    /* Shadows */
    --shadow-sm: 0 2px 4px rgba(0,0,0,0.1);
    --shadow-md: 0 4px 8px rgba(0,0,0,0.1);
    --shadow-lg: 0 8px 16px rgba(0,0,0,0.1);
    --shadow-xl: 0 12px 24px rgba(0,0,0,0.1);
}
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,font,ins,kbd,q,s,samp,small,strike,strong,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td{margin:0;padding:0;border:0;outline:0;vertical-align:baseline;background:transparent}img{margin:0;padding:0;border:0;outline:0;background:transparent}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}:focus{outline:0}a:focus{outline:0;text-decoration:none}ins{text-decoration:none}del{text-decoration:line-through}table{border-collapse:collapse;border-spacing:0}a{text-decoration:none;-webkit-transition:all .5s ease;-moz-transition:all .5s ease;transition:all .5s ease}a:hover{text-decoration:none}::-webkit-input-placeholder{opacity:1}:-moz-placeholder{opacity:1}::-moz-placeholder{opacity:1}:-ms-input-placeholder{opacity:1}*,*:before,*:after{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}
/* ===== BASE STYLES ===== */

body {
    font-family: var(--font-family);
    color: var(--color-dark);
    line-height: 1.6;
    padding-top: 0 !important;
}

.container{max-width: 1170px}

/* ===== HEADER ===== */
.header {
    border-bottom: 1px solid var(--color-gray-light);
    background: white;
    padding: 0;
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.logo {
    max-width: 320px;
    height: auto;
}

/* ===== BANNER ===== */
.banner-section {
    background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
    color: white;
}

.de3-page .banner-section {
    background: #ececec;
    color: #000;
}

.banner-header{
	padding-top: 15px;
	padding-bottom: 35px;
}

.de3-page .banner-header{
	padding-top: 15px;
	padding-bottom: 35px;
}

.banner-img{
	max-width: 350px
}
.banner-heading {
    font-size: var(--font-size-xxl);
    font-weight: 700;
    line-height: 1.1;
    margin-bottom: 20px;
}
.de3-page .banner-heading {
	font-size: 35px;
	font-weight: 600;
	line-height:1;
    margin-bottom: 10px;
}
.article-wrapper{ margin-top:-10px;}

.banner-paragraph {
    font-size: var(--font-size-sm);
    opacity: 0.95;
    margin-bottom: 0;
}

.de3-page .banner-paragraph {
    font-size: var(--font-size-lg);
	font-weight: 400;
	line-height:1.2;
   }

/* ===== MAIN CONTENT ===== */
.main-content {
    padding: 0 0 40px 0;
}

.last-updated {
    background: white;
    padding: 12px 20px;
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-sm);
    display: inline-block;
    margin-bottom: 30px;
	line-height: 1;
	font-size: var(--font-size-xs);
	transform: translateY(-50%)
}

.last-updated strong {
    display: block;
	font-weight: 600;
}

/* ===== ARTICLE STYLES ===== */
.content-article {
    padding-right: 30px;
}

.content-article h2 {
    color: var(--color-primary-dark);
    font-size: var(--font-size-xl);
    font-weight: 700;
    margin: 40px 0 20px;
}

.content-article h2:first-child {
    margin-top: 0;
}

.content-article h3 {
    color: var(--color-primary-dark);
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin: 30px 0 15px;
}

.content-article p {
    margin-bottom: 20px;
    font-size: 18px;
    line-height: 1.6;
}

/* List Styles */
.list-check {
    list-style: none;
    padding-left: 0;
    margin-bottom: 20px;
}

.list-check li {
    position: relative;
    padding-left: 25px;
    margin-bottom: 10px;
    font-size: 16px;
}

.list-check li:before {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='20px' viewBox='0 -960 960 960' width='20px' fill='%2311d237'%3E%3Cpath d='M389-235 163-460l84-85 142 142 324-323 84 84-408 407Z'/%3E%3C/svg%3E");
    position: absolute;
    left: 0;
    color: var(--color-success);
    font-weight: bold;
    font-size: 1.2em;
    top: 0;
}

.list-bullet {
    list-style: none;
    padding-left: 0;
    margin-bottom: 20px;
}

.list-bullet li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 8px;
    font-size: 16px;
}

.list-bullet li:before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--color-primary);
    font-size: 1.5em;
    top: -2px;
}

/* Ordered list */
.content-article ol {
    padding-left: 20px;
    margin-bottom: 20px;
}

.content-article ol li {
    margin-bottom: 10px;
    font-size: 16px;
}

/* ===== CTA BOX ===== */
.cta-box {

    padding: 20px;
    margin: 30px 0;
}

.cta-box h3 {
    margin-top: 0 !important;
    color: white !important;
}

/* ===== HL Box ===== */
.hlBox{
	background: var(--color-yellow-light);
	padding:20px;
	border: solid 1px #000;
	border-radius: var(--border-radius);
}
.hlBox h2{
	font-size:28px;
	font-weight:600;
	color: var(--font-size-xxl);
	}
.hlBox .btn{
	margin-left: 0;
    margin-right: auto;
	}	
.hlBox img{ width:350px; display:block; margin:0 auto; background:#FFF;}

/* ===== Article 1st Heading =====*/

.body-heading{
	font-size: 32px !important;
	font-weight: 700;
	color: var(--color-dark) !important;
	}
	

/* ===== PROMO BOX ===== */
.promo-box {
    background: var(--color-light);
    border: 1px solid var(--color-gray-light);
    box-shadow: var(--shadow-md);
    padding: 20px;
    margin: 30px 0;
    border-radius: 8px;
}

.promo-box h3 {
    margin-bottom: 10px;
    color: var(--color-dark);
}

/* ===== CHOICE BOX - SLEEK ===== */
.choice-box {
    position: sticky;
    top: 100px;
    margin-bottom: 30px;
    background: white;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 5px 20px rgba(0,0,0,0.1);
    border: 1px solid var(--color-gray-light);
}

.choice-header {
     background: linear-gradient(90deg, #FFD700, #FFA500);
    color: white;
}

.choice-body {
    padding: 20px 15px;
}

.choice-logo {
    max-height: 60px;
    max-width: 250px;
}

.deal-tag {
    border-radius: 5px;
}

.deal-tag.bg-danger {
    background: linear-gradient(90deg, #dc3545, #c82333) !important;
}

.list-check {
    padding-left: 20px;
    margin-bottom: 20px;
}

.list-check li {
    font-size: 0.85rem;
    padding-left: 25px;
    margin-bottom: 8px;
}
.choice-grade{width: 100%} 

.pulse-animate {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.02); }
    100% { transform: scale(1); }
}


/* ===== FOOTER ===== */
.footer {
    background: var(--color-light);
    border-top: 1px solid var(--color-gray-light);
    padding: 60px 0 120px;
}

.footer-logo {
    max-width: 320px;
    margin-bottom: 30px;
}

.footer-links{
	gap:15px;
		display: flex;
	flex-direction: row;
	justify-content: center;
	flex-wrap: wrap
		
}
.footer-links a {
    color: var(--color-primary);
    text-decoration: none;
    margin: 0 15px;
    font-size: 16px;
}

.footer-links a:hover {
    color: var(--color-primary-dark);
    text-decoration: underline;
}

.disclosure-box {
    margin-top: 40px;
    font-size: var(--font-size-xs);
    line-height: 1.6;
	color: var(--color-gray);
}

/* ===== STICKY FOOTER ===== */
.sticky-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: white;
    box-shadow: 0 -2px 15px rgba(0,0,0,0.15);
    z-index: 1000;
    padding: 10px 0;
    border-top: 1px solid var(--color-gray-light);
    display: none; /* Hidden by JS initially */
}

.sticky-close {
    position: absolute;
    top: -10px;
	transform: translateY(-50%);
    right: 0;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background: white;
    border: 1px solid var(--color-gray-light);
    cursor: pointer;
    font-size: 20px;
    line-height: 1;
    z-index: 1001;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sticky-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}
.sticky-info,
.sticky-img{flex: 0 0 auto; width: auto!important; }
.sticky-img img {max-height: 50px;max-width: 250px;}
.sticky-progress {max-width: 250px;}

.sticky-info h5 {
    color: var(--color-dark);
    font-weight: 700;
    margin: 0;
    font-size: var(--font-size-md)
}

.sticky-info small {
    color: var(--color-gray);
    font-size:var(--font-size-sm);
}


.deal-progress {
    background: #f8f9fa;
    padding: 10px 15px;
    border-radius: 10px;
    border: 1px solid #eaeaea;
}

.progress-label {
    color: #ff6b6b;
    font-weight: 600;
    font-size:var(--font-size-xs);
	line-height: 1;
    margin-bottom: 5px;
}

.progress-label .timer {
    font-weight: 800;
}

.progress-bar-container {
    background: #eaeaea;
    height: 6px;
    border-radius: 3px;
    overflow: hidden; position: relative
}

.progress-fill {
    background: linear-gradient(90deg, #28a745, #20c997);
    height: 100%;
    border-radius: 3px;
}

.btn.sticky-button{height: 45px;margin: 0; font-size:var(--font-size-sm)!important}
.btn.sticky-button span {background-size: 15px;}

.sticky-row{align-items: center; justify-content: center}




/* ===== EXIT MODAL ===== */
.exit-modal {
    display: none !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: rgba(0, 0, 0, 0.7) !important;
    z-index: 999999 !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px !important;
}

.exit-modal.active {
    display: flex !important;
}

.exit-modal-content {
    background: white !important;
    border-radius: 10px !important;
    padding: 30px !important;
    max-width: 900px !important;
    width: 100% !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    position: relative !important;
}

.exit-close {
    position: absolute !important;
    top: 15px !important;
    right: 20px !important;
    background: #eee !important;
    border: none !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    font-size: 24px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
}

.exit-close:hover {
    background: #333 !important;
    color: white !important;
}

body.modal-open {
    overflow: hidden !important;
}

.exit-logo {max-height: 70px !important; max-width: 250px!important}

.exit-modal-content .list-check{padding-left: 0}

.exit-modal-content .text-danger {
    color: #ef0e0e !important;
    font-size: var(--font-size-sm);
    font-weight: 700 !important;
    margin-bottom: 25px !important;
    display: block !important;
    background: #fff9e6;
    padding: 15px;
    border-radius: var(--border-radius);

}

.exit-modal-img  {max-width: 320px;}


/* ===== BUTTON STYLES ===== */
.btn { background-color: var(--color-success); font-size: 1.5rem !important; margin-bottom: 1rem;  color: #fff !important; font-weight: 700; padding: 10px 30px; transition: all 0.2s ease; display: flex; justify-content: center; align-items: center; margin-left: auto; margin-right: auto; border: none;  animation-name: pulse; animation-duration: 1.5s; animation-iteration-count: infinite; }
.btn:hover, .btn:active, .btn:focus {
            background: var(--color-success-dark);
            color: white;
            text-decoration: none;
            transform: translateY(-2px);
            box-shadow: 0 5px 15px rgba(17, 210, 55, 0.3);
}
.btn span { background-image: url("data:image/svg+xml,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 12 10'%3E%3Cpath stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 9 4-4-4-4M1 9l4-4-4-4'/%3E%3C/svg%3E"); background-position: right; padding-right: 30px; background-repeat: no-repeat; background-size: 20px; }
.btn.fit { width: fit-content; }

.choice-box .btn{font-size:var(--font-size-sm)!important }
.choice-box .btn span {background-size: 15px;}





/* Add these styles at the end of your existing style.css file */

/* ===== REVIEW COMPONENT STYLES ===== */
.review { background: var(--color-light); padding: 35px 50px; margin: 0 auto 50px; position: relative;}
.review .row { margin: 0; }
.review .row > .col, .review .row > [class*=col-] {
    padding-right: 0;
    padding-left: 0;
}

.revHeader { margin-bottom: 1rem !important; }
.revHeader h4 { font-size: 2.125rem; font-weight: 700; }
.revHeader h4 a { color: var(--color-dark); }
.revHeader p { margin-bottom: 0; }
.revHeader p a { color: var(--color-primary); }

.rank { max-width: 100px; height: 100px; background-size: contain; background-repeat: no-repeat; transform: translate(15px, -15px); }
.rank.gold { background-image: url('../img/goldbadge.png'); }
.rank.silver { background-image: url('../img/silverbadge.png'); }
.rank.bronze { background-image: url('../img/bronzebadge.png'); }

.revProduct { background: #fff; box-shadow: 0px 30px 60px rgba(19, 45, 73, 0.06); }
.revProduct > .col { padding-top: 20px; padding-bottom: 20px; text-align: center; }
.revProduct img { max-height: 150px; }
@media (min-width: 578px) { .revProduct > .col:not(:last-of-type) { border-right: solid 1px var(--color-gray-light); } }

.revCircle { width: 128px; height: 128px; position: relative; margin-left: auto; margin-right: auto; }
.circ { height: 100%; transform: rotate(-90deg); width: 100%; fill: none; position: absolute; left: 0; }
.circ_bg { fill: none; stroke: var(--color-light); stroke-width: 2; }

.circ_bar { 
    fill: none; 
    stroke: var(--color-success); 
    stroke-dasharray: 100 100; 
    stroke-dashoffset: 100; /* Start from full offset */
    stroke-width: 3; 
    transition: stroke-dashoffset 1.5s ease-out; 
    transition-delay: 300ms;
}

/* Remove the hardcoded stroke-dashoffset from inline style */
.cirData { display: flex; height: 100%; top: 0; text-align: center; position: absolute; justify-content: center !important; align-items: center !important; width: 100%; flex-direction: column; z-index: 9; }
.cirData h5 { font-weight: 700; font-size: 1.5rem; color: var(--color-dark) !important; margin-bottom: 0; line-height: 1; }
.cirData p { color: var(--color-gray) !important; line-height: 1; font-size: 0.875rem; }

.revGrade h5 { font-size: 5.625rem; font-weight: 700; line-height: 1; margin: 0; color: var(--color-dark); }
.revGrade p { font-weight: 700; text-transform: uppercase; color: var(--color-gray); }

.ratings { margin-top: 2.25rem; margin-bottom: 1.25rem; }
.ratings li { gap: 30px; padding:5px 0; border-bottom: 2px solid #F0F0F0; font-weight: 700; color: var(--color-dark); 
    display: flex;
    flex-wrap: wrap;
    margin-right: 0;
    margin-left: 0; align-items: center;
}
.ratings li > .col { padding: 0; }
.ratings li h5 { font-size: var(--font-size-xs); font-weight: 500; margin-bottom: 0; }
.rateAverage { max-width: 60px; text-align: right; font-weight: 700; }

.tip { padding-right: 20px; position: relative; display: inline-block; }
.tt { cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='%23DCDCDC' viewBox='0 0 20 20'%3E%3Cpath d='M10 .5a9.5 9.5 0 1 0 9.5 9.5A9.51 9.51 0 0 0 10 .5ZM9.5 4a1.5 1.5 0 1 1 0 3 1.5 1.5 0 0 1 0-3ZM12 15H8a1 1 0 0 1 0-2h1v-3H8a1 1 0 0 1 0-2h2a1 1 0 0 1 1 1v4h1a1 1 0 0 1 0 2Z'/%3E%3C/svg%3E"); 
    background-repeat: no-repeat; background-size: 16px; background-position: center right; width: 16px; height: 16px; font-size: 0.1px; display: block; position: absolute; right: 0; top: 0; transition: all 0.3s ease;
}
.tt.on { background-image: url("data:image/svg+xml,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='%23a3a6a9' viewBox='0 0 20 20'%3E%3Cpath d='M10 .5a9.5 9.5 0 1 0 9.5 9.5A9.51 9.51 0 0 0 10 .5ZM9.5 4a1.5 1.5 0 1 1 0 3 1.5 1.5 0 0 1 0-3ZM12 15H8a1 1 0 0 1 0-2h1v-3H8a1 1 0 0 1 0-2h2a1 1 0 0 1 1 1v4h1a1 1 0 0 1 0 2Z'/%3E%3C/svg%3E"); transform: scale(1.2); }

.tooltip { opacity: 0; transition: opacity 0.3s; }
.tooltip.show { opacity: 1; box-shadow: 0px 4px 8px 0px rgba(100, 102, 106, 0.15), 0px 8px 16px 0px rgba(100, 102, 106, 0.33); z-index: 999; position: absolute; background: #fff !important; }
.tooltip .arrow::before { display: none; }
.tooltip-inner { background-color: white !important; opacity: 1; color: black !important; max-width: 300px; font-size: 0.875rem; padding: 10px 15px; text-align: left;  }

.progress { width: 100%; height: 10px; border-radius: 10px; background-color: var(--color-gray-light); }
.progress-bar { background-color: var(--color-success);  background: linear-gradient(90deg, var(--color-success), var(--color-primary)); height: 10px; font-size: 0.625rem; text-align: right; padding-right: 15px; border-radius: 10px; text-transform: uppercase; font-weight: 500; color: white; }
.progress-bar span { color: white; font-weight: 600; }

.badges { margin: 2rem 0 !important; }
.badges .col { max-width: 130px; height: 130px; background-repeat: no-repeat; background-size: contain; background-position: center; }
.badges .col.sixtydayG { background-image: url("../img/100garantie.png"); }
.badges .col.madeinusa { background-image: url("../img/usa.png"); }
.badges .col.naturalingredients { background-image: url("../img/natural.png"); }

.prosBox, .consBox { margin: 2rem 0; padding: 25px; border-radius: var(--border-radius)}
.prosBox {
	background: linear-gradient(135deg, #f0fff4, #e6ffed);
	border: 1px solid #d4edda;
}
.prosBox h3{color: var(--color-success)}
.consBox {
	background: linear-gradient(135deg, #fff5f5, #ffe3e3);
	border: 1px solid #f8d7da;
}
.consBox h3 { color: var(--color-danger);}

.prosBox h3 svg,.consBox h3 svg {width: 20px; height: 20px;}
.prosBox h3,.consBox h3{font-size: 1.625rem; font-weight: 700; margin-bottom: 0; margin-top: 0 ; display: flex; gap:10px; margin-bottom: .5rem}
.prosBox h3 span,.consBox h3 span {min-width: 26px; min-height: 26px; height: 26px; width: 26px;  border-radius: 50%; text-align: center; display: flex; align-items: center; justify-content: center}

.prosBox h3 span{background-color: var(--color-success);}
.consBox h3 span{background-color: var(--color-danger);}



.list.pros, .list.cons { padding-left: 20px; }
.list.pros li, .list.cons li { margin-bottom: 10px; font-size: 16px; position: relative; }
.list.pros li:before { content: '✓'; color: var(--color-success); font-weight: bold; position: absolute; left: -20px; }
.list.cons li:before { content: '✗'; color: var(--color-danger); font-weight: bold; position: absolute; left: -20px; }





.Disclaimer { font-size: 0.75rem !important; font-style: italic; color: var(--color-gray); margin: 2rem 0; }

.cta_text { color: var(--color-gray); font-weight: 600; text-align: center; font-size: 0.875rem; margin: 0 auto; position: relative; display: inline-block; }
.cta_text::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 100%;
    height: 2px;
    background: var(--color-danger);
}



@keyframes pulse {
    0% { transform: scale(0.95); }
    50% { transform: scale(1); }
    100% { transform: scale(0.95); }
}




/* ===== RESPONSIVE STYLES FOR REVIEW ===== */
@media (max-width: 768px) {
    .review { padding: 25px; }
    .revHeader h4 { font-size: 1.5rem; }
    .rank { max-width: 70px; height: 70px; transform: translate(0) scale(1.2); }
    .revProduct img { max-height: 120px; }
    .revGrade h5 { font-size: 4rem; }
    .btn { font-size: 1.25rem !important; height: 60px; padding: 0 20px; }
	.hlBox img{ margin-bottom:20px; width:250px;}
	.hlBox .btn{
	margin-left: auto;
    margin-right: auto;
	}	
	
}

@media (max-width: 576px) {
	.article-wrapper{ margin-top:-30px;}
	.body-heading{
	font-size: 26px !important;
	}
    .review { padding: 20px; width: 100%; margin-left: 0; }
    .revProduct > .col:first-of-type { min-width: 100%; border-bottom: solid 1px var(--color-gray-light); }
    .ratings li { gap: 10px; }
    .ratings li > .col:first-of-type { min-width: 100%; }
    .badges .col { width: 80px; height: 80px; }
    .btn { padding-left: 15px; padding-right: 15px; font-size: 1.125rem !important; height: 55px; }
    .rank { max-width: 50px; height: 50px; }
	.exit-modal-img{width: 100%}
}



.comparison-container {
    background: white;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 5px 25px rgba(0,0,0,0.08);
    margin-bottom: 30px;
}

/* Base table styles */
.comparison-table {
    margin-bottom: 0;
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
}

/* Table header */
.comparison-table thead th {
    border: none;
    padding: 15px 10px;
    font-weight: 600;
    color: #343a40;
    background: linear-gradient(135deg, #f8f9fa, #e9ecef);
    border-bottom: 2px solid #dee2e6;
    font-size: 0.9rem;
    white-space: nowrap;
}

/* Table body rows */
.comparison-table tbody tr {
    border-bottom: 1px solid #f0f0f0;
    transition: background-color 0.2s;
}

.comparison-table tbody tr:hover {
    background-color: #fafafa;
}

.comparison-table tbody td {
    padding: 15px 10px;
    vertical-align: middle;
    border: none;
    font-size: 0.9rem;
}

/* Product name styling for mobile */
.comparison-table tbody td:first-child {
    font-size: 0.95rem;
    word-break: break-word;
    hyphens: auto;
}

/* Badge styles - optimized for mobile */
.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 5px 10px;
    border-radius: 20px;
    font-weight: 700;
    font-size: 0.75rem;
    white-space: nowrap;
    text-align: center;
    min-width: 60px;
}

.badge i {
    font-size: 16px;
    font-style: normal;
    line-height: 1;
}

/* Badge variants */
.winner-card {
    background: rgba(255, 215, 0, 0.15);
    color: #B8860B;
    border: 1px solid rgba(255, 215, 0, 0.3);
}

.runner-card {
    background: rgba(192, 192, 192, 0.15);
    color: #696969;
    border: 1px solid rgba(192, 192, 192, 0.3);
}

.value-card {
    background: rgba(205, 127, 50, 0.15);
    color: #8B4513;
    border: 1px solid rgba(205, 127, 50, 0.3);
}

/* Mobile-specific optimizations */
@media (max-width: 767.98px) {
    .comparison-container {
        border-radius: 10px;
        margin-bottom: 20px;
        box-shadow: 0 3px 15px rgba(0,0,0,0.08);
    }
    
    .comparison-table thead th {
        padding: 12px 8px;
        font-size: 0.85rem;
    }
    
    .comparison-table tbody td {
        padding: 12px 8px;
        font-size: 0.85rem;
    }
    
    .comparison-table tbody td:first-child {
        font-size: 0.9rem;
        font-weight: 600;
    }
    
    /* Reduce badge size for mobile */
    .badge {
        padding: 4px 8px;
        font-size: 0.7rem;
        gap: 3px;
        min-width: 55px;
    }
    
    .badge i {
        font-size: 14px;
    }
    
    /* Stack table columns on very small screens */
    @media (max-width: 575.98px) {
        .table-responsive {
            border: none;
            overflow-x: visible;
        }
        
        .comparison-table {
            display: block;
        }
        
        .comparison-table thead {
            display: none;
        }
        
        .comparison-table tbody,
        .comparison-table tr,
        .comparison-table td {
            display: block;
            width: 100%;
        }
        
        .comparison-table tr {
            margin-bottom: 15px;
            border: 1px solid #dee2e6;
            border-radius: 10px;
            overflow: hidden;
            padding: 0;
        }
        
        .comparison-table td {
            padding: 12px 15px;
            border-bottom: 1px solid #f0f0f0;
            position: relative;
            text-align: center;
        }
        
        .comparison-table td:last-child {
            border-bottom: none;
        }

	  .comparison-table tbody tr:first-child {
			border: 2px solid #f39c12;
			box-shadow: 0 6px 15px rgba(243, 156, 18, 0.2);

		}

       
        .comparison-table td:before {
            content: attr(data-label);
            font-weight: 600;
            color: #4a5568;
            display: block;
            font-size: 0.85rem;
            flex: 0 0 40%;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            background: #f7fafc;
            padding: 4px 8px;
            border-radius: 6px;
            margin-right: 10px;
        }
		
		
        .comparison-table td:first-child strong {
            font-size: 1.1rem;
            color: #2d3748;
            line-height: 1.3;
        }
        .comparison-table td:first-child:before {
            content: "Product";
        }
        
        .comparison-table td:nth-child(2):before {
            content: "Best For...";
        }
        
        .comparison-table td:nth-child(3):before {
            content: "Key Ingredient";
        }
        
        .comparison-table td:nth-child(4):before {
            content: "Verdict";
        }
		
        .comparison-table td:last-child .badge {
            width: 100%;
            justify-content: center;
            padding: 10px 16px;
            font-size: 0.9rem;
            border-radius: 8px;
        }
        
        .badge i {
            font-size: 20px;
        }
		
    }
}

/* Small tablet adjustments */
@media (min-width: 576px) and (max-width: 767.98px) {
    .comparison-table thead th,
    .comparison-table tbody td {
        padding: 10px 6px;
        font-size: 0.82rem;
    }
    
    .comparison-table tbody td:first-child {
        font-size: 0.88rem;
    }
}

/* Tablet adjustments */
@media (min-width: 768px) and (max-width: 991.98px) {
    .comparison-table thead th,
    .comparison-table tbody td {
        padding: 15px 8px;
        font-size: 0.88rem;
    }
    
    .comparison-table tbody td:first-child {
        font-size: 0.92rem;
    }
}















/* ===== RESPONSIVE STYLES ===== */
@media (max-width: 992px) {
    .content-article {
        padding-right: 0;
    }
    
    .choice-box {
        position: relative;
        top: 0 !important;
        margin-top: 40px;
    }
    
    .banner-heading {
        font-size: 2rem;
    }
    
    .sticky-footer .col-lg-3 {
        margin-top: 10px;
    }
}

@media (max-width: 768px) {
    .banner-section {
        padding: 20px 0;
    }
	.de3-page .banner-section {
        padding: 0px 0 20px;
    }
    
    .banner-heading {
        font-size: 1.75rem;
    }

	
	.banner-header{padding-bottom: 0}
    .de3-page .banner-header {
  padding-top: 15px;
  padding-bottom: 0px;
}
	
	
    .banner-paragraph {
        font-size: 1.125rem;
    }
	
	
	
	
	
	
	.header{text-align: center}
    .header .logo {
        max-width: 250px;
    }
    
    .footer-logo {
        max-width: 250px;
    }
    
    .sticky-footer {
        padding: 10px 0;
		z-index: 1050
    }
    
    .sticky-close {
        top: -30px;
        right: 10px;
    }
    
    .exit-modal-content {
        padding: 20px;
    }
    
    .exit-close {
        top: 10px;
        right: 15px;
        width: 35px;
        height: 35px;
        font-size: 20px;
    }
}

@media (max-width: 576px) {
.de3-page .banner-heading {
	font-size: 20px;
	line-height:1.3;
	font-weight: 600;
	margin-bottom: 10px;
}

.de3-page .banner-paragraph {
    font-size: 16px;
    line-height:1.3;
    }
    
    .banner-paragraph {
        font-size: var(--font-size-xs)
    }
    
    .content-article h2 {
        font-size: 1.5rem;
    }
    
    .content-article h3 {
        font-size: 1.25rem;
    }
    

    
    .sticky-footer .row > div {
        margin-bottom: 10px;
        text-align: center;
    }
    
    .sticky-footer img {
        max-width: 100px;
    }
}