*{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.top-nav{z-index:100;background:#1e3a5f;align-items:center;gap:20px;height:56px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000001f}.nav-brand a{color:#fff;letter-spacing:.5px;white-space:nowrap;font-size:18px;font-weight:700}.nav-links{flex-wrap:wrap;flex:1;gap:2px;display:flex}.nav-links a{color:#ffffffbf;white-space:nowrap;border-radius:6px;padding:8px 14px;font-size:14px;transition:all .2s}.nav-links a:hover,.nav-links a.active{color:#fff;background:#ffffff26}.nav-user{white-space:nowrap;align-items:center;gap:10px;display:flex}.nav-points{color:#fbbf24;background:#00000026;border-radius:20px;padding:4px 10px;font-size:13px;font-weight:600}.nav-phone{color:#fffc;text-overflow:ellipsis;max-width:80px;font-size:13px;overflow:hidden}.btn-logout{cursor:pointer;color:#ffffffd9;background:#ffffff26;border:none;border-radius:6px;outline:none;padding:6px 14px;font-size:13px;transition:all .2s}.btn-logout:hover{background:#ffffff40}.btn-login-nav{color:#2563eb;background:#fff;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;transition:all .2s}.btn-login-nav:hover{background:#f8fafc;transform:translateY(-1px)}.main-content{max-width:1000px;margin:0 auto;padding:20px}.app-footer{text-align:center;color:#94a3b8;border-top:1px solid #e2e8f0;margin-top:40px;padding:24px;font-size:13px}.page{animation:.25s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.auth-page{background:#1e3a5f;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px 36px;box-shadow:0 8px 24px #0000001a}.auth-card h1{text-align:center;margin-bottom:4px;font-size:24px}.auth-subtitle{color:#64748b;text-align:center;margin-bottom:28px;font-size:14px}.form-group{margin-bottom:16px}.form-group label{color:#1e293b;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:all .2s;display:block}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.btn-primary{color:#fff;cursor:pointer;text-align:center;background:#2563eb;border:none;border-radius:10px;outline:none;width:100%;padding:12px;font-size:15px;font-weight:600;transition:all .2s;display:inline-block}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{opacity:.5;cursor:not-allowed;-webkit-box-shadow:none;box-shadow:none;transform:none}.btn-primary:disabled:hover{-webkit-box-shadow:none;box-shadow:none;background:#2563eb;transform:none}.btn-link{color:#2563eb;cursor:pointer;background:0 0;border:none;outline:none;padding:4px 0;font-size:13px;text-decoration:underline}.btn-link:hover{color:#1d4ed8}.btn-danger{color:#fff;cursor:pointer;text-align:center;background:#dc2626;border:none;border-radius:10px;outline:none;width:100%;padding:10px;font-size:14px;transition:all .2s;display:inline-block}.btn-danger:hover{background:#b91c1c}.btn-back{color:#2563eb;cursor:pointer;background:0 0;border:none;outline:none;align-items:center;gap:4px;margin-bottom:12px;padding:6px 0;font-size:14px;display:inline-flex}.btn-back:hover{opacity:.8}.error-msg{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:14px}.success-msg{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:14px}.auth-switch{text-align:center;color:#2563eb;cursor:pointer;margin-top:20px;font-size:14px;font-weight:500}.loading-text{text-align:center;color:#64748b;padding:40px}.loading-shimmer{flex-direction:column;gap:12px;display:flex}.shimmer-card{-webkit-background-size:200% 100%;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%) 0 0/200% 100%;border-radius:10px;height:120px;animation:1.5s infinite shimmer}.header-bar{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.header-bar h2{font-size:22px}.header-sub{color:#64748b;margin-top:2px;font-size:13px}.header-stats{gap:12px;display:flex}.stat-item{background:#fff;border-radius:10px;flex-direction:column;align-items:center;padding:8px 16px;display:flex;box-shadow:0 1px 3px #0000000f}.stat-value{color:#2563eb;font-size:18px;font-weight:700}.stat-label{color:#94a3b8;font-size:11px}.guest-banner{color:#64748b;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:14px}.guest-banner a{color:#2563eb;margin-left:4px;font-weight:600}.category-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.cat-tab{color:#64748b;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:20px;outline:none;padding:6px 14px;font-size:13px;transition:all .2s}.cat-tab:hover{color:#2563eb;border-color:#2563eb}.cat-tab.active{color:#fff;background:#2563eb;border-color:#2563eb}.order-grid{flex-wrap:wrap;gap:14px;display:flex}.order-grid>*{width:-webkit-calc(33.333% - 10px);width:-moz-calc(33.333% - 10px);width:calc(33.333% - 10px);min-width:280px}@media (width<=960px){.order-grid>*{width:-webkit-calc(50% - 7px);width:-moz-calc(50% - 7px);width:calc(50% - 7px)}}@media (width<=640px){.order-grid>*{width:100%}}.order-card-new{cursor:pointer;background:#fff;border:1px solid #0000;border-radius:10px;padding:18px 20px;transition:all .2s;display:block;box-shadow:0 1px 3px #0000000f}.order-card-new:hover{border-color:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.oc-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.order-category{color:#2563eb;background:#eff6ff;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:600}.order-status{border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500}.order-status.open{color:#16a34a;background:#f0fdf4}.order-status.closed{color:#64748b;background:#f1f5f9}.oc-title{margin-bottom:8px;font-size:16px;line-height:1.4}.oc-desc{color:#64748b;margin-bottom:12px;font-size:13px;line-height:1.5}.oc-info{background:#f1f5f9;border-radius:6px;margin-bottom:10px;padding:10px}.oc-info-row{justify-content:space-between;padding:3px 0;font-size:13px;display:flex}.oc-label{color:#94a3b8}.oc-value{color:#1e293b;font-weight:500}.oc-value.budget{color:#2563eb;font-weight:600}.oc-footer{color:#94a3b8;justify-content:space-between;font-size:12px;display:flex}.card{background:#fff;border-radius:10px;padding:24px;box-shadow:0 1px 3px #0000000f}.card h2{margin-bottom:20px;font-size:20px}.points-bar{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 20px;display:flex}.points-display{flex-direction:column;display:flex}.points-label{color:#64748b;font-size:12px}.points-number{color:#2563eb;font-size:28px;font-weight:700}.points-desc{color:#64748b;font-size:13px}.cost-hint{color:#64748b;background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;margin-bottom:12px;padding:12px;font-size:13px}.cost-hint strong{color:#92400e}.empty-state{text-align:center;color:#64748b;padding:60px 20px}.empty-icon{color:#94a3b8;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:12px;font-size:14px;display:inline-flex}.empty-state p{margin-bottom:4px;font-size:15px}.empty-state span{color:#94a3b8;font-size:13px}.detail-card{padding:28px}.detail-header{margin-bottom:20px}.detail-tags{gap:8px;margin-bottom:12px;display:flex}.detail-title{font-size:22px;line-height:1.4}.detail-section{margin-bottom:20px}.detail-section h4{color:#64748b;margin-bottom:8px;font-size:14px}.detail-desc{color:#1e293b;font-size:15px;line-height:1.8}.detail-grid{background:#f8fafc;border-radius:10px;flex-wrap:wrap;margin-bottom:24px;padding:16px;display:flex}.detail-item{flex-direction:column;gap:2px;width:50%;padding:4px 0;display:flex}@media (width<=640px){.detail-item{width:100%}}.detail-label{color:#94a3b8;font-size:12px}.detail-value{font-size:14px;font-weight:500}.detail-value.highlight{color:#2563eb;font-weight:600}.contact-section{text-align:center;background:#fef9e7;border:1px solid #fcd34d;border-radius:10px;padding:20px}.phone-display{justify-content:center;align-items:center;gap:12px;padding:10px;display:flex}.phone-icon{color:#fff;background:#2563eb;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:700}.phone-number{color:#2563eb;letter-spacing:1px;font-size:24px;font-weight:700}.view-contact-area{text-align:center;padding:8px 0}.cost-info{justify-content:center;gap:24px;margin-bottom:14px;display:flex}.cost-row{color:#64748b;flex-direction:column;align-items:center;gap:2px;font-size:13px;display:flex}.cost-highlight{color:#92400e;font-size:16px;font-weight:700}.cost-free{color:#16a34a;font-size:16px;font-weight:700}.btn-view-contact{width:auto;padding:10px 36px;display:inline-block}.contact-hint-box{text-align:center;padding:16px}.contact-hint-box p{color:#64748b;font-size:14px}.recharge-layout{gap:24px;display:flex}.recharge-left{flex:1;min-width:0}.recharge-right{flex-shrink:0;width:240px}@media (width<=768px){.recharge-layout{flex-direction:column}.recharge-right{width:100%}}.recharge-left h3,.recharge-right h3{color:#1e293b;margin-bottom:14px;font-size:15px}.package-grid{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.package-grid>*{width:-webkit-calc(50% - 5px);width:-moz-calc(50% - 5px);width:calc(50% - 5px)}.package-card-new{cursor:pointer;text-align:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;padding:16px;transition:all .2s}.package-card-new:hover{background:#eff6ff;border-color:#2563eb}.package-card-new.selected{background:#eff6ff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.pkg-name{color:#1e293b;margin-bottom:4px;font-size:14px;font-weight:600}.pkg-points{color:#2563eb;font-size:22px;font-weight:700}.pkg-points span{color:#64748b;font-size:13px;font-weight:400}.pkg-price{color:#dc2626;margin-top:4px;font-size:16px;font-weight:700}.pkg-ratio{color:#94a3b8;margin-top:2px;font-size:12px}.selected-summary{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:16px}.summary-row{justify-content:space-between;margin-bottom:8px;font-size:14px;display:flex}.summary-price{color:#dc2626;font-size:20px;font-weight:700}.recharge-guide{flex-direction:column;gap:12px;display:flex}.guide-step{color:#64748b;align-items:center;gap:10px;font-size:13px;display:flex}.step-num{color:#fff;background:#2563eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:420px;max-height:90vh;padding:32px;animation:.3s slideUp;position:relative;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.modal-close{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:50%;outline:none;width:32px;height:32px;font-size:14px;line-height:32px;transition:all .2s;position:absolute;top:12px;right:12px}.modal-close:hover{color:#1e293b;background:#e2e8f0}.modal-content h3{margin-bottom:16px;font-size:20px}.payment-info{margin-bottom:20px}.payment-amount{flex-direction:column;align-items:center;gap:2px;display:flex}.payment-label{color:#64748b;font-size:13px}.payment-price{color:#dc2626;font-size:32px;font-weight:700}.payment-pkg{color:#64748b;margin-top:4px;font-size:13px}.qr-wrapper{background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:16px;display:inline-block}.qr-image-dynamic{width:200px;height:200px;display:block}.qr-tip{color:#64748b;margin-bottom:4px;font-size:13px}.qr-recipient-text{color:#94a3b8;margin-bottom:8px;font-size:12px}.divider{color:#94a3b8;align-items:center;gap:12px;margin:16px 0;font-size:12px;display:flex}.divider:before,.divider:after{content:"";background:#e2e8f0;flex:1;height:1px}.upload-section{margin-bottom:16px}.file-input-hidden{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.upload-label{cursor:pointer;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:24px;transition:all .2s;display:flex}.upload-label:hover{background:#eff6ff;border-color:#2563eb}.upload-icon{color:#94a3b8;font-size:28px;font-weight:300;line-height:1}.upload-label span:nth-child(2){color:#64748b;font-size:14px}.upload-hint{color:#94a3b8;font-size:12px}.preview-area{text-align:center;position:relative}.preview-image{border:1px solid #e2e8f0;border-radius:8px;max-width:100%;max-height:180px;margin:0 auto 8px;display:block}.btn-paid{margin:0}.tx-list{flex-direction:column;gap:8px;display:flex}.tx-item{background:#fff;border-radius:10px;justify-content:space-between;align-items:center;padding:14px 16px;display:flex;box-shadow:0 1px 3px #0000000f}.tx-info{flex-direction:column;gap:2px;display:flex}.tx-type{font-size:14px;font-weight:500}.tx-desc{color:#64748b;font-size:12px}.tx-amount{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.amount-positive{color:#16a34a;font-size:16px;font-weight:700}.amount-negative{color:#dc2626;font-size:16px;font-weight:700}.tx-balance{color:#64748b;font-size:12px}.tx-time{color:#94a3b8;font-size:11px}@media (width<=768px){.top-nav{-webkit-overflow-scrolling:touch;padding:0 12px;overflow-x:auto}.nav-links a{padding:6px 10px;font-size:12px}.cost-info{flex-direction:column;gap:8px}.header-bar{flex-direction:column;gap:10px}.package-grid>*{width:100%}.modal-content{padding:24px 16px}.nav-points,.nav-phone{display:none}}.admin-login-page{background:#0f172a;justify-content:center;align-items:center;min-height:100vh;display:flex}.admin-login-card{background:#fff;border-radius:12px;width:100%;max-width:380px;padding:40px 36px;box-shadow:0 20px 60px #0000004d}.admin-login-card h1{text-align:center;margin-bottom:4px;font-size:22px}.admin-login-sub{color:#64748b;text-align:center;margin-bottom:24px;font-size:13px}.admin-loading{text-align:center;color:#64748b;padding:40px;font-size:14px}.admin-layout{background:#f1f5f9;min-height:100vh;display:flex}.admin-sidebar{color:#fff;background:#1e293b;flex-direction:column;flex-shrink:0;width:220px;height:100vh;display:flex;position:sticky;top:0}.admin-sidebar-header{border-bottom:1px solid #ffffff14;padding:20px 20px 16px}.admin-sidebar-header h2{font-size:16px;font-weight:600}.admin-badge{color:#1e293b;text-transform:uppercase;letter-spacing:.5px;background:#f59e0b;border-radius:10px;margin-top:6px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.admin-nav{flex:1;padding:12px 0}.admin-nav-item{color:#fff9;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:14px;transition:all .15s;display:flex}.admin-nav-item:hover{color:#fff;background:#ffffff0f}.admin-nav-item.active{color:#fff;background:#2563eb33;border-left-color:#3b82f6}.admin-nav-icon{background:#ffffff1a;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:inline-flex}.admin-nav-item.active .admin-nav-icon{background:#3b82f6}.admin-sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:8px;padding:14px 20px;display:flex}.admin-user-info{color:#fff9;font-size:13px}.admin-logout-btn{color:#ffffffb3;cursor:pointer;text-align:center;background:#ffffff1a;border:none;border-radius:6px;outline:none;padding:6px 0;font-size:13px;transition:all .15s}.admin-logout-btn:hover{color:#fff;background:#ffffff26}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-topbar{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.admin-topbar h3{font-size:16px;font-weight:600}.admin-topbar-right{align-items:center;gap:12px;display:flex}.admin-to-front{color:#2563eb;border:1px solid #2563eb;border-radius:6px;padding:4px 12px;font-size:13px;transition:all .15s}.admin-to-front:hover{color:#fff;background:#2563eb}.admin-content{flex:1;padding:24px;overflow-y:auto}.admin-page{animation:.2s fadeIn}.admin-stat-grid{flex-wrap:wrap;gap:14px;margin-bottom:24px;display:flex}.admin-stat-card{text-align:center;background:#fff;border-top:3px solid #e2e8f0;border-radius:10px;flex:1;min-width:140px;padding:18px 20px;box-shadow:0 1px 3px #0000000f}.admin-stat-value{margin-bottom:2px;font-size:28px;font-weight:700}.admin-stat-label{color:#94a3b8;font-size:12px}.admin-dash-grid{gap:20px;display:flex}.admin-dash-section{background:#fff;border-radius:10px;flex:1;min-width:0;padding:18px;box-shadow:0 1px 3px #0000000f}.admin-dash-section h4{color:#1e293b;margin-bottom:12px;font-size:14px;font-weight:600}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;color:#64748b;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:8px 10px;font-size:12px;font-weight:600}.admin-table td{white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:9px 10px}.admin-table tbody tr:hover{background:#f8fafc}.admin-table.full-width{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.table-title{text-overflow:ellipsis;max-width:200px;overflow:hidden}.admin-status-tag{border-radius:10px;padding:2px 8px;font-size:12px;font-weight:500}.admin-status-tag.open{color:#16a34a;background:#f0fdf4}.admin-status-tag.closed{color:#64748b;background:#f1f5f9}.admin-status-tag.verified{color:#16a34a;background:#f0fdf4}.admin-status-tag.pending{color:#d97706;background:#fffbeb}.admin-status-tag.rejected{color:#dc2626;background:#fef2f2}.text-green{color:#16a34a;font-weight:600}.text-red{color:#dc2626;font-weight:600}.admin-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.admin-search{gap:8px;display:flex}.admin-search-input{border:1px solid #e2e8f0;border-radius:8px;outline:none;width:220px;padding:8px 14px;font-size:13px;transition:border-color .2s}.admin-search-input:focus{border-color:#2563eb}.admin-filter-tabs{gap:4px;display:flex}.admin-filter-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:6px;outline:none;padding:6px 14px;font-size:13px;transition:all .15s}.admin-filter-btn:hover{color:#2563eb;border-color:#2563eb}.admin-link{color:#2563eb;font-size:13px;font-weight:500}.admin-link:hover{text-decoration:underline}.admin-actions{gap:6px;display:flex}.admin-btn-sm{cursor:pointer;color:#64748b;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:5px;outline:none;padding:4px 10px;font-size:12px;transition:all .15s}.admin-btn-sm:hover{color:#2563eb;border-color:#2563eb}.admin-btn-sm.danger:hover{color:#dc2626;border-color:#dc2626}.admin-btn-sm.success:hover{color:#16a34a;border-color:#16a34a}.admin-detail-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 3px #0000000f}.admin-detail-card h3{margin-bottom:14px;font-size:16px}.admin-detail-grid{background:#f8fafc;border-radius:10px;flex-wrap:wrap;padding:14px;display:flex}.admin-detail-grid .info-item{width:50%}@media (width<=640px){.admin-detail-grid .info-item{width:100%}}.admin-detail-grid .info-item label{color:#94a3b8;margin-bottom:2px;font-size:12px;display:block}.admin-detail-grid .info-item span{font-size:14px;font-weight:500}.admin-points-edit{align-items:center;gap:8px;display:flex}.admin-points-input{border:1px solid #e2e8f0;border-radius:6px;outline:none;width:80px;padding:6px 10px;font-size:14px}.admin-points-input:focus{border-color:#2563eb}@media (width<=768px){.admin-sidebar{width:60px}.admin-sidebar-header h2,.admin-badge,.admin-nav-item span:not(.admin-nav-icon),.admin-user-info{display:none}.admin-logout-btn{font-size:11px}.admin-dash-grid{flex-direction:column}.admin-stat-grid{display:-ms-grid;grid-template-columns:1fr 1fr;display:grid}}.mobile-menu-toggle{cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:110;background:0 0;border:none;outline:none;margin-right:8px;padding:8px;display:none}.hamburger{background:#fff;width:22px;height:2px;transition:all .25s;display:block;position:relative}.hamburger:before,.hamburger:after{content:"";background:#fff;width:22px;height:2px;transition:all .25s;position:absolute;left:0}.hamburger:before{top:-7px}.hamburger:after{top:7px}.hamburger.open{background:0 0}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{top:0;transform:rotate(-45deg)}.mobile-user-section,.mobile-overlay{display:none}.desktop-only{display:flex}@media (width<=768px){.mobile-menu-toggle{display:block}.desktop-only{display:none!important}.mobile-overlay{z-index:90;background:#0006;animation:.2s fadeIn;display:block;position:fixed;inset:56px 0 0}.top-nav{padding:0 12px;position:sticky}.nav-brand a{font-size:16px}.nav-links{z-index:95;-webkit-overflow-scrolling:touch;background:#fff;flex-direction:column;max-height:calc(100vh - 56px);padding:8px 0;display:none;position:fixed;top:56px;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001f}.nav-links.mobile-open{display:flex}.nav-links a{color:#1e293b;border-bottom:1px solid #f1f5f9;border-radius:0;padding:14px 24px;font-size:15px}.nav-links a:hover,.nav-links a.active{color:#2563eb;background:#eff6ff}.mobile-user-section{border-top:2px solid #e2e8f0;flex-direction:column;gap:10px;margin-top:8px;padding:14px 24px;display:flex}.mobile-user-section .nav-points{color:#2563eb;text-align:center;background:#eff6ff;border-radius:8px;padding:10px 16px;font-size:18px;font-weight:700;display:block}.mobile-user-section .nav-phone{color:#64748b;text-align:center;max-width:none;font-size:14px;display:block;overflow:visible}.mobile-user-section .btn-logout{color:#dc2626;text-align:center;background:#f1f5f9;border-radius:8px;padding:10px;font-size:14px}.main-content{padding:12px}.order-grid{gap:10px}.order-grid>*{min-width:0;width:100%!important}.header-bar h2{font-size:20px}.header-stats{gap:8px}.stat-item{padding:6px 12px}.stat-value{font-size:16px}.detail-card{padding:16px}.detail-title{font-size:18px}.card{padding:16px}.card h2{font-size:18px}.form-row{flex-direction:column;gap:0}.cost-info{flex-direction:column;gap:8px}.package-grid>*{width:100%!important}.modal-content{max-height:85vh;padding:20px 16px}.recharge-layout{flex-direction:column}.recharge-right{width:100%}.phone-number{font-size:20px}.guest-banner{padding:10px 14px;font-size:13px}.admin-table{-webkit-overflow-scrolling:touch;white-space:nowrap;display:block;overflow-x:auto}.admin-table.full-width{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-content{padding:12px}.admin-topbar{padding:12px 14px}.admin-toolbar{flex-direction:column;align-items:flex-start}.admin-search{width:100%}.admin-search-input{box-sizing:border-box;width:100%}.admin-filter-tabs{-webkit-overflow-scrolling:touch;white-space:nowrap;width:100%;padding-bottom:4px;overflow-x:auto}.admin-filter-btn{flex-shrink:0}.admin-dash-section{padding:12px}.stat-grid-mobile{gap:8px}.admin-stat-card{min-width:0;padding:14px 12px}.admin-stat-value{font-size:22px}.admin-stat-label{font-size:11px}.admin-sidebar{width:56px;overflow:hidden}.admin-nav-item{border-left:none;border-right:3px solid #0000;justify-content:center;padding:12px 0}.admin-nav-item.active{background:#2563eb26;border-left:none;border-right-color:#3b82f6}.admin-sidebar-footer{align-items:center;padding:8px 6px}}@media (width<=480px){body{font-size:13px}.top-nav{height:50px;padding:0 10px}.nav-brand a{font-size:15px}.main-content{padding:10px}.header-bar h2{font-size:18px}.order-card-new{padding:14px 16px}.oc-title{font-size:15px}.detail-card{padding:14px}.detail-title{font-size:17px}.detail-desc{font-size:14px}.card{padding:14px}.btn-primary{padding:10px;font-size:14px}.btn-view-contact{padding:10px 28px;font-size:14px}.phone-number{font-size:18px}.auth-card{padding:28px 22px}.auth-card h1{font-size:20px}.stat-item{padding:6px 10px}.stat-value{font-size:15px}.stat-label{font-size:10px}.category-tabs{gap:6px}.cat-tab{padding:5px 12px;font-size:12px}.modal-content{padding:16px 12px}.modal-content h3{font-size:18px}.payment-price{font-size:26px}.points-number{font-size:24px}.points-display{gap:2px}.admin-stat-grid{flex-direction:column}.admin-content{padding:8px}.admin-topbar h3{font-size:14px}.empty-state{padding:40px 16px}.empty-state p{font-size:14px}}@media (hover:none) and (pointer:coarse){button,a,.cat-tab,.package-card-new,.order-card-new,.admin-btn-sm,.admin-filter-btn{-webkit-tap-highlight-color:#2563eb1a}button,.cat-tab,.admin-btn-sm,.admin-filter-btn{min-width:40px;min-height:40px}.admin-table td,.admin-table th{padding:10px 8px}.nav-links a{min-height:48px}}@supports (padding:env(safe-area-inset-bottom)){.app-footer{padding-bottom:calc(24px + env(safe-area-inset-bottom))}.bottom-fixed,.mobile-menu-toggle{padding-bottom:env(safe-area-inset-bottom)}}.nav-unread-badge{color:#fff;text-align:center;vertical-align:middle;background:#dc2626;border-radius:10px;min-width:16px;margin-left:4px;padding:1px 6px;font-size:10px;font-weight:700;line-height:14px;display:inline-block}.msg-list{flex-direction:column;gap:8px;display:flex}.msg-item{cursor:pointer;background:#fff;border:1px solid #0000;border-radius:10px;align-items:center;gap:12px;padding:14px 16px;transition:all .2s;display:flex;position:relative;box-shadow:0 1px 3px #0000000f}.msg-item:hover{border-color:#2563eb;box-shadow:0 4px 12px #00000014}.msg-avatar{color:#fff;background:#1e3a5f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex}.msg-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.msg-top-row{justify-content:space-between;align-items:center;display:flex}.msg-name{color:#1e293b;font-size:15px;font-weight:600}.msg-time{color:#94a3b8;flex-shrink:0;font-size:12px}.msg-order-tag{color:#64748b;text-overflow:ellipsis;white-space:nowrap;background:#f1f5f9;border-radius:4px;width:fit-content;max-width:300px;padding:2px 8px;font-size:12px;display:inline-block;overflow:hidden}.msg-preview{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.msg-badge{color:#fff;background:#dc2626;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:700;display:flex}.chat-page{background:#f8fafc;flex-direction:column;height:100vh;display:flex}.chat-loading{color:#64748b;flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.chat-header{background:#1e3a5f;flex-shrink:0;align-items:center;gap:12px;padding:12px 16px;display:flex}.chat-back-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:none;border-radius:6px;outline:none;padding:6px 14px;font-size:14px;transition:all .2s}.chat-back-btn:hover{background:#ffffff40}.chat-header-info{flex-direction:column;gap:2px;min-width:0;display:flex}.chat-header-name{color:#fff;font-size:16px;font-weight:600}.chat-header-order{color:#ffffffb3;text-overflow:ellipsis;white-space:nowrap;max-width:400px;font-size:12px;overflow:hidden}.chat-header-order:hover{color:#fff}.chat-messages{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:8px;padding:16px;display:flex;overflow-y:auto}.chat-empty{color:#94a3b8;flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.chat-bubble-row{display:flex}.chat-bubble-row.mine{justify-content:flex-end}.chat-bubble-row.other{justify-content:flex-start}.chat-bubble{word-wrap:break-word;overflow-wrap:break-word;border-radius:16px;max-width:70%;padding:10px 14px;position:relative}.bubble-mine{color:#fff;background:#2563eb;border-bottom-right-radius:4px}.bubble-other{color:#1e293b;background:#fff;border-bottom-left-radius:4px;box-shadow:0 1px 3px #00000014}.chat-text-msg{white-space:pre-wrap;font-size:14px;line-height:1.5}.chat-image-msg{cursor:pointer;border-radius:8px;max-width:100%;max-height:240px;display:block}.chat-time{opacity:.6;margin-top:4px;font-size:10px}.bubble-mine .chat-time{text-align:right;color:#ffffffb3}.bubble-other .chat-time{color:#94a3b8}.chat-error{color:#dc2626;text-align:center;background:#fef2f2;border-top:1px solid #fecaca;padding:8px 16px;font-size:13px}.chat-input-area{background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 16px;display:flex}.chat-textarea{resize:none;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:20px;outline:none;flex:1;max-height:120px;padding:8px 14px;font-family:inherit;font-size:14px;line-height:1.4;transition:border-color .2s}.chat-textarea:focus{background:#fff;border-color:#2563eb}.chat-img-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:50%;outline:none;flex-shrink:0;width:40px;height:40px;font-size:11px;font-weight:700;transition:all .2s}.chat-img-btn:hover{color:#2563eb;background:#e2e8f0}.chat-img-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:20px;outline:none;flex-shrink:0;height:40px;padding:8px 20px;font-size:14px;font-weight:600;transition:all .2s}.chat-send-btn:hover{background:#1d4ed8}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed;background:#2563eb}@media (width<=640px){.chat-bubble{max-width:85%}.chat-header-order{max-width:200px}.chat-input-area{padding:8px 12px}.chat-messages{padding:12px 8px}}@media (width<=480px){.chat-bubble{max-width:90%;padding:8px 12px}.chat-text-msg{font-size:13px}.chat-send-btn{padding:8px 14px;font-size:13px}}@supports (padding:env(safe-area-inset-bottom)){.chat-input-area{padding-bottom:calc(12px + env(safe-area-inset-bottom))}}.floating-chat-btn{color:#fff;cursor:pointer;z-index:998;-webkit-transition:background .2s,-webkit-transform .15s;-moz-transition:background .2s,-moz-transform .15s;background:#1e40af;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:background .2s,transform .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 3px 12px #00000040}.floating-chat-btn:hover{background:#1d4ed8;transform:scale(1.08)}.floating-chat-btn.has-unread{background:#dc2626}.floating-chat-btn .unread-dot{background:#facc15;border:2px solid #1e40af;border-radius:50%;width:10px;height:10px;position:absolute;top:6px;right:6px}.floating-chat-panel{z-index:999;background:#fff;border-radius:12px;flex-direction:column;width:360px;max-width:calc(100vw - 32px);height:500px;max-height:calc(100vh - 80px);display:flex;position:fixed;bottom:24px;right:24px;overflow:hidden;box-shadow:0 8px 32px #0003}.chat-panel-header{color:#fff;background:#1e40af;flex-shrink:0;align-items:center;padding:12px 16px;display:flex}.chat-panel-header h3{white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0;font-size:15px;font-weight:600;overflow:hidden}.chat-panel-header .back-btn,.chat-panel-header .close-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.chat-panel-header .back-btn{margin-right:8px}.chat-panel-header .back-btn:hover,.chat-panel-header .close-btn:hover{background:#ffffff26}.chat-panel-body{flex-direction:column;flex:1;display:flex;overflow-y:auto}.tickets-list{flex:1;padding:12px;overflow-y:auto}.create-ticket-btn{color:#1e40af;cursor:pointer;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;width:100%;margin-bottom:12px;padding:10px;font-size:14px;font-weight:500}.create-ticket-btn:hover{background:#eff6ff;border-color:#1e40af}.empty-tickets{text-align:center;color:#64748b;padding:40px 16px}.empty-tickets .hint{color:#94a3b8;margin-top:8px;font-size:13px}.ticket-item{cursor:pointer;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:8px;padding:12px;transition:background .15s}.ticket-item:hover{background:#f1f5f9}.ticket-item.has-reply{border-left:3px solid #f59e0b}.ticket-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.ticket-subject{color:#1e293b;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.reply-badge{color:#fff;text-align:center;background:#ef4444;border-radius:10px;min-width:18px;padding:1px 6px;font-size:11px;font-weight:600}.ticket-meta{color:#64748b;align-items:center;gap:8px;font-size:12px;display:flex}.ticket-meta .status.open{color:#f59e0b;font-weight:500}.ticket-meta .status.closed{color:#10b981}.create-form{flex-direction:column;flex:1;padding:16px;display:flex}.create-form .ai-tip{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:6px;margin-bottom:12px;padding:10px 12px;font-size:13px;line-height:1.5}.create-form .ai-tip strong{color:#047857}.create-form label{color:#1e293b;margin-bottom:6px;font-size:14px;font-weight:500}.create-form textarea{resize:none;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:10px;font-size:14px}.create-form textarea:focus{border-color:#1e40af;outline:none}.char-count{color:#94a3b8;text-align:right;margin-top:4px;font-size:12px}.create-form .submit-btn{color:#fff;cursor:pointer;background:#1e40af;border:none;border-radius:6px;width:100%;margin-top:12px;padding:10px;font-size:14px;font-weight:500}.create-form .submit-btn:disabled{cursor:not-allowed;background:#94a3b8}.form-hint{color:#94a3b8;text-align:center;margin-top:12px;font-size:12px}.message-thread{flex-direction:column;flex:1;display:flex;overflow:hidden}.messages-container{flex:1;padding:12px;overflow-y:auto}.no-messages{text-align:center;color:#64748b;padding:40px 16px;font-size:14px}.message{margin-bottom:12px}.message .message-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.message .sender{color:#1e293b;font-size:12px;font-weight:600}.message.admin .sender{color:#1e40af}.message .time{color:#94a3b8;font-size:11px}.message .message-body{color:#1e293b;word-break:break-word;border-radius:8px;padding:8px 12px;font-size:14px;line-height:1.5}.message.user .message-body{background:#f1f5f9}.message.admin .message-body{background:#eff6ff}.message.ai .sender{color:#059669}.message.ai .message-body{white-space:pre-wrap;background:#ecfdf5;border:1px solid #a7f3d0}.message-input{border-top:1px solid #e2e8f0;flex-shrink:0;padding:12px}.message-input textarea{resize:none;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:8px;font-size:14px}.message-input textarea:focus{border-color:#1e40af;outline:none}.input-actions{justify-content:flex-end;margin-top:8px;display:flex}.send-btn{color:#fff;cursor:pointer;background:#1e40af;border:none;border-radius:4px;padding:6px 16px;font-size:13px}.send-btn:disabled{cursor:not-allowed;background:#94a3b8}.ticket-closed{text-align:center;color:#64748b;border-top:1px solid #e2e8f0;flex-shrink:0;padding:16px}.new-ticket-btn{color:#fff;cursor:pointer;background:#1e40af;border:none;border-radius:6px;margin-top:8px;padding:8px 16px;font-size:13px}.ticket-actions{text-align:center;border-top:1px solid #e2e8f0;flex-shrink:0;padding:8px 12px}.close-ticket-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #cbd5e1;border-radius:4px;padding:6px 16px;font-size:12px}.close-ticket-btn:hover{color:#ef4444;border-color:#ef4444}.close-ticket-btn:disabled{opacity:.5;cursor:not-allowed}.support-thread{border:1px solid #e2e8f0;border-radius:6px;max-height:400px;margin-bottom:12px;padding:12px;overflow-y:auto}.support-msg{margin-bottom:12px}.support-msg-meta{align-items:center;gap:8px;margin-bottom:4px;font-size:12px;display:flex}.support-msg-meta strong{color:#1e293b}.support-msg-meta span{color:#94a3b8}.support-msg.admin .support-msg-meta strong{color:#1e40af}.support-msg-body{word-break:break-word;border-radius:6px;padding:8px 12px;font-size:14px;line-height:1.5}.support-msg.user .support-msg-body{background:#f1f5f9}.support-msg.admin .support-msg-body{background:#eff6ff}.support-msg.ai .support-msg-meta strong{color:#059669}.support-msg.ai .support-msg-body{white-space:pre-wrap;background:#ecfdf5;border:1px solid #a7f3d0}.support-reply-area{margin-top:8px}.support-reply-area textarea{resize:none;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:10px;font-size:14px}.support-reply-area textarea:focus{border-color:#1e40af;outline:none}.admin-filter-tabs{gap:4px;margin-bottom:16px;display:flex}.admin-filter-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:6px 16px;font-size:13px}.admin-filter-btn.active{color:#fff;background:#1e40af;border-color:#1e40af}.admin-toolbar{margin-bottom:12px}@media (width<=480px){.floating-chat-btn{width:48px;height:48px;bottom:16px;right:16px}.floating-chat-panel{border-radius:0;width:100%;max-width:100%;height:100vh;max-height:100vh;bottom:0;left:0;right:0}}
