/* XPages Application CSS */
.content-container {
    padding: 0 10px;
    box-sizing: border-box;
}
/* .models-grid {
    display: grid;
    grid-template-columns: repeat(
        auto-fill,
        minmax(220px, 1fr)
    );
    gap: 15px;
     z-index: 99999;
    margin:10px 10px;
     
    width: 100%;
} */

.models-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 15px;

    margin: 10px 0;   /* IMPORTANT */
    padding: 0;
}

/* .sliderWrap {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: #111;
	padding: 10px;
}
 */
/* .sliderTrack {
	display: flex;
	transition: transform 0.4s ease;
}
 */
.sliderTrack {
    display: flex;
    gap: 12px; /* replaces margin-right */
    	transition: transform 0.4s ease;
}
.slide {
	/* min-width: 220px; */
/* 	margin-right: 12px;
	  position: relative;
	background: #222;
	border-radius: 8px;
	overflow: hidden;
	color: white;
	text-align: center;
	flex-shrink: 0;
	display: inline-block;
	max-width:220px;
	background: rgba(88, 88, 88, 0.19);
border-radius: 8px;
box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
backdrop-filter: blur(7.7px);
-webkit-backdrop-filter: blur(7.7px);
border: 1px solid rgba(111, 111, 111, 0.35);

   */
/* 	max-height:200px; */
}

.slide {
    margin: 0;          /* remove drift */
    flex-shrink: 0;
    width: 220px;       /* replace max-width approach */
    
    background: #222;
	border-radius: 8px;
	overflow: hidden;
	color: white;
	text-align: center;
	flex-shrink: 0;
	display: inline-block;
	max-width:220px;
	background: rgba(88, 88, 88, 0.19);
border-radius: 8px;
box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
backdrop-filter: blur(7.7px);
-webkit-backdrop-filter: blur(7.7px);
border: 1px solid rgba(111, 111, 111, 0.35);
}

/* .slide {
    background: var(--card);
    border-radius: 14px;
    overflow: hidden;
    transition: .2s;
    cursor: pointer;
} */

.slide:hover {

    transform: translateY(-4px);
    transform: scale(1.4);
    z-index: 999;
    position: relative;
      box-shadow: 0 10px 30px rgba(0,0,0,0.5);
      	transition: transform 0.6s ease;
      
      	   cursor: pointer;
      	
      
      	   
      	background: rgba(111, 111, 111, 0.43);
border-radius: 8px;
box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
backdrop-filter: blur(4.7px);
-webkit-backdrop-filter: blur(4.7px);
border: 1px solid rgba(111, 111, 111, 0.96);   
}

/* .slide img {
	width: 211px;
	height: 110px;
	object-fit: cover;
	display: block;
} */

.slide img {
    width: 100%;
      position: relative;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
     transition: transform 0.25s ease-in-out;
    transform-origin: center center;
    	  cursor: pointer;
    	  z-index:1;
}


.slide:hover img {
	        transform: translateY(-1px);
    transform: scale(1.89);
   	  z-index:0;
    position: relative;
      box-shadow: 0 10px 30px rgba(0,0,0,0.5);
      	transition: transform 0.4s ease;
      
      	  cursor: pointer;
	
}
.modelNameHeader,
.cardBody,
.modelRow,
.modelRow2,
.modelRow3,
.roomSubject,
.modelMeta {

    position: relative;

    z-index: 5;

}
/* .slideTitle {
	padding: 8px;
	font-size: 14px;
	width: 160px;
}

.sliderButton {
	position: absolute;
	top: 40%;
	transform: translateY(-50%);
	background: rgba(0, 0, 0, .6);
	color: white;
	border: none;
	font-size: 28px;
	cursor: pointer;
	z-index: 10;
	padding: 10px;
}
 */
.prevBtn {
	left: 5px;
}

.nextBtn {
	right: 5px;
}

.cardBody {
	padding: 8px;
}
/* 
.modelRow {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 6px 8px;
}

.modelName {
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.modelMeta {
	margin-left: 8px;
	white-space: nowrap;
	font-size: 13px;
	color: #ccc;
} */

