/* ============================================
   thaihotgirls.com — Light Creamy Pink Theme
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=Noto+Sans+Thai:wght@300;400;500;600;700&family=Pacifico&display=swap');

:root {
  --bg-background: #faf5f7;
  --bg-background-alt: #f5edf1;
--bg-surface: #fffbfc;
--bg-surface-hover: #fff0f4;
  --bg-surface-50: rgba(255,240,245,0.5);
--bg-card: #fffbfc;
--bg-card-hover: #fff0f4;
  --bg-elevated: #ffffff;
  --bg-input: #fef9fb;
  --text-primary: #1a1a2e;
  --text-secondary: #555570;
  --text-muted: #9a8a9a;
  --color-primary: #ec4899;
  --color-primary-dark: #db2777;
  --color-primary-light: #f9a8d4;
  --color-purple: #a855f7;
  --color-purple-dark: #9333ea;
  --color-purple-light: #c4b5fd;
  --border-color: rgba(236,72,153,0.12);
  --border-light: rgba(236,72,153,0.08);
  --border-premium: rgba(236,72,153,0.25);
  --border-purple: rgba(168,85,247,0.15);
  --font-outfit: 'Outfit', sans-serif;
  --font-jakarta: 'Plus Jakarta Sans', sans-serif;
  --font-thai: 'Noto Sans Thai', sans-serif;
  --shadow-card: 0 1px 3px rgba(0,0,0,0.04), 0 4px 16px rgba(236,72,153,0.06);
  --shadow-card-hover: 0 8px 30px rgba(236,72,153,0.1), 0 2px 8px rgba(0,0,0,0.04);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.06);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.08);
  --glass-bg: rgba(255,255,255,0.82);
  --glass-border: rgba(236,72,153,0.1);
  --glass-shadow: 0 8px 32px rgba(236,72,153,0.06);
  --glow-pink: 0 0 20px rgba(236,72,153,0.1);
  --glow-purple: 0 4px 20px rgba(168,85,247,0.08);
  --gradient-pink: linear-gradient(135deg, #ec4899, #db2777);
  --gradient-purple-pink: linear-gradient(135deg, #a855f7, #ec4899);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-outfit);background:var(--bg-background);color:var(--text-primary);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}

::selection{background:#ec4899;color:#fff}

.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}
.top-0{top:0}.left-0{left:0}.right-0{right:0}.bottom-0{bottom:0}.top-3{top:12px}.top-full{top:100%}.bottom-2{bottom:8px}.bottom-3{bottom:12px}.right-2{right:8px}.right-3{right:12px}
.top-1\/2{top:50%}.left-2{left:8px}.top-2{top:8px}.left-4{left:16px}
.-z-10{z-index:-10}.z-50{z-index:50}.z-\[60\]{z-index:60}
.mx-auto{margin-left:auto;margin-right:auto}.mx-0{margin-left:0;margin-right:0}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-10{margin-bottom:40px}.mb-12{margin-bottom:48px}
.ml-2{margin-left:8px}
.block{display:block}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.flex{display:flex}
.grid{display:grid}.hidden{display:none}
.shrink-0{flex-shrink:0}.shrink{flex-shrink:1}
.h-2{height:8px}.h-2\.5{height:10px}.h-3{height:12px}.h-3\.5{height:14px}.h-4{height:16px}.h-5{height:20px}.h-7{height:28px}.h-9{height:36px}.h-10{height:40px}.h-16{height:64px}.h-px{height:1px}
.w-2{width:8px}.w-2\.5{width:10px}.w-3{width:12px}.w-3\.5{width:14px}.w-4{width:16px}.w-5{width:20px}.w-7{width:28px}.w-9{width:36px}.w-16{width:64px}.w-20{width:80px}.w-24{width:96px}.w-56{width:224px}.w-auto{width:auto}.w-full{width:100%}.w-max{width:max-content}
.max-w-7xl{max-width:1280px}.max-w-2xl{max-width:672px}.max-w-xl{max-width:576px}.max-w-6xl{max-width:1152px}.max-w-\[6rem\]{max-width:6rem}.max-w-\[200px\]{max-width:200px}.max-w-full{max-width:100%}
.min-w-0{min-width:0}
.h-\[58px\]{height:58px}
.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}
.grid-cols-\[auto_1fr_auto\]{grid-template-columns:auto 1fr auto}
.gap-1{gap:4px}.gap-1\.5{gap:6px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.gap-6{gap:24px}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}
.justify-center{justify-content:center}.justify-between{justify-content:space-between}
.justify-self-start{justify-self:start}.justify-self-center{justify-self:center}.justify-self-end{justify-self:end}
.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}
.rounded-md{border-radius:6px}.rounded-lg{border-radius:8px}.rounded-xl{border-radius:12px}.rounded-full{border-radius:9999px}.rounded-sm{border-radius:2px}
.border{border:1px solid var(--border-color)}.border-2{border-width:2px}
.border-border{border:1px solid var(--border-color)}.border-primary{border-color:var(--color-primary)}
.border-premium{border:1px solid var(--border-premium)}
.border-t{border-top:1px solid var(--border-color)}
.border-l{border-left:1px solid}
.border-border\/60{border-color:rgba(236,72,153,0.08)}
.border-primary\/30{border-color:rgba(236,72,153,0.3)}
.bg-background{background:var(--bg-background)}.bg-background-alt{background:var(--bg-background-alt)}.bg-background\/80{background:rgba(254,249,251,0.85)}
.bg-surface{background:var(--bg-surface)}.bg-surface\/50{background:var(--bg-surface-50)}
.bg-surface-hover{background:var(--bg-surface-hover)}.bg-primary{background:var(--color-primary)}
.bg-input\/30{background:rgba(236,72,153,0.04)}
.p-0{padding:0}.p-1{padding:4px}.p-2{padding:8px}.p-4{padding:16px}.p-5{padding:20px}.p-6{padding:24px}
.px-2{padding-left:8px;padding-right:8px}.px-2\.5{padding:10px}.px-3{padding:12px}.px-3\.5{padding:14px}.px-4{padding:16px}
.py-1{padding-top:4px;padding-bottom:4px}.py-2{padding-top:8px;padding-bottom:8px}.py-2\.5{padding-top:10px;padding-bottom:10px}.py-3{padding-top:12px;padding-bottom:12px}.py-5{padding-top:20px;padding-bottom:20px}.py-6{padding-top:24px;padding-bottom:24px}.py-8{padding-top:32px;padding-bottom:32px}.py-10{padding-top:40px;padding-bottom:40px}
.pl-2{padding-left:8px}.pl-3{padding-left:12px}.pl-4{padding-left:16px}.pl-11{padding-left:44px}.pr-10{padding-right:40px}.pb-1{padding-bottom:4px}.pb-2{padding-bottom:8px}.pb-16{padding-bottom:64px}
.text-left{text-align:left}.text-center{text-align:center}
.text-xs{font-size:12px}.text-sm{font-size:14px}.text-base{font-size:16px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-3xl{font-size:30px}.text-\[8\.5px\]{font-size:8.5px}.text-\[10px\]{font-size:10px}.text-\[12px\]{font-size:12px}
.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.uppercase{text-transform:uppercase}.italic{font-style:italic}
.leading-tight{line-height:1.25}.leading-relaxed{line-height:1.625}
.tracking-wider{letter-spacing:0.05em}.tracking-\[3px\]{letter-spacing:3px}
.text-white{color:#fff}
.text-text-primary{color:var(--text-primary)}.text-text-secondary{color:var(--text-secondary)}.text-text-muted{color:var(--text-muted)}.text-primary{color:var(--color-primary)}.text-purple{color:var(--color-purple)}
.placeholder\:text-text-muted::placeholder{color:var(--text-muted)}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-nowrap{white-space:nowrap}
.align-bottom{vertical-align:bottom}.align-self-center{align-self:center}
.select-none{user-select:none}
.pointer-events-none{pointer-events:none}
.object-cover{object-fit:cover}
.aspect-\[2\/3\]{aspect-ratio:2/3}
.ring-2{box-shadow:0 0 0 2px}.ring-primary\/30{box-shadow:0 0 0 2px rgba(236,72,153,0.3)}
.scale-105{transform:scale(1.05)}
.-translate-y-1\/2{transform:translateY(-50%)}
.transition-all{transition:all .2s}.transition-colors{transition:color .2s,background .2s}.transition-transform{transition:transform .2s}
.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}
.outline-none{outline:0}
.cursor-pointer{cursor:pointer}
.flex-col{flex-direction:column}.flex-wrap{flex-wrap}
.me-1{margin-inline-end:4px}
.scrollbar\:thin{scrollbar-width:thin}
.hover\:border-premium:hover{border-bottom-color:var(--border-premium);border-color:var(--border-premium)}
.hover\:glow-pink:hover{box-shadow:0 0 20px rgba(236,72,153,.12)}
.hover\:scale-\[1\.02\]:hover{transform:scale(1.02)}
.group:hover .group-hover\:scale-105{transform:scale(1.05)}

.glass-light{background:rgba(250,245,247,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(236,72,153,0.08)}
.glass-light .h-16{height:64px}@media(min-width:768px){.glass-light .md\:h-24{height:96px}}

[data-slot="button"]{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid;font-size:14px;font-weight:500;white-space:nowrap;transition:all .2s;outline:0;user-select:none;-webkit-appearance:none}
[data-slot="button"]:focus-visible{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(236,72,153,0.3)}
[data-slot="button"]:active:not([aria-haspopup]){transform:translateY(1px)}
[data-slot="button"]:disabled{pointer-events:none;opacity:.5}
.border-border[data-slot="button"]{border-color:var(--border-color);background:#fff;color:var(--text-secondary)}
.border-border[data-slot="button"]:hover{background:var(--bg-surface-hover);color:var(--text-primary)}

.lucide{display:inline-block;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.gradient-pink{background:linear-gradient(135deg,#ec4899,#db2777)}
.gradient-purple-pink{background:linear-gradient(135deg,#a855f7,#ec4899)}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-from),var(--tw-gradient-to))}
.from-primary\/20{--tw-gradient-from:rgba(236,72,153,0.2)}
.to-transparent{--tw-gradient-to:transparent}

.animated-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.mesh-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 20%,rgba(236,72,153,0.06) 0%,transparent 70%),radial-gradient(ellipse 60% 50% at 80% 80%,rgba(168,85,247,0.04) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 50% 50%,rgba(236,72,153,0.02) 0%,transparent 70%)}
.aurora{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;mix-blend-mode:screen;animation:auroraFloat 20s ease-in-out infinite}
.aurora-1{width:600px;height:600px;background:radial-gradient(circle,rgba(236,72,153,.08),transparent);top:-10%;left:-10%;animation-delay:0s}
.aurora-2{width:500px;height:500px;background:radial-gradient(circle,rgba(168,85,247,.06),transparent);bottom:-5%;right:-5%;animation-delay:-7s}
.aurora-3{width:400px;height:400px;background:radial-gradient(circle,rgba(236,72,153,.04),transparent);top:40%;left:50%;animation-delay:-14s}
@keyframes auroraFloat{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,10px) scale(.95)}75%{transform:translate(10px,30px) scale(1.02)}}
.color-ribbon{position:absolute;top:0;left:-20%;width:140%;height:2px;background:linear-gradient(90deg,transparent,#ec4899,#a855f7,transparent);animation:ribbonSweep 8s ease-in-out infinite;opacity:.4}
@keyframes ribbonSweep{0%,100%{transform:translateX(-30%)}50%{transform:translateX(30%)}}
.ambient-pulse{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(236,72,153,.03) 0%,transparent 60%);animation:ambientPulse 4s ease-in-out infinite}
@keyframes ambientPulse{0%,100%{opacity:.5}50%{opacity:1}}
.sparkle{position:absolute;width:3px;height:3px;border-radius:50%;background:#a855f7;opacity:0;animation:sparkle 4s ease-in-out infinite}
.sparkle-lg{width:4px;height:4px}
@keyframes sparkle{0%,100%{opacity:0;transform:scale(0)}50%{opacity:.5;transform:scale(1)}}
.bg-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;pointer-events:none}
.opacity-12{opacity:.04}

.glow-pink{box-shadow:0 0 20px rgba(236,72,153,.12)}
.glow-purple{box-shadow:0 4px 20px rgba(168,85,247,.08)}
.glow-premium-hover{box-shadow:0 0 30px rgba(236,72,153,.15)}
.card-hover-glow{box-shadow:0 8px 30px rgba(236,72,153,.1),0 0 20px rgba(168,85,247,.06)}
.shadow-card{box-shadow:0 1px 3px rgba(0,0,0,0.04),0 4px 16px rgba(236,72,153,0.06)}
.shadow-card-hover{box-shadow:0 8px 30px rgba(236,72,153,0.1),0 2px 8px rgba(0,0,0,0.04)}
.shadow-sm{box-shadow:0 1px 2px rgba(0,0,0,0.04)}
.drop-shadow-sm{filter:drop-shadow(0 1px 2px rgba(0,0,0,.06))}
.card-entry{opacity:0;animation:fadeInUp .5s ease forwards}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-pulse{animation:skeletonPulse 2s ease-in-out infinite}
@keyframes skeletonPulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes fadeEntry{to{opacity:1;transform:translateY(0)}}
.scroll-reveal{opacity:0;transform:translateY(10px);transition:all .6s ease-out}.scroll-reveal.revealed{opacity:1;transform:translateY(0)}
.group:hover .group-hover\:scale-105{transform:scale(1.05)}
.img-cover{position:absolute;height:100%;width:100%;left:0;top:0;right:0;bottom:0;object-fit:cover}

.flag-wrap{display:flex;align-items:center}
.flag-btn{display:flex;border-radius:4px;padding:4px;transition:all .2s;cursor:pointer;background:transparent;border:none;align-items:center;gap:4px}
.flag-btn.active{opacity:1;box-shadow:0 0 0 2px rgba(236,72,153,.3);transform:scale(1.05);border-radius:4px}
.flag-btn:not(.active){opacity:.5;filter:grayscale(1)}
.flag-btn:not(.active):hover{opacity:.8;filter:grayscale(0)}
.flag-svg{width:28px;height:20px;border-radius:2px;display:block;flex-shrink:0}
.load-more-wrap{margin-top:32px;display:flex;justify-content:center}
.load-more-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);font-size:14px;font-weight:500;padding:8px 16px;height:36px;gap:6px;transition:all .2s;outline:0;cursor:pointer}
.load-more-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary);box-shadow:var(--shadow-md)}
.load-more-btn:focus-visible{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(236,72,153,.3)}
.premium-scroll-outer{overflow:hidden;width:100%;padding:8px 0;background:linear-gradient(135deg,#fdf2f8,#fce7f3);transform-style:preserve-3d;contain:paint layout}
.premium-marquee{display:flex;will-change:transform;backface-visibility:hidden;perspective:1000px;transform:translate3d(0,0,0);animation:premiumScroll 10s linear infinite;isolation:isolate}
.premium-card{width:170px;flex-shrink:0;margin-right:14px;will-change:transform}
.premium-card{width:170px;flex-shrink:0;margin-right:14px}
@media(min-width:768px){.premium-card{width:200px;margin-right:16px}}
@media(min-width:1024px){.premium-card{width:240px;margin-right:18px}}
@keyframes premiumScroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-25%,0,0)}}
.girl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(min-width:640px){.girl-grid{gap:12px}}@media(min-width:768px){.girl-grid{grid-template-columns:repeat(4,1fr);gap:12px}}@media(min-width:1024px){.girl-grid{grid-template-columns:repeat(5,1fr);gap:16px}}
.site-footer{border-top:1px solid var(--border-color);background:var(--bg-background-alt)}
.site-footer-inner{margin:0 auto;max-width:1280px;padding:24px 16px}
.site-footer p{text-align:center;font-size:12px;color:var(--text-muted)}
@media(min-width:1024px){.site-footer-inner{padding:24px 32px}}
.section-container{margin:0 auto;max-width:1280px;padding:0 16px}@media(min-width:1024px){.section-container{padding:0 32px}}
.premium-radial-bg{position:absolute;inset:0;pointer-events:none;z-index:-1;background:radial-gradient(ellipse at center,rgba(168,85,247,0.03) 0%,transparent 70%)}
@media(min-width:768px){
  .md\:flex{display:flex}.md\:hidden{display:none}
  .md\:h-24{height:96px}
  .md\:grid-cols-4{grid-template-columns:repeat(4,1fr)}
  .md\:grid-cols-\[1fr_auto_1fr\]{grid-template-columns:1fr auto 1fr}
  .md\:gap-3\.5{gap:14px}
}
@media(min-width:1024px){
  .lg\:flex{display:flex}.lg\:hidden{display:none}
  .lg\:px-8{padding-left:32px;padding-right:32px}
  .lg\:py-14{padding-top:56px;padding-bottom:56px}
  .lg\:gap-4{gap:16px}
  .lg\:grid-cols-5{grid-template-columns:repeat(5,1fr)}
  .lg\:ml-2{margin-left:8px}
  .lg\:pl-3{padding-left:12px}
  .lg\:border-l{border-left:1px solid}
  .lg\:text-\[11px\]{font-size:11px}
  .lg\:font-medium{font-weight:500}
  .lg\:max-w-\[16rem\]{max-width:16rem}
  .lg\:h-16{height:64px}
  .xl\:h-20{height:80px}
}
@media(min-width:640px){
  .sm\:gap-3{gap:12px}
  .sm\:h-12{height:48px}
  .sm\:text-\[10px\]{font-size:10px}
  .sm\:text-xs{font-size:12px}
  .sm\:max-w-\[10rem\]{max-width:10rem}
}
.flex-wrap{flex-wrap:wrap}

/* ============================================
   Bootstrap Light Pink Theme Overrides
   ============================================ */

