.customer-display-page{width:100vw;height:100vh;overflow:hidden;background:#edf2f7;color:#0f172a}.active-display,.idle-display{width:100vw;height:100vh;padding:16px;background:#e8eef4}.idle-display{position:relative}.active-display,.idle-display{overflow:hidden}.idle-display-image{position:absolute;inset:0;z-index:0;background-repeat:no-repeat;background-position:50%;background-size:cover;opacity:0;-webkit-transform:scale(1.02);transform:scale(1.02);-webkit-transition:opacity .7s ease,-webkit-transform 4.5s ease;transition:opacity .7s ease,-webkit-transform 4.5s ease;transition:opacity .7s ease,transform 4.5s ease;transition:opacity .7s ease,transform 4.5s ease,-webkit-transform 4.5s ease}.idle-display-image.active{opacity:1;-webkit-transform:scale(1);transform:scale(1)}.idle-display-overlay{position:absolute;inset:0;z-index:1;background:-webkit-gradient(linear,left top,left bottom,from(rgba(15,23,42,.28)),to(rgba(15,23,42,.08)));background:linear-gradient(180deg,rgba(15,23,42,.28),rgba(15,23,42,.08))}.idle-display .display-glass-header{position:relative;z-index:2}.active-header,.display-glass-header{height:80px;display:grid;grid-template-columns:360px minmax(0,1fr) 260px;gap:14px;border:1px solid rgba(219,228,239,.58);border-radius:16px;background:hsla(0,0%,100%,.52);-webkit-box-shadow:0 8px 24px rgba(15,23,42,.12);box-shadow:0 8px 24px rgba(15,23,42,.12);backdrop-filter:blur(9px) saturate(1.18);-webkit-backdrop-filter:blur(9px) saturate(1.18);overflow:hidden}.active-header,.display-brand,.display-glass-header{-webkit-box-align:center;-ms-flex-align:center;align-items:center}.display-brand{min-width:0;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start;padding:8px 26px}.display-brand img{max-width:300px;max-height:58px;width:auto;height:auto;-o-object-fit:contain;object-fit:contain}.display-logo-fallback{width:54px;height:54px;border-radius:12px;background:#e9f2ff;color:#375f96;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;font-size:24px;font-weight:900}.active-branch,.active-source,.display-branch,.display-status{min-width:0}.active-branch,.display-branch{text-align:center}.active-source,.display-status{text-align:right;padding-right:22px}.active-branch strong,.active-source strong,.display-branch strong,.display-status strong{display:block;color:#0f172a;font-size:20px;line-height:1.2;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.active-branch span,.active-source span,.display-branch span,.display-status span{display:block;margin-top:4px;color:#60749a;font-size:12px;line-height:1.2;font-weight:900;letter-spacing:0;text-transform:uppercase}.active-grid{height:calc(100vh - 124px);margin-top:12px;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:170px minmax(0,1fr);gap:12px}.display-panel{background:#fff;border:1px solid #dbe4ef;border-radius:16px;-webkit-box-shadow:0 2px 8px rgba(15,23,42,.12);box-shadow:0 2px 8px rgba(15,23,42,.12);overflow:hidden}.student-panel{grid-column:span 8;padding:10px;display:grid;grid-template-columns:132px minmax(0,1fr);grid-template-rows:auto minmax(0,1fr);gap:12px}.student-identity{min-width:0;display:contents}.student-avatar{width:132px;height:132px;border-radius:12px;background:#f1f5f9;color:#8fa2bf;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;font-size:54px;overflow:hidden}.student-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.student-panel-empty,.student-pending{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.student-pending{width:100%;height:100%;min-height:132px;border-radius:12px;background:#f8fafc;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:8px;color:#60749a;text-align:center}.student-pending-icon{width:52px;height:52px;border-radius:14px;background:#fff;color:#8fa2bf;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;font-size:26px;border:1px solid #dbe4ef;-webkit-box-shadow:0 3px 8px rgba(15,23,42,.08);box-shadow:0 3px 8px rgba(15,23,42,.08)}.student-pending strong{color:#0f172a;font-size:18px;font-weight:800}.student-pending span{max-width:560px;font-size:14px;line-height:1.4}.student-name-block{min-width:0;position:relative;padding:0 110px 0 0;-ms-flex-item-align:start;align-self:start}.student-code{position:absolute;top:2px;right:0;max-width:104px;padding:6px 11px;border-radius:8px;background:#eef2f7;color:#375f96;font-size:12px;line-height:1.2;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-name-block h1,.student-name-block h2{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-name-block h1{padding-top:4px;padding-bottom:2px;font-size:24px;line-height:1.5;font-weight:900;color:#0f172a}.student-name-block h2{margin-top:-2px;padding-bottom:1px;font-size:15px;line-height:1.35;font-weight:800;color:#1f2a44}.student-info-grid{grid-column:2;min-width:0;align-self:end;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 18px}.student-info-item{min-width:0;display:grid;grid-template-columns:22px minmax(82px,auto) minmax(0,1fr);-webkit-column-gap:9px;-moz-column-gap:9px;column-gap:9px}.student-info-item,.student-info-item i{-webkit-box-align:center;-ms-flex-align:center;align-items:center}.student-info-item i{width:22px;height:22px;border-radius:6px;display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;font-size:12px}.info-date i{color:#2563eb;background:#dbeafe}.info-phone i{color:#059669;background:#d1fae5}.info-gender i{color:#7c3aed;background:#ede9fe}.info-grade i{color:#1d4ed8;background:#dbeafe}.info-dob i{color:#f97316;background:#ffedd5}.student-info-grid span,.summary-panel span{color:#475569;font-size:13px;line-height:1.2;font-weight:800;white-space:nowrap}.student-info-grid strong,.summary-panel strong{min-width:0;color:#020617;font-size:13px;line-height:1.2;font-weight:900;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-panel{grid-column:span 4;padding:12px;display:grid;grid-template-rows:24px minmax(0,1fr);gap:8px;background:linear-gradient(135deg,#fff,#f8fbff)}.summary-title{gap:8px;font-size:12px;font-weight:900;text-transform:uppercase}.summary-title,.summary-title i{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;color:#60749a}.summary-title i{width:24px;height:24px;border-radius:8px;background:#fff;border:1px solid #dbe4ef;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.payment-metrics{min-height:0;display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:repeat(2,minmax(0,1fr));gap:8px}.payment-card{min-height:0;border-radius:12px;border:1px solid #dbe4ef;background:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;gap:14px;padding:10px 14px}.payment-card,.payment-card-label{min-width:0;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.payment-card-label{gap:9px;color:#60749a}.payment-card-label,.payment-card-label i{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex}.payment-card-label i{width:24px;height:24px;-webkit-box-flex:0;-ms-flex:0 0 24px;flex:0 0 24px;border-radius:50%;background:#eff6ff;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.payment-card-label span{color:#60749a;font-size:11px;text-transform:uppercase}.payment-card strong{color:#020617;font-size:24px;line-height:1.05;font-weight:900}.paid-card{background:#ecfdf5;border-color:#a7f3d0}.paid-card .payment-card-label,.paid-card .payment-card-label span,.paid-card strong{color:#047857}.paid-card .payment-card-label i{background:#d1fae5}.items-panel{grid-column:span 8;min-height:0;overflow:hidden}.items-panel table{width:100%;table-layout:fixed;border-collapse:collapse;font-size:14px}.items-panel th{padding:11px 10px;background:#f8fafc;color:#1f2a44;font-size:12px;font-weight:800;text-align:left;border-bottom:2px solid #cbd5e1}.items-panel td{padding:10px 10px;border-bottom:1px solid #edf2f7;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.items-panel tr:nth-child(odd) td{background:#f8fafc}.items-panel td:first-child,.items-panel td:nth-child(4),.items-panel th:first-child,.items-panel th:nth-child(4){text-align:center}.items-panel td:nth-child(5),.items-panel td:nth-child(6),.items-panel th:nth-child(5),.items-panel th:nth-child(6){text-align:right}.col-no{width:7%}.col-type{width:20%}.col-qty{width:9%}.col-price{width:15%}.col-total{width:16%}.empty-row{height:330px;text-align:center!important;color:#64748b!important}.items-empty{min-height:330px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;gap:8px;color:#8aa0bf}.items-empty i{color:#cbd5e1;font-size:42px}.items-empty strong{color:#334155;font-size:16px;font-weight:800}.items-empty span{font-size:14px}.qr-panel{grid-column:span 4;min-height:0;padding:16px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.qr-card{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;max-width:260px;max-height:100%;border-radius:clamp(12px,2.2vh,18px);overflow:hidden;border:1px solid #e7e7e7;-webkit-box-shadow:0 18px 35px rgba(15,23,42,.12);box-shadow:0 18px 35px rgba(15,23,42,.12)}.qr-header{height:14%;min-height:36px;max-height:60px;background:#fff;overflow:hidden}.qr-header img{width:100%;height:100%;display:block;-o-object-fit:fill;object-fit:fill}.qr-body{height:86%;min-height:0;padding:clamp(6px,1.15vh,10px);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center;background:#fff}.qr-content{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;max-width:100%}.qr-payee{width:100%;min-height:clamp(12px,1.8vh,18px);color:#334155;font-size:clamp(10px,1.65vh,14px);line-height:1.3;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qr-amount{width:100%;margin-top:clamp(2px,.55vh,5px);padding-bottom:clamp(5px,.9vh,9px);border-bottom:1px dashed #94a3b8;color:#020617;font-size:clamp(18px,3.35vh,28px);line-height:1.08;font-weight:900}.qr-canvas-wrap{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;min-height:0;margin:0;padding:clamp(8px,1.4vh,14px) 0 clamp(3px,.7vh,8px);background:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.qr-generated-wrap{-webkit-box-shadow:none;box-shadow:none}.qr-placeholder{width:min(82%,24vh);max-width:220px;aspect-ratio:1;margin:auto 0;border-radius:10px;border:solid #0f172a;color:#0f172a;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;gap:8px;font-weight:800}.qr-placeholder img{width:clamp(42px,8vh,74px);height:clamp(42px,8vh,74px);-o-object-fit:contain;object-fit:contain}.qr-empty{width:100%;height:100%;min-height:0;border:1px dashed #dbe4ef;border-radius:16px;background:#f8fafc;color:#60749a;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;gap:10px;text-align:center}.qr-empty i{font-size:clamp(28px,5.5vh,44px);color:#cbd5e1}.qr-empty strong{color:#334155;font-size:clamp(16px,2.6vh,20px);font-weight:800}.payment-success-overlay{position:fixed;inset:0;z-index:1000;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;padding:24px;background:rgba(15,23,42,.34);backdrop-filter:blur(12px) saturate(.9);-webkit-backdrop-filter:blur(12px) saturate(.9)}.payment-success-card,.payment-success-overlay{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.payment-success-card{width:min(680px,calc(100vw - 48px));border-radius:28px;background:linear-gradient(135deg,hsla(0,0%,100%,.78),rgba(236,253,245,.56));border:1px solid hsla(0,0%,100%,.82);-webkit-box-shadow:0 28px 80px rgba(15,23,42,.26);box-shadow:0 28px 80px rgba(15,23,42,.26);-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;text-align:center;padding:32px 24px 24px;overflow:hidden}.payment-success-icon{width:50px;height:50px;border-radius:50%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;background:#10b981;color:#fff;font-size:24px;-webkit-box-shadow:0 16px 36px rgba(16,185,129,.34);box-shadow:0 16px 36px rgba(16,185,129,.34)}.payment-success-title-kh{margin-top:22px;color:#111827;font-size:25px;line-height:1.55;font-weight:900}.payment-success-title{margin-top:0;color:#059669;font-size:18px;line-height:1.2;font-weight:900}.payment-success-detail{width:100%;margin-top:20px;border-radius:14px;overflow:hidden;border:1px solid rgba(226,232,240,.95);background:hsla(0,0%,100%,.62);-webkit-box-shadow:inset 0 1px 0 hsla(0,0%,100%,.72);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.72);text-align:left}.payment-success-received,.payment-success-student{padding:14px}.payment-success-student{min-height:78px;background:hsla(0,0%,100%,.66)}.payment-success-received{min-height:94px;background:rgba(167,243,208,.42);border-top:1px solid rgba(203,213,225,.78)}.payment-success-received span,.payment-success-student span{display:block;color:#64748b;font-size:11px;line-height:1.2;font-weight:900;letter-spacing:.16em;text-transform:uppercase}.payment-success-student strong{display:block;max-width:100%;margin-top:10px;color:#0f172a;font-size:18px;line-height:1.35;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payment-success-received strong{display:block;margin-top:16px;color:#047857;font-size:30px;line-height:1.1;font-weight:900}.payment-success-footer{width:100%;margin-top:14px;border-radius:14px;background:#1f2937;color:#fff;font-size:15px;line-height:1.35;font-weight:900;padding:13px 18px}.payment-success-enter-active,.payment-success-leave-active{-webkit-transition:opacity .2s ease;transition:opacity .2s ease}.payment-success-enter-active .payment-success-card,.payment-success-leave-active .payment-success-card{-webkit-transition:-webkit-transform .2s ease;transition:-webkit-transform .2s ease;transition:transform .2s ease;transition:transform .2s ease,-webkit-transform .2s ease}.payment-success-enter,.payment-success-leave-to{opacity:0}.payment-success-enter .payment-success-card,.payment-success-leave-to .payment-success-card{-webkit-transform:translateY(8px) scale(.98);transform:translateY(8px) scale(.98)}@media (max-width:760px){.active-header,.display-glass-header{grid-template-columns:220px minmax(0,1fr) 220px}.active-grid{grid-template-rows:auto minmax(0,1fr) minmax(300px,40vh)}.items-panel,.qr-panel,.student-panel,.summary-panel{grid-column:span 12}.student-panel{grid-template-columns:minmax(0,1fr)}.student-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.payment-metrics{grid-template-columns:minmax(0,1fr)}}