/* .roomSubject {
	font-size: 12px;
	line-height: 1.35;
	color: #bdbdbd;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: 32px;
} */
.roomSubject {

    display: -webkit-box;

   	  z-index:5;

   

    overflow: hidden;

    line-height: 1.4em;

    min-height: 2.8em;

    max-height: 2.8em;

    text-align: left;
     display: block;
    line-height: 1.4em;
    min-height: 2.8em;

}

.modelRow,
.metaRow {

    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 4px 0px 4px;
    font-size:larger;
}

.modelNameHeader {
    font-weight: 700;
    padding: 4px 10px 10px 4px;
       font-size:larger;
       margin-left: 10px;
       	  z-index:10;
}

.modelName {
    font-weight: 700;
}

.modelMeta {
   display: flex;

    align-items: center;

    gap: 8px;

    flex-wrap: wrap;
}
/* .modelMeta > * {

    display: inline-flex;

    align-items: center;

} */

.modelRow2,
.metaRow2 {
   padding: 4px 0px 0px 4px;
    text-align: left;
    font-size:smaller;
    color:lightgray;
}

.modelRow3,
.metaRow3 {
   padding: 4px 0px 10px 4px;
    text-align: left;
    font-size: smaller;
    color: darksalmon;
}

.modelMeta3 {
    display: flex;
    gap: 8px;
}


.genderIcon {
    font-size: 16px;
    margin-right: 6px;
}

.gender-f {
    color: #ff5ba7;
}

.gender-m {
    color: #4ea3ff;
}

.gender-c {
    color: #b388ff;
}

.gender-t {
    color: #4dd0e1;
}



.genderButton {

    display: inline-flex;

    align-items: center;

    gap: 8px;

    padding: 10px 18px;

    border-radius: 12px;

    background: #202020;

    color: #ffffff;

    text-decoration: none;

    font-weight: 600;

    transition: all .2s ease;
}


.genderButton xp\\:text,
.genderButton .counter {

    margin-left: auto;

}
.genderButton:hover {

    transform: translateY(-2px);

    background: #2d2d2d;

    box-shadow: 0 0 15px rgba(255,91,167,.4);

}

.genderButton .fa-venus {

    color: #ff5ba7;

    font-size: 18px;
}
.genderButton .fa-transgender{

     color: #4dd0e1;

    font-size: 18px;
}
.genderButton .fa-user-group{

    

    font-size: 18px;
}
.hdBadge {

   /*  display:inline-flex; */

    align-items:center;

    gap:4px;

    padding:3px 8px;

    border-radius:20px;

    font-size:11px;

    font-weight:700;

    color:#00ff88;

    border:1px solid rgba(0,255,136,.35);

    background:rgba(0,255,136,.08);

    box-shadow:

        0 0 8px rgba(0,255,136,.35);

}
.hdIcon {

     font-size: 10px;

    line-height: 1;

    display: inline-flex;

    align-items: center;

    text-shadow:
        0 0 6px rgba(0,255,136,.6),
        0 0 14px rgba(0,255,136,.35);

    animation: hdPulse 2s ease-in-out infinite;

}

@keyframes hdPulse {

    0% {
        transform: scale(1);
        opacity: .8;
    }

    50% {
        transform: scale(1.15);
        opacity: 1;
    }

    100% {
        transform: scale(1);
        opacity: .8;
    }

}
.online-banner {
    display: flex;
    align-items: center;

    margin: 10px 0;   /* IMPORTANT: no left/right margin */
    padding: 10px 18px;

    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 9px;

    color: var(--text);
    font-size: 1.1rem;
    font-weight: 700;
}

.online-banner::before {
    content: "";
    width: 10px;
    height: 10px;

    border-radius: 50%;

    background: #ff4d4d;

    margin-right: 10px;

    box-shadow: 0 0 10px #ff4d4d;
}


.roomStatus::before {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    text-align: left;
}

