@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Sans+Thai:wght@300;400;500;600;700&family=Noto+Sans+Lao:wght@300;400;500;700&family=Noto+Sans+SC:wght@400;500;700&display=swap";:root{--primary:#e84393;--primary-gradient:linear-gradient(135deg, #f43f5e, #8b5cf6);--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--nav-height:64px;--header-height:56px;--font-th:"Noto Sans Thai", "Inter", sans-serif;--font-lo:"Noto Sans Lao", "Inter", sans-serif;--font-zh:"Noto Sans SC", "Inter", sans-serif;--font-default:"Inter", sans-serif}:root,[data-theme=light]{--background:oklch(98.5% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--secondary:oklch(96% 0 0);--secondary-foreground:oklch(14.5% 0 0);--muted:oklch(96% 0 0);--muted-foreground:oklch(45% 0 0);--accent:oklch(96% 0 0);--accent-foreground:oklch(14.5% 0 0);--border:oklch(90% 0 0);--input:oklch(90% 0 0);--ring:oklch(50% 0 0);--bg:var(--background);--bg-card:var(--card);--bg-elevated:oklch(97% 0 0);--bg-input:var(--input);--text-primary:var(--foreground);--text-secondary:var(--muted-foreground);--text-muted:oklch(60% 0 0);--shadow-glow:0 4px 15px #0000000d;--border-color:oklch(90% 0 0);--input-primary:oklch(90% 0 0)}[data-theme=dark]{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(18% .01 260);--card-foreground:oklch(98.5% 0 0);--popover:oklch(14.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--border:oklch(26.9% 0 0);--input:oklch(26.9% 0 0);--ring:oklch(43.9% 0 0);--bg:var(--background);--bg-card:var(--card);--bg-elevated:oklch(22% .01 260);--bg-input:var(--input);--text-primary:var(--foreground);--text-secondary:var(--muted-foreground);--text-muted:oklch(50% 0 0);--shadow-glow:0 0 20px #e8439333;--border-color:oklch(26.9% 0 0);--input-primary:oklch(90% 0 0)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);font-family:var(--font-th);-webkit-font-smoothing:antialiased;min-height:100dvh;font-size:15px;line-height:1.6}body[data-lang=en]{font-family:var(--font-default)}body[data-lang=lo]{font-family:var(--font-lo)}body[data-lang=zh]{font-family:var(--font-zh)}body[data-lang=vi]{font-family:var(--font-default)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{outline:none;font-family:inherit}.MuiTypography-root,.MuiButton-root,.MuiButtonBase-root,.MuiInputBase-root,.MuiTreeItem-root,.MuiTreeItem-label,.MuiTreeItem-content,.MuiTreeItem-iconContainer{font-family:inherit!important}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app-layout{flex-direction:column;width:100%;height:100dvh;margin:0 auto;display:flex;position:relative}@media (width>=1024px){.app-layout{max-width:1280px;padding:0 20px}}@media (width<=768px){.page-content{padding-bottom:var(--nav-height);flex:1;overflow-y:auto}}.page-content{-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.page-content-nopad{flex:1;overflow-y:auto;padding-bottom:0!important}.page-container{padding:16px}.app-header{z-index:400;height:var(--header-height);background:var(--bg);color:var(--text-primary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.page-header,.page-header-desktop{border-bottom:2px solid var(--primary);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex!important}@media (width<=767px){.page-header-desktop{display:none!important}.page-header-mobile{display:block!important}}.page-header-mobile{border-bottom:2px solid var(--primary);margin-bottom:20px;display:none}.desktop-title{color:var(--text-primary);margin:0;font-size:24px;font-weight:800}.header-title{background:var(--primary-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}@media (width>=768px){.app-header{display:none}}.bottom-nav{width:100%;max-width:480px;height:var(--nav-height);background:var(--bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-top:1px solid var(--border);z-index:200;justify-content:space-around;align-items:center;padding:0 4px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}@media (width>=768px){.bottom-nav{display:none}}.top-nav{background:var(--bg);border-bottom:1px solid var(--border);z-index:300;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);height:72px;display:none;position:sticky;top:0}@media (width>=768px){.top-nav{justify-content:space-between;align-items:center;padding:0 40px;display:flex}}.top-nav-logo{align-items:center;gap:10px;font-size:22px;font-weight:800;display:flex}.top-nav-links{align-items:center;gap:30px;display:flex}.top-nav-link{color:var(--text-secondary);align-items:center;gap:8px;font-weight:600;transition:color .2s;display:flex}.top-nav-link:hover,.top-nav-link.active{color:var(--primary)}.nav-item{border-radius:var(--radius);color:var(--text-muted);flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 12px;font-size:10px;font-weight:500;transition:all .2s;display:flex;position:relative}.nav-item.active{color:var(--primary)}.nav-item.active svg{filter:drop-shadow(0 0 6px #e8439399)}.nav-badge{background:var(--primary);color:#fff;text-align:center;border-radius:9999px;min-width:16px;padding:1px 5px;font-size:9px;font-weight:700;position:absolute;top:4px;right:8px}.btn{color:var(--text-primary);border-radius:var(--radius-full);white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary-gradient);color:#fff;border:none;font-weight:700;box-shadow:0 4px 15px #e8439340}.btn-primary:active{opacity:.9;transform:scale(.97)}.btn-outline{border:1px solid var(--border);color:var(--foreground);background:0 0}.btn-outline:hover{background:var(--bg-elevated);border-color:var(--muted-foreground)}.btn-ghost{color:var(--foreground);background:0 0}.btn-ghost:hover{color:var(--foreground);background:#ffffff0d}.btn-danger{background:var(--destructive);color:#fff}.btn-sm{height:34px;padding:6px 12px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-icon{border-radius:50%;justify-content:center;width:40px;height:40px;padding:0}.btn-full{color:var(--text-primary);justify-content:center;width:100%}.fab-button{bottom:calc(var(--nav-height) + 16px);background:var(--primary-gradient);color:#fff;z-index:500;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s;display:flex;position:fixed;right:16px;box-shadow:0 4px 12px #e8439366}.fab-button:active{transform:scale(.9)}@media (width>=768px){.fab-button{display:none}}.grid-responsive{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width>=768px){.grid-responsive{grid-template-columns:repeat(3,1fr);gap:20px}}@media (width>=1200px){.grid-responsive{grid-template-columns:repeat(4,1fr);gap:24px}}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);transition:transform .2s,box-shadow .2s;overflow:hidden}.card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.card-body{color:var(--text-primary);padding:16px}.listing-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);cursor:pointer;flex-direction:column;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.listing-card:hover{border-color:oklch(50% .1 340);transform:translateY(-4px);box-shadow:0 12px 30px #00000080}.listing-card-image-wrap{aspect-ratio:1/1.1;background:var(--bg-elevated);width:100%;position:relative;overflow:hidden}.listing-card-photo{object-fit:cover;width:100%;height:100%;transition:transform .5s}.listing-card:hover .listing-card-photo{transform:scale(1.05)}.listing-card-photo-placeholder{background:linear-gradient(135deg, var(--bg-elevated), var(--bg-card));justify-content:center;align-items:center;width:100%;height:100%;display:flex}.listing-card-stamp{letter-spacing:.05em;color:#fff;z-index:10;border-radius:6px;width:fit-content;padding:3px 8px;font-size:8px;font-weight:800}.listing-card-stamp.verified{background:#0ea5e9}.listing-card-stamp.agent{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.listing-card-stamp.vip{background:linear-gradient(135deg,#f59e0b,#ea580c);box-shadow:0 0 10px #f59e0b66}.listing-card-info{flex-direction:column;flex-grow:1;gap:8px;padding:12px;display:flex}.heart-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;z-index:20;background:#0006;border-radius:8px;align-items:center;gap:4px;padding:4px 8px;font-size:13px;font-weight:700;display:flex}.heart-overlay.card-mode{padding:2px 6px;font-size:11px}.listing-card-user{align-items:center;gap:8px;display:flex}.listing-card-avatar{object-fit:cover;border:1.5px solid var(--border);border-radius:50%;width:32px;height:32px}.listing-card-avatar-placeholder{background:var(--bg-elevated);width:32px;height:32px;color:var(--muted-foreground);border:1.5px solid var(--border);border-radius:50%;justify-content:center;align-items:center;display:flex}.listing-card-user-details{flex:1;min-width:0}.listing-card-nickname{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:4px;font-size:14px;font-weight:600;display:flex;overflow:hidden}.listing-card-age{color:var(--muted-foreground);font-size:12px;font-weight:400}.listing-card-rating{color:var(--warning);align-items:center;gap:3px;font-size:11px;font-weight:600;display:flex}.listing-card-reviews{color:var(--muted-foreground);margin-left:1px;font-weight:400}.listing-card-title{color:var(--foreground);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:12px;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.listing-card-footer{justify-content:space-between;align-items:center;margin-top:auto;padding-top:4px;display:flex}.listing-card-meta{color:var(--muted-foreground);align-items:center;gap:4px;font-size:11px;display:flex}.listing-card-tags{flex-wrap:wrap;gap:4px;display:flex}.tag-pill{background:var(--bg-elevated);border:1px solid var(--border);color:var(--muted-foreground);border-radius:6px;padding:2px 8px;font-size:10px}.listing-card-actions{border-top:1px solid var(--border);gap:8px;padding:12px;display:flex}.stamp-badge{border-radius:var(--radius-full);align-items:center;gap:3px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.stamp-verified{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 0 8px #3b82f64d}.stamp-vip{color:#fff;background:linear-gradient(135deg,#f59e0b,#ea580c);box-shadow:0 0 8px #f59e0b66}.stamp-agent{color:#fff;background:linear-gradient(135deg,#8b5cf6,#6d28d9);box-shadow:0 0 8px #8b5cf666}.tag{border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);align-items:center;padding:3px 10px;font-size:11px;font-weight:500;display:inline-flex}.tag-primary{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.listing-card-stamps-mobile{display:flex!important}.listing-card-stamps-desktop{display:none!important}@media (width>=768px){.listing-card-stamps-mobile{display:none!important}.listing-card-stamps-desktop{align-items:center;gap:4px;display:inline-flex!important}}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);padding:12px 16px;font-size:15px;transition:border-color .2s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #e8439326}.form-input::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23a891c8' viewBox='0 0 20 20'%3E%3Cpath d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px}.form-error{color:var(--danger);margin-top:4px;font-size:12px}.stars{gap:2px;display:flex}.star{color:#f59e0b;font-size:14px}.star-empty{color:var(--border-light);font-size:14px}.avatar{object-fit:cover;background:var(--bg-elevated);border-radius:50%;flex-shrink:0}.avatar-sm{width:36px;height:36px}.avatar-md{width:48px;height:48px}.avatar-lg{width:72px;height:72px}.avatar-xl{width:96px;height:96px}.avatar-placeholder{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.action-bar{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.action-btn{border-radius:var(--radius);color:var(--text-secondary);background:var(--bg-elevated);border:1.5px solid var(--border);flex-direction:column;align-items:center;gap:4px;padding:10px 8px;font-size:11px;font-weight:500;transition:all .2s;display:flex}.action-btn.active-like{color:#ef4444;background:#ef44441a;border-color:#ef4444}.action-btn.active-save{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b}.action-btn.active-follow{color:var(--secondary);border-color:var(--secondary);background:#7c3aed1a}.action-btn.chat{color:#fff;border-color:var(--primary);background:linear-gradient(135deg, var(--primary), var(--secondary))}.chat-bubble{border-radius:var(--radius-lg);overflow-wrap:break-word;word-break:normal;white-space:pre-wrap;width:max-content;min-width:60px;max-width:100%;padding:10px 16px;font-size:14.5px;line-height:1.4;display:block}.chat-bubble-mine{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-bottom-right-radius:4px;margin-left:auto}.chat-bubble-other{background:var(--bg-elevated);color:var(--text-primary);border-bottom-left-radius:4px}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.gradient-text{background:var(--primary-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state-icon{margin-bottom:12px;font-size:48px}.empty-state-title{color:var(--text-secondary);margin-bottom:8px;font-size:18px;font-weight:700}.empty-state-text{font-size:14px}.grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.spinner{border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{justify-content:center;align-items:center;min-height:200px;display:flex}.toast-container{font-family:inherit!important}.section-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:12px;font-size:16px;font-weight:700;display:flex}.chip-group{flex-wrap:wrap;gap:6px;display:flex}.chip{border-radius:var(--radius-full);border:1.5px solid var(--border);color:var(--text-secondary);background:var(--bg-input);cursor:pointer;padding:5px 12px;font-size:12px;font-weight:500;transition:all .15s}.chip.selected{border-color:var(--primary);color:var(--primary);background:#e843931f}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;background:#000000b3;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border);width:100%;max-width:480px;padding:20px 20px calc(env(safe-area-inset-bottom) + 20px);max-height:90dvh;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;overflow-y:auto}.modal-handle{background:var(--border-light);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s ease-in-out infinite pulse}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-elevated) 50%, var(--bg-card) 75%);border-radius:var(--radius);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{to{background-position:-200% 0}}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-online{background:var(--success);box-shadow:0 0 4px var(--success)}.status-offline{background:var(--text-muted)}.stars-picker{gap:6px;display:flex}.star-pick{cursor:pointer;font-size:28px;transition:transform .15s}.star-pick:hover,.star-pick.active{transform:scale(1.2)}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.admin-table th{color:var(--text-secondary);background:var(--bg-elevated);font-weight:600}.admin-table tr:hover td{background:#ffffff05}.detail-layout{align-items:start;gap:24px;display:grid}@media (width>=1024px){.detail-layout{grid-template-columns:1fr 340px}}.detail-sidebar{top:calc(var(--header-height) + 20px);flex-direction:column;gap:20px;display:flex;position:sticky}.detail-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;padding:24px}.detail-section-title{color:var(--foreground);margin-bottom:16px;font-size:18px;font-weight:700}.user-summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:24px}.user-summary-avatar-wrap{width:96px;height:96px;margin:0 auto 16px;position:relative}.user-summary-avatar{object-fit:cover;border:2px solid var(--border);border-radius:50%;width:100%;height:100%}.user-summary-badge{background:#fff;border-radius:50%;padding:2px;display:flex;position:absolute;bottom:0;right:0}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}@keyframes vibrate{0%{transform:translate(0)}25%{transform:translate(-1px,1px)}50%{transform:translate(1px,-1px)}75%{transform:translate(-1px,-1px)}to{transform:translate(0)}}.animate-pop{animation:.4s cubic-bezier(.175,.885,.32,1.275) pop}.btn-loading{opacity:.7!important;cursor:not-allowed!important;pointer-events:none!important}.btn-vibrate{animation:.15s linear infinite vibrate}.heart-pop{filter:drop-shadow(0 0 8px #e8439399);color:#e84393!important}.phone-input-container{width:100%;align-items:stretch!important;display:flex!important}.phone-input-container .PhoneInputInput{background:var(--bg-input);border:1.5px solid var(--border);color:var(--text-primary);border-radius:0 12px 12px 0;flex:1;min-height:48px;padding:12px 16px;font-size:15px;transition:all .2s}.phone-input-container .PhoneInputInput:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #e8439326}.phone-input-container .PhoneInputCountry{background:var(--bg-elevated);border:1.5px solid var(--border);border-right:none;border-radius:12px 0 0 12px;align-items:center;padding:0 12px;display:flex;margin:0!important}.PhoneInputCountrySelectArrow{opacity:.5;color:var(--text-primary);margin-left:6px}.PhoneInputCountryIcon{border-radius:2px;box-shadow:0 0 4px #0000004d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.top-progress-bar-container{z-index:9999;pointer-events:none;background:0 0;width:100%;height:3px;position:fixed;top:0;left:0;overflow:hidden}.top-progress-bar{background:var(--primary-gradient);height:100%;box-shadow:0 0 8px var(--primary);transform-origin:0;width:100%;animation:2s cubic-bezier(.4,0,.2,1) infinite top-progress-anim}@keyframes top-progress-anim{0%{width:30%;transform:translate(-100%)}50%{width:80%;transform:translate(0)}to{width:30%;transform:translate(100%)}}
