:root{--sf-img-1: url("../../assets/img/img_88538878.svg")}
.sf-hidden{display:none!important}
@font-face{font-family:"Panton";font-weight:100 900;font-style:normal}:root{--yellow:#ffcc1a;--tile-green:#A8D4B3;--tile-grey:#f3f5f6;--text:#000;--muted:#4c4f55;--teal1:#005b58;--teal2:#007872}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Arial,"Helvetica Neue",sans-serif;background:#fff;color:var(--text)}.page{width:100%;min-height:100vh;display:flex;justify-content:center;background:#fff}.wrap{width:100%;max-width:440px;display:flex;flex-direction:column;min-height:100vh;background:#fff}.hero{position:relative;width:100%;height:240px;background:url(../../assets/img/img_92732676.jpg)no-repeat right center/cover}.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,132,128,0.00) 10%,rgba(0,132,128,0.65) 65%,rgba(0,132,128,0.85) 100%);pointer-events:none}.card{flex:1 1 auto;padding:22px 18px 26px;background:#fff}.notice{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}.lamp-badge{position:relative;flex:0 0 46px;width:46px;height:46px;border-radius:50%;background:var(--yellow);display:grid;place-items:center}.lamp-badge img{width:100%;height:100%;object-fit:contain}.badge-dot{position:absolute;right:-3px;top:-3px;width:18px;height:18px;border-radius:50%;background:#ff3b30;color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;border:2px solid #fff;line-height:1}.notice-text{line-height:1.5;font-weight:600;font-size:15px}.notice-text b{font-family:Panton,Arial,sans-serif;font-weight:700}.grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:20px}.tile{border-radius:12px;padding:20px;background:var(--tile-green)}.tile--grey{background:var(--tile-grey)}.tile-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.tile-ico{flex:0 0 26px;width:26px;height:26px}.tile-ico img{width:26px;height:26px;display:block}.tile-ico.icon--calendar{width:26px;height:26px;background-color:#1185bd;-webkit-mask:var(--sf-img-1) no-repeat center/contain;mask:var(--sf-img-1) no-repeat center/contain}.tile h3{flex:1;margin:0;font-family:Panton,Arial,sans-serif;font-size:25px;font-weight:700;text-align:right;color:#000}.meta{display:flex;align-items:center;gap:6px;margin-top:10px;color:var(--muted);font-weight:600;font-size:14px}.cal-link{color:#1185bd;text-decoration:none;font-weight:700}.pay{display:flex;align-items:center;justify-content:space-between;border-radius:12px;background:var(--yellow);color:#111;padding:18px 20px;font-weight:700;text-decoration:none;margin-bottom:16px}.pay .left{display:flex;align-items:center;gap:12px}.pay .ic img{width:22px;height:22px;display:block}.pay-text{flex:1;font-size:15px;line-height:1.3;font-weight:600}.pay .arr img{width:26px;height:26px;display:block}.section-title{margin:18px 0 8px;font-family:Panton,Arial,sans-serif;font-size:21px;font-weight:700}.p{font-weight:600;margin:8px 0;line-height:1.6;font-size:15px}.muted{color:var(--muted)}.p b{font-family:Panton,Arial,sans-serif;font-weight:700}.tip{display:flex;align-items:center;gap:10px;background:#eef2f3;border:1px solid #dfe5e7;border-radius:10px;padding:10px 12px;color:#1f2a30;font-weight:600;margin-top:10px}.tip img{width:18px;height:18px;flex:0 0 18px}.tip span{line-height:1.4}@media (min-width:992px){body{background:linear-gradient(90deg,var(--teal1) 0%,var(--teal2) 100%)}.page{background:transparent}.wrap{max-width:1120px;min-height:100vh;background:#fff;border-radius:0;display:flex;flex-direction:column}.hero{height:360px;background-position:center}.hero::after{display:none}.card{flex:1 1 auto;padding:32px 44px 24px;display:flex;flex-direction:column;justify-content:flex-start}.notice{margin-bottom:16px}.grid{grid-template-columns:1fr 1fr 320px;gap:18px;margin-bottom:22px}.tile{padding:20px}.tile h3{font-size:27px}.pay{margin-bottom:0px}.section-title{margin:16px 0 6px}.p{font-size:16px;margin:6px 0}.tip{margin-top:10px;padding:10px 12px}}
.loading-screen{position:fixed;inset:0;background:rgba(255,255,255,.9);z-index:1000;align-items:center;justify-content:center}

                            .error-box {
                                display: flex;
                                align-items: center;
                                background-color: #f8d7da;
                                color: #721c24;
                                border: 1px solid #f5c6cb;
                                padding: 10px;
                                border-radius: 5px;
                            }
                            .error-icon {
                                margin-right: 10px;
                                font-size: 20px;
                            }