a{color:var(--color-primary)}
a:hover{color:#db2777}
.btn-link{color:var(--color-primary)}.btn-link:hover{color:#db2777}
.form-control:focus,.form-select:focus{border-color:rgba(236,72,153,0.4);box-shadow:0 0 0 3px rgba(236,72,153,0.12)}
.nav-link{color:var(--text-secondary)}.nav-link:hover,.nav-link.active{color:var(--color-primary)}
.text-primary{color:var(--color-primary)!important}
.border-primary{border-color:var(--color-primary)!important}
.bg-primary{background-color:var(--color-primary)!important}
.btn-outline-primary{color:var(--color-primary);border-color:var(--color-primary)}.btn-outline-primary:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.alert-info{background:rgba(236,72,153,0.92);color:#fff}
.list-group-item.active{background:var(--color-primary);border-color:var(--color-primary)}
.page-link{color:var(--color-primary)}.page-link:hover{color:#db2777}
.progress-bar{background-color:var(--color-primary)}

body {
  --bs-body-bg: var(--bg-background);
  --bs-body-color: var(--text-primary);
  --bs-body-font-family: var(--font-outfit);
  --bs-border-color: var(--border-color);
  --bs-card-bg: transparent;
  --bs-card-border-color: var(--border-color);
  --bs-card-cap-bg: transparent;
  --bs-card-cap-color: var(--text-primary);
  --bs-card-color: var(--text-primary);
}

.btn {
  --bs-btn-font-family: var(--font-outfit);
  border-radius: 8px;
  font-weight: 500;
  transition: all .2s;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0) !important; }

.btn-primary, .btn-gold {
  background: linear-gradient(135deg, #ec4899, #db2777);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 15px rgba(236,72,153,0.25);
}
.btn-primary:hover, .btn-gold:hover {
  background: linear-gradient(135deg, #f472b6, #ec4899);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 8px 30px rgba(236,72,153,0.35);
}

.btn-ghost {
  background: transparent;
  border-color: var(--border-color);
  color: var(--text-secondary);
}
.btn-ghost:hover {
  background: var(--bg-surface-hover);
  border-color: rgba(236,72,153,0.2);
  color: var(--text-primary);
}

.btn-outline-gold {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background: transparent;
}
.btn-outline-gold:hover {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

.form-control, .form-select {
  background: #fff;
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  border-radius: 6px;
}
.form-control:focus, .form-select:focus {
  background: #fff;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(236,72,153,0.1);
  color: var(--text-primary);
}
.form-control::placeholder { color: var(--text-muted); }
.form-control-lg { padding: 12px 16px; }
.form-label { color: var(--text-secondary); font-size: 14px; font-weight: 500; margin-bottom: 6px; }
.form-text { color: var(--text-muted); font-size: 12px; }
.form-check-input {
  background: #fff;
  border: 1px solid var(--border-color);
}
.form-check-input:checked {
  background-color: #ec4899;
  border-color: #ec4899;
}
.form-check-label { color: var(--text-secondary); font-size: 14px; }

.card-glass {
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--text-primary);
}
.card-glass:hover {
  background: rgba(255,255,255,0.95);
  border-color: rgba(236,72,153,0.15);
}

.page-header {
  padding: 40px 0 24px;
  background: var(--bg-background-alt);
  border-bottom: 1px solid var(--border-color);
}
.page-header h1 {
  font-weight: 700;
  font-size: 2rem;
  color: var(--text-primary);
}
@media (min-width: 768px) {
  .page-header { padding: 64px 0 32px; }
  .page-header h1 { font-size: 2.5rem; }
}

.section-padding { padding: 48px 0; }
.section-dark { background: var(--bg-background); }

.badge-premium {
  background: linear-gradient(135deg, #ec4899, #a855f7);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.badge-verified {
  color: #22c55e;
  font-size: 13px;
}
.badge-verified i { font-size: 16px; }
.badge-online {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #22c55e;
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(34,197,94,0.5);
}

.text-gold { color: var(--color-primary); }
.text-pink { color: #ec4899; }
.text-purple { color: #a855f7; }
.text-muted { color: var(--text-muted) !important; }
.gradient-text {
  background: linear-gradient(135deg, #ec4899, #a855f7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

a.text-pink:hover { color: #f472b6; }
a.text-purple:hover { color: #c4b5fd; }

.empty-state {
  text-align: center;
  padding: 48px 16px;
  color: var(--text-muted);
}
.empty-state i { font-size: 48px; display: block; margin-bottom: 16px; }

.profile-header {
  position: relative;
  padding-bottom: 0;
}
.profile-cover {
  height: 200px;
  background: linear-gradient(135deg, rgba(236,72,153,0.06), rgba(168,85,247,0.04));
  border-bottom: 1px solid var(--border-color);
}
@media (min-width: 768px) {
  .profile-cover { height: 300px; }
}
.profile-cover-alt {
  height: 180px;
  background: linear-gradient(135deg, #fce4ec, #f8bbd0);
  border-bottom: 1px solid var(--border-color);
}
@media (min-width: 768px) {
  .profile-cover-alt { height: 260px; }
}
.profile-main-photo {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid #fff;
  margin-top: -90px;
  box-shadow: 0 4px 20px rgba(236,72,153,0.12);
}
.profile-photo-wrap {
  filter: drop-shadow(0 4px 20px rgba(236,72,153,0.15));
}
.bg-green-50\/80 {
  background: rgba(240,253,244,0.85);
}
.text-green-700 {
  color: #15803d;
}
@media (min-width: 768px) {
  .profile-cover { height: 300px; }
}
.profile-main-photo {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid #fff;
  margin-top: -90px;
  box-shadow: 0 4px 20px rgba(236,72,153,0.12);
}

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: #f9f0f4; }
::-webkit-scrollbar-thumb { background: #e8c0d4; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #d4a0be; }

.dropdown-menu {
  background: #fff;
  border: 1px solid var(--border-color);
  box-shadow: 0 8px 24px rgba(236,72,153,0.08);
}
.dropdown-item {
  color: var(--text-secondary);
}
.dropdown-item:hover, .dropdown-item:focus {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.modal-content {
  background: #fff;
  border: 1px solid var(--border-color);
  color: var(--text-primary);
}
.modal-header { border-bottom-color: var(--border-color); }
.modal-footer { border-top-color: var(--border-color); }

.nav-link { color: var(--text-secondary); }
.nav-link:hover { color: var(--text-primary); }
.nav-tabs { border-bottom-color: var(--border-color); }
.nav-tabs .nav-link.active {
  background: transparent;
  border-color: var(--border-color);
  border-bottom-color: #fff;
  color: var(--color-primary);
}

.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--text-primary);
  --bs-table-border-color: var(--border-color);
  --bs-table-hover-bg: rgba(236,72,153,0.03);
  --bs-table-striped-bg: rgba(236,72,153,0.02);
}
.table>:not(:first-child) { border-top: 1px solid var(--border-color); }

.alert { border-radius: 8px; }
.alert-danger {
  background: rgba(239,68,68,0.06);
  border-color: rgba(239,68,68,0.12);
  color: #dc2626;
}
.alert-success {
  background: rgba(34,197,94,0.06);
  border-color: rgba(34,197,94,0.12);
  color: #15803d;
}
.alert-info {
  background: rgba(168,85,247,0.06);
  border-color: rgba(168,85,247,0.12);
  color: #7c3aed;
}
.alert-warning {
  background: rgba(245,158,11,0.06);
  border-color: rgba(245,158,11,0.12);
  color: #b45309;
}

.pagination {
  --bs-pagination-bg: #fff;
  --bs-pagination-border-color: var(--border-color);
  --bs-pagination-color: var(--text-secondary);
  --bs-pagination-hover-bg: var(--bg-surface-hover);
  --bs-pagination-hover-color: var(--text-primary);
  --bs-pagination-hover-border-color: var(--border-color);
  --bs-pagination-active-bg: var(--color-primary);
  --bs-pagination-active-border-color: var(--color-primary);
  --bs-pagination-active-color: #fff;
  --bs-pagination-disabled-bg: #fff;
  --bs-pagination-disabled-color: var(--text-muted);
}

.breadcrumb { background: transparent; }
.breadcrumb-item a { color: var(--text-secondary); }
.breadcrumb-item.active { color: var(--text-muted); }

.row { --bs-gutter-x: 1rem; }
@media (min-width: 768px) {
  .row { --bs-gutter-x: 1.5rem; }
}

.sticky-top { z-index: 10; }

.filter-range { display: flex; align-items: center; gap: 8px; }
.filter-range .form-control { width: 100%; }

.border-secondary { border-color: var(--border-color) !important; }

.premium-card {
  background: rgba(255,255,255,0.85);
  border-radius: 8px;
  border: 1px solid var(--border-premium);
  overflow: hidden;
  transition: all .2s;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.premium-card:hover {
  background: rgba(255,255,255,0.95);
  box-shadow: 0 8px 30px rgba(236,72,153,0.1);
}

.card {
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  color: var(--text-primary);
  transition: all .2s;
}
.card:hover {
  border-color: rgba(236,72,153,0.2);
  box-shadow: 0 8px 30px rgba(236,72,153,0.08);
}

.list-group-item {
  background: #fff;
  border-color: var(--border-color);
  color: var(--text-primary);
}
.list-group-item:hover {
  background: var(--bg-surface-hover);
}

.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:80px 16px 32px;background:var(--bg-background)}
.auth-card{width:100%;max-width:420px;margin:0 auto;padding:32px 28px;border-radius:16px;background:#fff;border:1px solid var(--border-color);box-shadow:0 4px 24px rgba(236,72,153,0.06)}
.auth-logo-wrap{text-align:center;margin-bottom:24px}
.auth-logo-wrap .logo{height:48px;width:auto}
.auth-card h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}
.auth-card .sub{font-size:0.875rem;color:var(--text-muted);margin:0}
.auth-field{margin-bottom:1rem}
.auth-field label{display:block;font-size:0.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:0.375rem}
.auth-field input[type="email"],.auth-field input[type="password"],.auth-field input[type="text"]{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border-color);font-size:0.875rem;color:var(--text-primary);background:var(--bg-background);transition:border-color .2s,box-shadow .2s;outline:none}
.auth-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(236,72,153,0.12)}
.auth-btn{width:100%;padding:12px;border:none;border-radius:8px;background:linear-gradient(135deg,#ec4899,#db2777);color:#fff;font-size:0.9375rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px rgba(236,72,153,0.25);margin-top:0.25rem}
.auth-btn:hover{background:linear-gradient(135deg,#f472b6,#ec4899);transform:translateY(-1px);box-shadow:0 8px 30px rgba(236,72,153,0.35)}
.auth-btn:active{transform:translateY(0)}
.auth-link{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color .2s}
.auth-link:hover{color:#db2777;text-decoration:underline}
.auth-switch{text-align:center;font-size:0.875rem;color:var(--text-muted);margin-top:1.25rem}
.auth-check{display:flex;align-items:center;gap:8px;font-size:0.875rem;color:var(--text-secondary);cursor:pointer}
.auth-check input[type="checkbox"]{accent-color:var(--color-primary);width:16px;height:16px;cursor:pointer}
.auth-hint{font-size:0.75rem;color:var(--text-muted);margin-top:4px}