@import url('https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700&display=swap');
:root{--from:#0891b2;--to:#06b6d4;--teal:#0891b2;--bg:#f0fdfc;--text:#111827;--muted:#6b7280;--border:#e5e7eb;--card:#ffffff;--danger:#dc2626;--success:#16a34a}
*{box-sizing:border-box}body{margin:0;font-family:'Sarabun',Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}.page{min-height:100vh;display:flex;justify-content:center}.phone{width:100%;max-width:430px;min-height:100vh;background:#fff;box-shadow:0 0 35px rgba(15,23,42,.12);position:relative;padding-bottom:86px}.header{background:linear-gradient(135deg,var(--from),var(--to));color:#fff;border-radius:0 0 28px 28px;padding:14px 16px;box-shadow:0 10px 25px rgba(8,145,178,.3)}.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.logo{height:58px;max-width:150px;object-fit:contain}.title{font-size:20px;font-weight:700}.search{display:flex;gap:8px;align-items:center;margin-top:12px}.search input,.input,select,textarea{width:100%;border:1.5px solid var(--border);border-radius:14px;padding:12px 14px;font:inherit;background:#fff;color:var(--text)}.auth-input{border:2px solid #c084fc;background:#f3f4f6;border-radius:14px}.btn{border:0;border-radius:14px;padding:12px 16px;font:inherit;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(90deg,var(--from),var(--to));color:#fff}.btn-outline{background:#fff;color:var(--teal);border:2px solid var(--to)}.btn-light{background:rgba(255,255,255,.2);color:#fff}.btn-danger{background:#ef4444;color:#fff}.btn-block{width:100%}.content{padding:16px}.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:16px;box-shadow:0 8px 20px rgba(15,23,42,.06);margin-bottom:14px}.grid{display:grid;gap:10px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.product{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff;position:relative}.product img{width:100%;aspect-ratio:1/1;object-fit:cover;background:#f3f4f6}.product-body{padding:9px}.product-name{font-size:13px;line-height:1.35;height:36px;overflow:hidden}.price{font-weight:800;color:#dc2626}.old-price{text-decoration:line-through;color:#9ca3af;font-size:12px}.badge{display:inline-flex;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:700;background:#ede9fe;color:#6d28d9}.badge-red{background:#fee2e2;color:#b91c1c}.badge-green{background:#dcfce7;color:#166534}.badge-yellow{background:#fef9c3;color:#854d0e}.slider{overflow:hidden;border-radius:0;background:#fff;box-shadow:0 4px 18px rgba(0,0,0,.08);margin-bottom:14px}.slides{display:flex;transition:transform .4s ease}.slide{min-width:100%;aspect-ratio:16/7;background:#eff6ff}.slide img{width:100%;height:100%;object-fit:contain}.section-title{font-size:18px;font-weight:800;margin:18px 0 10px}.category{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;font-size:12px}.cat-icon{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;background:linear-gradient(135deg,var(--from),var(--to));overflow:hidden}.cat-icon img{width:100%;height:100%;object-fit:cover}.nav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:100%;max-width:430px;background:#fff;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);padding:6px 2px 10px;z-index:10}.nav a{font-size:10px;color:#9ca3af;text-align:center;padding:5px 2px;border-radius:14px;display:flex;flex-direction:column;align-items:center;gap:2px;transition:color .2s}.nav a .nav-icon{width:38px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:background .2s}.nav a.active{color:var(--teal);font-weight:700}.nav a.active .nav-icon{background:rgba(8,145,178,.12)}.nav a svg{flex-shrink:0}.flash{margin:12px 16px;padding:12px;border-radius:14px;background:#dcfce7;color:#166534}.flash.error{background:#fee2e2;color:#991b1b}.auth{min-height:100vh;background:#f3f4f6;padding:28px 24px}.auth-logo{text-align:center;margin-bottom:28px}.form{display:grid;gap:14px}.password-row{display:flex;align-items:stretch;gap:10px}.password-row .auth-input{min-width:0;flex:1}.password-toggle{width:48px;min-width:48px;height:48px;padding:0;border-radius:14px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.password-toggle .eye-icon{pointer-events:none}.muted{color:var(--muted);font-size:13px}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat{text-align:center;border:1px solid var(--border);border-radius:16px;padding:13px;background:#fff}.wallet{background:linear-gradient(90deg,var(--from),var(--to));color:#fff;border-radius:20px;padding:18px}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;font-size:13px}.table th,.table td{border-bottom:1px solid var(--border);padding:9px;text-align:left;white-space:nowrap}.tabs{display:flex;background:#fff;border-radius:16px;border:1px solid var(--border);overflow:hidden;margin:14px 0}.tabs a,.tabs button{flex:1;text-align:center;border:0;background:#fff;padding:12px;font:inherit}.tabs .active{background:linear-gradient(90deg,var(--from),var(--to));color:#fff;font-weight:800}.admin-menu{background:#fff;border:1px solid var(--border);border-radius:18px;padding:12px;height:max-content}.admin-menu a.active{background:#ede9fe;color:#6d28d9;font-weight:800}.modal{position:fixed;inset:0;background:rgba(15,23,42,.45);display:none;align-items:center;justify-content:center;padding:20px;z-index:30}.modal.open{display:flex}.modal-card{background:#fff;border-radius:20px;padding:18px;max-width:390px;width:100%}.social-divider{display:flex;align-items:center;gap:12px;margin:18px 0 14px;color:var(--muted);font-size:13px}.social-divider::before,.social-divider::after{content:'';flex:1;height:1px;background:var(--border)}.social-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}.btn-social{border-radius:14px;padding:11px 8px;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;text-decoration:none;border:none}.btn-google{background:#fff;color:#3c4043;border:1.5px solid #dadce0}.btn-facebook{background:#1877f2;color:#fff}.btn-line{background:#06c755;color:#fff}.user-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.25);border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:#fff;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.greeting{font-size:13px;opacity:.9}.greeting b{font-size:16px;display:block}.header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.chat-float{position:fixed;right:18px;bottom:100px;z-index:20;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--from),var(--to));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(8,145,178,.45);text-decoration:none;border:3px solid #fff}.chat-msgs{display:flex;flex-direction:column;gap:10px;padding:10px 0;max-height:62vh;overflow-y:auto}.msg-bubble{max-width:80%;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.45}.msg-in{background:#f1f5f9;color:var(--text);align-self:flex-start;border-bottom-left-radius:4px}.msg-out{background:linear-gradient(135deg,var(--from),var(--to));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.msg-meta{font-size:11px;opacity:.6;margin-top:3px}.msg-form{display:flex;gap:8px;padding:10px 16px;border-top:1px solid var(--border);background:#fff;position:sticky;bottom:0}.msg-form input{flex:1;border:1.5px solid var(--border);border-radius:24px;padding:10px 16px;font:inherit}.msg-form button{background:linear-gradient(135deg,var(--from),var(--to));color:#fff;border:0;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.room-list{display:flex;flex-direction:column;gap:0}.room-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;text-decoration:none;color:var(--text)}.room-icon{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--from),var(--to));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;flex-shrink:0}@media(max-width:760px){.grid-3{gap:6px}.content{padding:14px}.phone{box-shadow:none}}
.social-divider{display:flex;align-items:center;text-align:center;margin:18px 0;gap:10px;color:var(--muted);font-size:13px}.social-divider::before,.social-divider::after{content:"";flex:1;border-top:1px solid var(--border)}.social-btns{display:flex;gap:10px;margin-bottom:16px}.btn-social{flex:1;border-radius:14px;padding:11px 8px;font-size:14px;font-weight:700;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:opacity .15s}.btn-social:hover{opacity:.88}.btn-google{background:#fff;color:#3c4043;border:1.5px solid #dadce0}.btn-facebook{background:#1877F2;color:#fff}.btn-line{background:#06C755;color:#fff}.adm-wrap{display:flex;min-height:100vh;background:#f1f5f9}.adm-sidebar{width:240px;background:#1e2a3a;color:#fff;display:flex;flex-direction:column;flex-shrink:0;min-height:100vh;position:sticky;top:0;height:100vh;overflow-y:auto}.adm-brand{display:flex;align-items:center;gap:12px;padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.adm-brand-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#38bdf8,#0ea5e9);display:flex;align-items:center;justify-content:center;flex-shrink:0}.adm-brand-name{font-weight:700;font-size:15px;color:#fff}.adm-brand-sub{font-size:11px;color:rgba(255,255,255,.5);margin-top:1px}.adm-nav{padding:12px 10px;flex:1}.adm-nav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;color:rgba(255,255,255,.65);font-size:14px;margin-bottom:3px;transition:.15s;text-decoration:none}.adm-nav a svg{opacity:.7;flex-shrink:0}.adm-nav a:hover{background:rgba(255,255,255,.08);color:#fff}.adm-nav a:hover svg{opacity:1}.adm-nav a.active{background:rgba(56,189,248,.15);color:#38bdf8;font-weight:600}.adm-nav a.active svg{opacity:1}.adm-nav-section{color:rgba(255,255,255,.3);font-size:10px;font-weight:700;letter-spacing:.08em;padding:16px 12px 6px;text-transform:uppercase}.adm-sidebar-footer{padding:16px 10px;border-top:1px solid rgba(255,255,255,.08)}.adm-logout-btn{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;background:rgba(239,68,68,.12);color:#f87171;border:none;font-size:14px;cursor:pointer;transition:.15s;font-family:inherit}.adm-logout-btn:hover{background:rgba(239,68,68,.22);color:#fca5a5}.adm-main{flex:1;display:flex;flex-direction:column;min-width:0}.adm-topbar{background:#fff;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 0 #e2e8f0;position:sticky;top:0;z-index:10}.adm-topbar-title{font-size:18px;font-weight:700;color:#0f172a;margin:0}.adm-topbar-right{display:flex;align-items:center;gap:12px}.adm-admin-badge{background:linear-gradient(135deg,#0ea5e9,#38bdf8);color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}.adm-body{padding:24px;flex:1}.adm-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.adm-stat-card{background:#fff;border-radius:14px;padding:18px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 3px rgba(0,0,0,.06);border:1px solid #e2e8f0}.adm-stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.adm-stat-icon.blue{background:#eff6ff;color:#3b82f6}.adm-stat-icon.green{background:#f0fdf4;color:#22c55e}.adm-stat-icon.orange{background:#fff7ed;color:#f97316}.adm-stat-icon.purple{background:#faf5ff;color:#a855f7}.adm-stat-val{font-size:26px;font-weight:700;color:#0f172a;line-height:1.2}.adm-stat-label{font-size:13px;color:#64748b;margin-top:2px}.adm-card{background:#fff;border-radius:14px;box-shadow:0 1px 3px rgba(0,0,0,.06);border:1px solid #e2e8f0;overflow:hidden}.adm-card-head{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f1f5f9}.adm-card-head h2{margin:0;font-size:16px;font-weight:700;color:#0f172a}.adm-table-wrap{overflow-x:auto}.adm-table{width:100%;border-collapse:collapse}.adm-table th{background:#f8fafc;padding:10px 16px;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-weight:600;text-align:left;border-bottom:1px solid #e2e8f0;white-space:nowrap}.adm-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adm-table tr:last-child td{border-bottom:none}.adm-table tbody tr:hover td{background:#f8fafc}#toast-wrap{position:fixed;top:20px;right:20px;z-index:99999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:12px;background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 8px 30px rgba(0,0,0,.18);animation:toastIn .3s ease;border-left:4px solid #94a3b8;min-width:260px;max-width:360px;pointer-events:all}.toast.success,.toast.info{border-left-color:#22c55e}.toast.error{border-left-color:#ef4444}.toast-icon{font-size:20px;flex-shrink:0;line-height:1.3}.toast-msg{flex:1;font-size:14px;line-height:1.5;color:#1e293b;font-family:Sarabun,Arial,sans-serif}.toast-close{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:18px;padding:0;line-height:1;flex-shrink:0;margin-top:-1px;pointer-events:all}.toast-close:hover{color:#475569}@keyframes toastIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes toastOut{to{transform:translateX(110%);opacity:0}}@media(max-width:900px){.adm-sidebar{display:none}.adm-stat-row{grid-template-columns:repeat(2,1fr)}}
/* Product image wrap */
.product-img-wrap{position:relative;cursor:pointer;overflow:hidden}.product-img-wrap img{width:100%;aspect-ratio:1/1;object-fit:cover;background:#f3f4f6;transition:transform .2s}.product-img-wrap:hover img{transform:scale(1.04)}.img-count-badge{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;pointer-events:none}
/* Gallery modal */
.gallery-card{max-width:420px;width:100%;padding:0;border-radius:20px;overflow:hidden}.gallery-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.gallery-title{font-weight:700;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:240px}.gallery-stage{position:relative;display:flex;align-items:center;background:#000;min-height:300px}.gallery-img-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:8px}.gallery-img-wrap img{max-width:100%;max-height:380px;object-fit:contain;border-radius:8px}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:0;color:#fff;font-size:36px;line-height:1;padding:8px 14px;cursor:pointer;z-index:2;border-radius:8px;transition:.15s}.gallery-nav:hover{background:rgba(255,255,255,.3)}.gallery-prev{left:6px}.gallery-next{right:6px}.gallery-dots{display:flex;justify-content:center;gap:7px;padding:10px}.g-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:.15s}.g-dot.active{background:var(--teal)}.gallery-counter{text-align:center;font-size:13px;color:var(--muted);padding-bottom:14px}
/* Cart badge */
.cart-btn-wrap{position:relative;flex-shrink:0}
.cart-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;border-radius:999px;font-size:11px;font-weight:700;padding:0 5px;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 6px rgba(239,68,68,.5);pointer-events:none;border:2px solid rgba(255,255,255,.3)}
/* Cart items */
.cart-empty{text-align:center;color:var(--muted);padding:28px 16px;font-size:14px}
.cart-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.cart-item:last-of-type{border-bottom:none}
.cart-item-img{width:56px;height:56px;border-radius:10px;object-fit:cover;flex-shrink:0;background:#f3f4f6}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:13px;font-weight:600;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.cart-item-price{font-size:13px;color:var(--teal);font-weight:700;margin-top:3px}
.cart-item-qty{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;flex-shrink:0}
.cart-item-qty button{background:#f8fafc;border:none;width:30px;height:30px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--teal);font-weight:700;transition:.1s}
.cart-item-qty button:hover{background:var(--border)}
.cart-item-qty span{min-width:28px;text-align:center;font-size:14px;font-weight:700;line-height:30px}
.cart-item-del{background:none;border:none;cursor:pointer;color:#dc2626;padding:6px;flex-shrink:0;border-radius:8px;display:flex;align-items:center;transition:.15s}
.cart-item-del:hover{background:#fee2e2}
.cart-total{display:flex;justify-content:space-between;align-items:center;padding:12px 0 4px;font-size:14px;border-top:2px solid var(--border);margin-top:6px}
.cart-total strong{font-size:16px;color:var(--teal)}
/* Notice box */
.notice-box{background:#fff7ed;border:1px solid #fdba74;border-radius:10px;padding:9px 12px;font-size:13px;color:#92400e;margin-top:6px}
/* Admin input */
.adm-input{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:9px 12px;font:inherit;background:#fff;color:var(--text);margin-top:4px}
/* Chat float button */
.chat-float{position:fixed;bottom:96px;right:18px;width:60px;height:60px;border-radius:50%;background:#031634;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(8,145,178,.45);z-index:200;transition:.2s;overflow:visible}.chat-float:hover{transform:scale(1.08)}.chat-float-img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;border:2px solid rgba(255,255,255,.9)}.chat-float-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;background:#ef4444;color:#fff;border-radius:999px;font-size:11px;font-weight:700;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 6px rgba(239,68,68,.5);border:2px solid #fff}
/* User chat page */
.chat-page-main{display:flex;flex-direction:column;height:calc(100vh - 60px);padding:0;background:#f0fdfc}
.chat-page-msgs{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:6px}
.chat-empty{text-align:center;color:var(--muted);padding:32px 16px;font-size:13px;margin:auto}
.chat-msg-row{display:flex;flex-direction:column;max-width:80%}
.chat-msg-row.chat-msg-in{align-self:flex-start;align-items:flex-start}
.chat-msg-row.chat-msg-out{align-self:flex-end;align-items:flex-end}
.chat-msg-name{font-size:10px;color:var(--muted);margin-bottom:2px;padding-left:2px}
.chat-bubble{padding:8px 12px;border-radius:16px;font-size:13px;line-height:1.45;word-break:break-word;max-width:100%}
.chat-bubble-in{background:#fff;border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--text)}
.chat-bubble-out{background:linear-gradient(135deg,var(--from),var(--to));color:#fff;border-bottom-right-radius:4px}
.chat-bubble-img img{max-width:200px;max-height:200px;border-radius:10px;cursor:pointer;display:block}
.chat-file-link{color:inherit;text-decoration:underline;font-size:12px;word-break:break-all}
.chat-msg-time{font-size:10px;color:var(--muted);margin-top:2px;padding:0 3px}
.chat-page-form{position:relative;display:flex;gap:6px;padding:8px 10px;background:#fff;border-top:1px solid var(--border);align-items:flex-end}
.chat-page-input{flex:1;border:1.5px solid var(--border);border-radius:18px;padding:8px 12px;font:inherit;background:#f8fafc;outline:none;font-size:13px;resize:none;max-height:100px;overflow-y:auto;line-height:1.4}
.chat-page-input:focus{border-color:var(--teal);background:#fff}
.chat-send-btn{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--from),var(--to));color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-icon-btn{width:34px;height:34px;border-radius:50%;background:#f0fdfc;border:1px solid var(--border);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;line-height:1;transition:.15s}
.chat-icon-btn:hover{background:var(--border)}
/* Emoji picker */
.emoji-picker{position:absolute;bottom:60px;left:8px;z-index:200;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.12);padding:10px;width:270px;max-height:240px;overflow:hidden;display:grid;flex-direction:column}
.emoji-tabs{display:flex;gap:6px;margin-bottom:8px;grid-column:1/-1}
.emoji-tab{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:4px;font-size:12px;cursor:pointer;background:#fff;transition:.15s}
.emoji-tab.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;overflow-y:auto;max-height:170px;grid-column:1/-1}
.emoji-item{background:none;border:0;font-size:20px;cursor:pointer;border-radius:6px;padding:3px;line-height:1;transition:.1s}
.emoji-item:hover{background:#f0fdfc;transform:scale(1.15)}
.emoji-sticker{font-size:22px}
/* Chat image modal */
.chat-img-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.chat-img-modal img{max-width:90vw;max-height:80vh;border-radius:12px;object-fit:contain}
.chat-img-modal button{background:rgba(255,255,255,.2);border:0;color:#fff;font-size:22px;border-radius:50%;width:44px;height:44px;cursor:pointer;position:absolute;top:16px;right:16px}
/* Slider */
.slider{overflow:hidden;position:relative;width:100%;background:#000}.slides{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}.slide{flex:0 0 100%;display:block}.slide img{width:100%;height:200px;object-fit:cover;display:block}
/* Side menu */
.hamburger-btn{background:rgba(255,255,255,.2);border:0;border-radius:10px;padding:8px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s}.hamburger-btn:hover{background:rgba(255,255,255,.35)}
#side-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9998;opacity:0;pointer-events:none;transition:opacity .3s}#side-menu-overlay.open{opacity:1;pointer-events:all}
#side-menu{position:fixed;top:0;left:-300px;width:270px;height:100%;background:#fff;z-index:9999;box-shadow:4px 0 24px rgba(0,0,0,.15);transition:left .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}#side-menu.open{left:0}
.side-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px 18px 16px;border-bottom:1px solid #e5e7eb;font-weight:700;font-size:17px;background:linear-gradient(135deg,var(--from),var(--to));color:#fff}.side-menu-close{background:rgba(255,255,255,.2);border:0;border-radius:8px;padding:6px 10px;cursor:pointer;color:#fff;font-size:18px}
.side-menu-nav{padding:12px 0;flex:1;overflow-y:auto}.side-menu-nav a{display:flex;align-items:center;padding:14px 20px;color:#1f2937;font-size:15px;font-weight:500;text-decoration:none;border-bottom:1px solid #f3f4f6;transition:.15s}.side-menu-nav a:hover{background:#f0fdfc;color:var(--teal)}.side-menu-logout{width:100%;padding:14px 20px;text-align:left;background:none;border:none;border-bottom:1px solid #f3f4f6;color:#dc2626;font:500 15px 'Sarabun',Arial,sans-serif;cursor:pointer}
/* Admin chat layout */
.adm-chat-layout{display:flex;height:calc(100vh - 120px);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(15,23,42,.08)}
.adm-chat-sidebar{width:260px;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;background:#fafafa}
.adm-chat-sidebar-head{padding:12px 14px;font-weight:700;font-size:12px;color:#475569;border-bottom:1px solid #e2e8f0;text-transform:uppercase;letter-spacing:.05em}
.adm-chat-room-list{flex:1;overflow-y:auto}
.adm-chat-room-item{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;border-bottom:1px solid #f1f5f9;text-decoration:none;color:inherit;transition:.15s}
.adm-chat-room-item:hover{background:#f0fdfc}
.adm-chat-room-item.active{background:#e0f7fa;border-left:3px solid var(--teal)}
.adm-chat-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--from),var(--to));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.adm-chat-main{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}
.adm-chat-topbar{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid #e2e8f0;background:#fff}
.adm-chat-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;background:#f8fafc}
.adm-msg-row{display:flex;flex-direction:column;max-width:70%;position:relative}
.adm-msg-row:hover .adm-msg-actions{opacity:1}
.adm-msg-row.adm-msg-in{align-self:flex-start;align-items:flex-start}
.adm-msg-row.adm-msg-out{align-self:flex-end;align-items:flex-end}
.adm-msg-who{font-size:10px;color:#94a3b8;margin-bottom:2px;padding-left:2px}
.adm-msg-bubble{padding:8px 12px;border-radius:14px;font-size:13px;line-height:1.45;word-break:break-word}
.adm-msg-bubble-in{background:#fff;border:1px solid #e2e8f0;border-bottom-left-radius:4px;color:#1e2a3a}
.adm-msg-bubble-out{background:linear-gradient(135deg,#0891b2,#06b6d4);color:#fff;border-bottom-right-radius:4px}
.adm-msg-bubble-img img{max-width:180px;max-height:180px;border-radius:8px;cursor:pointer;display:block}
.adm-msg-time{font-size:10px;color:#94a3b8;margin-top:2px;padding:0 3px}
.adm-msg-actions{display:flex;gap:3px;opacity:0;transition:.15s;margin-bottom:3px}
.adm-msg-act-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;padding:2px 6px;cursor:pointer;line-height:1.5;transition:.1s}
.adm-msg-act-btn:hover{background:#f0fdfc}
.adm-del-all-btn{background:#fee2e2;border:1px solid #fca5a5;color:#dc2626;border-radius:8px;font-size:11px;padding:5px 10px;cursor:pointer;font-weight:600;transition:.15s;white-space:nowrap}
.adm-del-all-btn:hover{background:#fecaca}
.adm-chat-form{position:relative;display:flex;gap:8px;padding:10px 14px;border-top:1px solid #e2e8f0;background:#fff;align-items:flex-end}
.adm-chat-input{flex:1;border:1.5px solid #e2e8f0;border-radius:18px;padding:8px 14px;font:inherit;background:#f8fafc;outline:none;font-size:13px;resize:none;max-height:100px;overflow-y:auto;line-height:1.4}
.adm-chat-input:focus{border-color:#0891b2;background:#fff}
.adm-chat-send{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#0891b2,#06b6d4);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
/* Admin edit modal */
.adm-edit-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.adm-edit-inner{background:#fff;border-radius:16px;padding:20px;width:100%;max-width:400px;box-shadow:0 8px 32px rgba(0,0,0,.15)}

/* Admin emoji picker override */
#admEmojiPicker{bottom:62px;left:14px}
/* Product card compact (3-col) */
.product-body{padding:7px!important}
.product-name{font-size:11px!important;height:30px!important;line-height:1.3!important}
.product-body .old-price{font-size:10px!important;margin:1px 0!important}
.product-body .price{font-size:13px!important;margin:1px 0 4px!important}
.product-body .btn{padding:6px 8px!important;font-size:11px!important;border-radius:10px!important}
/* Category horizontal scroll */
.cat-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px;margin:0 -16px;padding-left:16px}
.cat-scroll-wrap::-webkit-scrollbar{display:none}
.cat-scroll{display:flex;flex-direction:row;gap:10px;width:max-content;padding-right:16px}
.cat-scroll .category{width:72px;flex-shrink:0;font-size:11px;gap:4px}
.cat-scroll .cat-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#e0f7fa,#b2ebf2);display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:22px}
.cat-scroll .cat-icon img{width:100%;height:100%;object-fit:cover}
.header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.header-logo-link{display:flex;align-items:center;flex-shrink:0}.logo{height:54px;max-width:170px;object-fit:contain}.auth-logo{text-align:center;margin:18px 0}.auth-logo .logo{height:96px;max-width:240px}.adm-brand-logo{width:46px;height:46px;object-fit:contain;border-radius:10px;background:rgba(255,255,255,.08);flex-shrink:0}
