
@font-face{font-family:SBB;src:url("../assets/SBBWeb-Roman.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:SBB;src:url("../assets/SBBWeb-Bold.woff2") format("woff2");font-weight:700;font-display:swap}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:SBB,"Helvetica Neue",Helvetica,Arial,sans-serif;background:#fff;color:#212121;-webkit-font-smoothing:antialiased;padding-bottom:88px}
img{max-width:100%;height:auto;display:block}
button{font:inherit;cursor:pointer;border:none}

.sbb-header{background:#fff;padding:16px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:12px}
.sbb-header img.sbb-logo{height:32px;width:auto}
.sbb-header img.sbb-pos{height:28px;width:auto;margin-left:auto}

.sbb-hero{background:#eb0000;color:#fff;position:relative;overflow:hidden}
.sbb-hero-pattern{position:absolute;inset:0;opacity:.08;background:url("../assets/sbb-arrow.png") center/120px repeat}
.sbb-hero-inner{position:relative;z-index:2;max-width:520px;margin:0 auto;padding:36px 20px 40px}
.sbb-kicker{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;opacity:.9;margin-bottom:12px}
.sbb-hero h1{font-size:clamp(30px,8vw,40px);font-weight:700;line-height:1.1;letter-spacing:-.3px;margin-bottom:14px}
.sbb-hero p{font-size:16px;line-height:1.55;opacity:.95;margin-bottom:24px;max-width:34em}

.sbb-ticket{background:#fff;color:#212121;border-radius:8px;padding:20px;box-shadow:0 12px 40px rgba(0,0,0,.2)}
.sbb-ticket-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:2px dashed #eee}
.sbb-ticket-head img{height:24px}
.sbb-ticket-type{font-size:11px;font-weight:700;color:#eb0000;text-transform:uppercase;letter-spacing:.6px}
.sbb-amount{font-size:clamp(36px,9vw,44px);font-weight:700;color:#eb0000;letter-spacing:-1px;line-height:1}
.sbb-amount small{font-size:.4em;vertical-align:super;font-weight:700}
.sbb-was{font-size:16px;color:#999;text-decoration:line-through;margin-right:8px}
.sbb-save{display:inline-block;background:#fef2f2;color:#eb0000;font-size:12px;font-weight:700;padding:4px 10px;border-radius:4px;margin:10px 0 14px}
.sbb-meta{font-size:13px;color:#666;margin-bottom:16px}
.sbb-meta strong{color:#eb0000}

.sbb-btn{width:100%;background:#eb0000;color:#fff;font-size:16px;font-weight:700;padding:16px;border-radius:4px;display:flex;align-items:center;justify-content:center;gap:8px}
.sbb-btn:active{background:#c90000}
.sbb-btn:disabled{opacity:.55}
.sbb-btn svg{width:18px;height:18px;fill:currentColor}

.sbb-body{max-width:520px;margin:0 auto}
.sbb-block{padding:28px 20px;border-top:1px solid #eee}
.sbb-block h2{font-size:18px;font-weight:700;margin-bottom:14px;color:#212121}
.sbb-check{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid #f5f5f5;font-size:14px;line-height:1.5;color:#444}
.sbb-check:last-child{border-bottom:none}
.sbb-check::before{content:"";width:20px;height:20px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 11'%3E%3Cpath d='M13.707.707 4.707 9.697 0 5.697l.707-.707 3.646 3.647L13 0z' fill='%23EB0000'/%3E%3C/svg%3E") center/contain no-repeat;margin-top:2px}

.sbb-steps{counter-reset:n;list-style:none;padding:0}
.sbb-steps li{counter-increment:n;padding:14px 0 14px 40px;position:relative;font-size:14px;color:#444;border-bottom:1px solid #f0f0f0}
.sbb-steps li::before{content:counter(n);position:absolute;left:0;width:28px;height:28px;border:2px solid #eb0000;color:#eb0000;border-radius:50%;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}

.sbb-foot{padding:28px 20px 36px;text-align:center;font-size:11px;color:#999;line-height:1.55}
.sbb-foot img{height:28px;margin:0 auto 12px}

.sbb-bar{position:fixed;left:0;right:0;bottom:0;z-index:200;background:#fff;border-top:3px solid #eb0000;padding:12px 16px calc(12px + env(safe-area-inset-bottom));display:flex;gap:12px;align-items:center;max-width:520px;margin:0 auto;transition:transform .25s;box-shadow:0 -4px 16px rgba(0,0,0,.08)}
.sbb-bar--hidden{transform:translateY(110%)}
.sbb-bar .sbb-btn{width:auto;padding:14px 20px;font-size:14px}
.sbb-bar-amt{flex:1;font-size:22px;font-weight:700;color:#eb0000}

@media(min-width:600px){body{padding-bottom:0}.sbb-bar{display:none}}
#pay-bar.pay-bar--hidden{transform:translateY(110%)}