.roomStatus.public::before {
  /*   content: "\f111";   fa-circle */
    color: #2ecc71;
}

.roomStatus.private::before {
    content: "\f023";   /* fa-lock */
    color: #e74c3c;
}

.roomStatus.away::before {
    content: "\f186";   /* fa-moon */
    color: #f1c40f;
}

.roomStatus.hidden::before {
    content: "\f070";   /* fa-eye-slash */
    color: #7f8c8d;
}

.roomStatus.group::before {
    content: "\f0c0";   /* fa-users */
    color: #3498db;
}

.roomStatus.ticket::before {
    content: "\f145";   /* fa-ticket */
    color: #9b59b6;
}


.modelHeader {
    display: flex;
    align-items: center;
    width: 100%;
}

.headerSpacer {
    width: 18px;          /* same width as icon */
    flex-shrink: 0;
}

.modelNameTop {
    flex: 1;
    text-align: center;
    font-weight: 700;
    color: white;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    
    
    padding: 4px 10px 10px 4px;
       font-size:larger;
    
       	  z-index:10;
}

.roomStatus {
    width: 18px;
    text-align: center;
    flex-shrink: 0;
}

.roomStatus::before {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
}

/* .roomStatus.public::before  { content: "\f111"; color:#2ecc71; }  *//* circle */
.roomStatus.private::before { content: "\f023"; color:#e74c3c; } /* lock */
.roomStatus.away::before    { content: "\f186"; color:#f1c40f; } /* moon */
.roomStatus.hidden::before  { content: "\f070"; color:#7f8c8d; } /* eye-slash */
.roomStatus.group::before   { content: "\f0c0"; color:#3498db; } /* users */
.roomStatus.ticket::before  { content: "\f145"; color:#9b59b6; } /* ticket */
:root {
	--primaryold: #8e6525;
	--primary: #e84356;
	--primary-hoverold: #a8792d;
	--primary-hover: #9a67eef1;
	--bg: #0f1117;
	--header: #181b23;
	--card: #20242e;
	--card-new: #9a67eef1;
	--text: #ffffff;
	--muted: #b7b7b7;
	--border: #2e3440;
	--radius: 14px;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: Inter, system-ui, sans-serif;
	background: var(--bg);
	color: var(--text);
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

tbody {
	font-family: Inter, system-ui, sans-serif;
	background: var(--bg);
	color: var(--text);
	padding: 0px;
}

td {
	padding: 0px !important;
}

/* main {
	flex: 1;
 	max-width: 1920px; 
	width: 100%;
	margin: auto;
	padding: 40px 24px;
	display: block;
} */

table {
    width: 100%;
    background: var(--card);
    color: var(--text);
    border-collapse: collapse;
    border-radius: var(--radius);
    overflow: hidden;
}

/* cells */
table td,
table th {
    padding: .75rem;
    vertical-align: top;
    border-top: 1px solid var(--border);
    background: var(--card);
    color: var(--text);
    border-top: 1px solid var(--bg)!important;
}

/* header row */
table th {
    background: var(--header);
    color: var(--text);
    font-weight: 600;
}

/* row hover */
table tr:hover td {
    background: rgba(142, 101, 37, 0.12);
    transition: background 0.15s ease;
}

/* optional zebra striping */
table tr:nth-child(even) td {
    background: rgba(255, 255, 255, 0.02);
}

main {
	flex: 1;
	width: 100%;
	max-width: 100%;
	padding: 0px;
	margin: 0 auto;
}

@media ( max-width : 900px) {
	.footer-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media ( max-width : 600px) {
	.footer-grid {
		grid-template-columns: 1fr;
	}
}

/* MOBILE */
@media ( max-width : 900px) {
	.header-container {
		flex-wrap: wrap;
	}
	.search-area {
		order: 3;
		width: 100%;
	}
	.nav-actions {
		display: none;
	}
	.nav-actions.active {
		display: flex;
		width: 100%;
		flex-direction: column;
		align-items: stretch;
		margin-top: 10px;
	}
	.mobile-toggle {
		display: block;
		margin-left: auto;
	}
	.nav-btn {
		justify-content: center;
	}
}
:root {
	--primary: #8e6525;
	--primary-light: #b68639;
	--primary-dark: #5b4018;
	--bg: #111111;
	--panel: #1b1b1b;
	--panel2: #242424;
	--text: #ffffff;
	--muted: #bbbbbb;
}

header {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	z-index: 500;
	padding: 20px 50px;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.85),
		rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
}

.headerRow {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.left {
	display: flex;
	align-items: center;
	gap: 40px;
}

/* .logo {
	font-size: 34px;
	font-weight: bold;
	color: #d7a047;
	letter-spacing: 2px;
} */
.logo span {
	color: var(--primary);
}

.logo span {
	font-size: 1.5rem;
	font-weight: 300;
	margin-left: 5px;
}
/* .logo {
    display: flex;
    align-items: center;
}
 */
.logo {
	grid-column: 1;
	grid-row: 1/span 2;
	display: flex;
	align-items: center;
	gap: 10px;
}

.logo img {
	height: 48px; /* adjust as needed */
	width: auto;
	display: block;
}

.logo img:first-child {
	height: 80px;
}

.logo img:last-child {
	height: 40px;
}

.logo span img {
	height: 5px; /* adjust as needed */
	width: auto;
	display: block;
}

.mainNav {
	display: flex;
	gap: 28px;
}

.mainNav a {
	text-decoration: none;
	color: var(--text);
	font-weight: 600;
	transition: 0.25s;
}

.mainNav a:hover {
	color: var(--primary);
}

nav a {
	color: white;
	text-decoration: none;
	font-size: 15px;
	transition: 0.25s;
}

nav a:hover {
	color: #d7a047;
}

.right {
	display: flex;
	align-items: center;
	gap: 15px;
}

.search {
	width: 220px;
	padding: 10px 15px;
	background: rgba(255, 255, 255, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.15);
	color: white;
	border-radius: 25px;
}

.search::placeholder {
	color: #ccc;
}

.button {
	padding: 10px 22px;
	border-radius: 30px;
	border: none;
	cursor: pointer;
	background: #d7a047;
	color: #111;
	font-weight: bold;
}

/******************************
 HERO
******************************/
.hero {
	position: relative;
	height: 720px;
	overflow: hidden;
}

.repeatImage {
	min-width: 1000px;
	/* min-height:800px; */
	width: stretch;
	/* height:900px; */
	inset: 0;
	
}

.slideHeader {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 1s;
	background-size: cover;
	background-position: center;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.35),
		rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.75));
}

.slideHeader.active {
	opacity: 1;
}

.slideHeader::before {
	  content:"";
    position:absolute;
    inset:0;

    background:
        linear-gradient(
            to bottom,
            rgba(0,0,0,.75),
            rgba(0,0,0,.35),
            rgba(0,0,0,.85)
        ),
        rgba(0,0,0,.20);
}

.contentHeader {
	position: absolute;
	left: 70px;
	bottom: 130px;
	width: 650px;
	z-index: 20;
}

.contentHeader h1 {
	font-size: 65px;
	margin-bottom: 20px;
	line-height: 62px;
}

.contentHeader p {
	font-size: 20px;
	line-height: 1.6;
	color: #ddd;
}

.watch {
	margin-top: 35px;
	padding: 14px 35px;
	border: none;
	cursor: pointer;
	background: #d7a047;
	color: #111;
	font-size: 18px;
	border-radius: 40px;
}

/******************************
DOTS
******************************/
.dots {
	position: absolute;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 10px;
	z-index: 100;
}

.dot {
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background: #888;
	cursor: pointer;
}

.dot.active {
	background: #fff;
}

/******************************/
section {
	padding: 60px;
}

.cardsHeader {
	display: flex;
	gap: 20px;
}

.cardHeader {
	height: 180px;
	flex: 1;
	background: #333;
	border-radius: 10px;
}

.hamburger {
	display: none;
	width: 40px;
	height: 40px;
	cursor: pointer;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	gap: 6px;
}

.hamburger span {
	width: 26px;
	height: 3px;
	border-radius: 4px;
	background: var(--text);
	transition: 0.3s;
}

.hamburger.active span:nth-child(1) {
	transform: rotate(45deg) translate(6px, 6px);
}

.hamburger.active span:nth-child(2) {
	opacity: 0;
}

.hamburger.active span:nth-child(3) {
	transform: rotate(-45deg) translate(7px, -7px);
}

header {
	transition: 0.35s;
}

header.scrolled {
	position: fixed;
	background: rgba(17, 17, 17, 0.94);
	backdrop-filter: blur(20px);
	box-shadow: 0 5px 25px rgba(0, 0, 0, 0.4);
}

@media ( max-width : 900px) {
	header {
		padding: 20px;
	}
	.hamburger {
		display: flex;
	}
	.mainNav {
		position: absolute;
		left: 0;
		top: 100%;
		width: 100%;
		background: rgba(15, 15, 15, 0.96);
		backdrop-filter: blur(18px);
		display: flex;
		flex-direction: column;
		padding: 20px;
		gap: 20px;
		transform: translateY(-25px);
		opacity: 0;
		visibility: hidden;
		transition: 0.35s;
	}
	.mainNav.show {
		transform: translateY(0);
		opacity: 1;
		visibility: visible;
	}
	/*
                .right {
                    display: none;
                }
*/
	.logo {
		font-size: 28px;
	}
	.contentHeader {
		width: 90%;
		left: 30px;
		bottom: 90px;
	}
	.contentHeader h1 {
		font-size: 42px;
	}
	.contentHeader p {
		font-size: 18px;
	}
	.hero {
		height: 600px;
	}
}

@media ( max-width : 900px) {
	.headerRow {
		align-items: flex-start;
	}
	.right {
		position: absolute;
		top: 72px;
		left: 0;
		width: 100%;
		padding: 20px;
		display: flex;
		flex-direction: column;
		gap: 15px;
		background: rgba(15, 15, 15, 0.96);
		backdrop-filter: blur(18px);
		transform: translateY(-20px);
		opacity: 0;
		visibility: hidden;
		transition: 0.35s;
	}
	.right.show {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}
	.search {
		width: 100%;
	}
	.button {
		width: 100%;
	}
	.mainNav {
		position: absolute;
		top: 180px; /* sits below search + login */
		left: 0;
		width: 100%;
		padding: 20px;
		display: flex;
		flex-direction: column;
		gap: 20px;
		background: rgba(15, 15, 15, 0.96);
		backdrop-filter: blur(18px);
		opacity: 0;
		visibility: hidden;
		transform: translateY(-20px);
		transition: 0.35s;
	}
	.mainNav.show {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}
}
/* FOOTER */
footer {
	background: var(--header);
	border-top: 1px solid var(--border);
	padding: 20px;
	text-align: center;
	color: var(--muted);
}

footer {
	background: #181b23;
	border-top: 1px solid #2e3440;
	padding: 40px 24px;
}

.footer-container {
	max-width: 1400px;
	margin: auto;
}

.footer-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px;
	margin-bottom: 30px;
}

.footer-grid h4 {
	margin-bottom: 15px;
	color: #8e6525;
}

.footer-grid a {
	display: block;
	color: #b7b7b7;
	text-decoration: none;
	padding: 4px 0;
}

.footer-grid a:hover {
	color: white;
}

.footer-links {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	padding: 25px 0;
	border-top: 1px solid #2e3440;
	border-bottom: 1px solid #2e3440;
}

.footer-links a {
	text-decoration: none;
	color: #b7b7b7;
}

.footer-links a:hover {
	color: white;
}

.compliance {
	text-align: center;
	padding: 25px 0;
}

.trust-badges {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 15px;
	margin-top: 20px;
}

.badge {
	padding: 10px 18px;
	border: 1px solid #2e3440;
	border-radius: 12px;
}

.copyright {
	text-align: center;
	color: #888;
	margin-top: 20px;
}
