/* MPL Tickets Portal - tickets.darrengrech.com */
:root {
  --red:#C8102E; --red2:#e8162f; --red-glow:rgba(200,16,46,.2);
  --gold:#F0A500; --green:#00D084; --blue:#3B82F6; --warn:#F59E0B;
  --bg:#08080D; --bg2:#0F0F17; --bg3:#14141E;
  --s1:#1A1A26; --s2:#22222E; --s3:#2A2A38;
  --b1:rgba(255,255,255,.06); --b2:rgba(255,255,255,.11);
  --t1:#F2F2FA; --t2:#8A8AA8; --t3:#4A4A68;
  --f:'Outfit',sans-serif; --fd:'Syne',sans-serif;
  --r:12px; --rs:8px; --rl:20px;
  --sh:0 4px 24px rgba(0,0,0,.4); --sh-lg:0 8px 48px rgba(0,0,0,.6);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f);background:var(--bg);color:var(--t1);min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px}

/* NAV */
.tnav{position:sticky;top:0;z-index:100;background:rgba(8,8,13,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--b1)}
.tnav-inner{max-width:1100px;margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;gap:16px}
.tnav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.tnav-logo-icon{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--red),#ff3553);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--red-glow);flex-shrink:0}
.tnav-logo-name{font-family:var(--fd);font-size:14px;font-weight:800;white-space:nowrap}
.tnav-logo-sub{font-size:9.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.tnav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.tlink{padding:7px 13px;border-radius:var(--rs);font-size:13px;font-weight:500;color:var(--t2);transition:all .15s}
.tlink:hover,.tlink.active{background:var(--s1);color:var(--t1)}
.tbtn{background:var(--red);color:#fff;border-radius:var(--rs);padding:8px 18px;font-size:13px;font-weight:700;transition:all .15s;white-space:nowrap}
.tbtn:hover{background:var(--red2);transform:translateY(-1px)}
.tbtn-outline{border:1px solid var(--b2);color:var(--t2);border-radius:var(--rs);padding:7px 14px;font-size:13px;font-weight:600;transition:all .15s}
.tbtn-outline:hover{background:var(--s1);color:var(--t1)}
.tnav-mob{display:none;background:none;border:none;color:var(--t2);padding:6px;cursor:pointer;flex-shrink:0}

/* FLASH */
.tflash{padding:12px 24px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;max-width:1100px;margin:0 auto}
.tflash.ok{color:var(--green)}.tflash.err{color:#ff5577}

/* PAGE WRAPPER */
.tpage{max-width:1100px;margin:0 auto;padding:40px 20px}
.tpage-sm{max-width:520px;margin:0 auto;padding:40px 20px}
.tpage-md{max-width:760px;margin:0 auto;padding:40px 20px}

/* HERO */
.thero{position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center;justify-content:center;padding:60px 20px;text-align:center}
.thero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(200,16,46,.16) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 80% 70%,rgba(240,165,0,.07) 0%,transparent 60%)}
.thero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:40px 40px;mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.4) 0%,transparent 70%)}
.thero-content{position:relative;z-index:1;max-width:700px}
.thero-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(200,16,46,.1);border:1px solid rgba(200,16,46,.2);border-radius:20px;padding:6px 16px;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--red2);margin-bottom:22px;text-transform:uppercase}
.thero-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--red2);animation:blink 1.5s ease infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.thero h1{font-family:var(--fd);font-size:clamp(36px,6vw,68px);font-weight:800;line-height:1.05;letter-spacing:-.04em;margin-bottom:18px}
.thero h1 span{color:var(--red)}
.thero p{font-size:clamp(14px,2vw,17px);color:var(--t2);line-height:1.6;max-width:520px;margin:0 auto 32px}
.thero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.thero-stats{display:flex;justify-content:center;gap:36px;margin-top:48px;padding-top:36px;border-top:1px solid var(--b1);flex-wrap:wrap}
.thero-stat-v{font-family:var(--fd);font-size:26px;font-weight:800}
.thero-stat-l{font-size:11px;color:var(--t3);margin-top:3px}

/* SECTION */
.tsec{padding:72px 20px;max-width:1100px;margin:0 auto}
.tsec-label{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.tsec h2{font-family:var(--fd);font-size:clamp(22px,3vw,34px);font-weight:800;letter-spacing:-.03em;margin-bottom:6px}
.tsec-sub{font-size:13.5px;color:var(--t3);margin-bottom:32px}

/* FIXTURE CARDS */
.tfix-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.tfix-card{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r);padding:20px;transition:all .18s;cursor:pointer;position:relative;overflow:hidden}
.tfix-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--red)}
.tfix-card:hover{transform:translateY(-2px);border-color:var(--b2);box-shadow:var(--sh)}
.tfix-md{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:14px}
.tfix-matchup{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:16px}
.tfix-team{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}
.tfix-logo{width:50px;height:50px;border-radius:50%;background:var(--s2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;overflow:hidden;flex-shrink:0;border:2px solid var(--b1)}
.tfix-logo img{width:100%;height:100%;object-fit:contain}
.tfix-tname{font-size:12.5px;font-weight:700;text-align:center;line-height:1.2}
.tfix-vs{text-align:center;flex-shrink:0;padding:0 6px}
.tfix-vs-date{font-family:var(--fd);font-size:10px;font-weight:800;color:var(--red);letter-spacing:.04em;text-transform:uppercase}
.tfix-vs-time{font-size:20px;font-weight:800;color:var(--t2);margin:3px 0;font-family:var(--fd)}
.tfix-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:11.5px}
.tfix-venue{color:var(--t3)}
.tfix-price{font-weight:700;color:var(--gold)}
.tfix-avail{font-size:9.5px;font-weight:800;padding:3px 9px;border-radius:20px}
.tfix-avail.on{background:rgba(0,208,132,.1);color:var(--green)}
.tfix-avail.few{background:rgba(245,158,11,.1);color:var(--warn)}
.tfix-avail.out{background:rgba(200,16,46,.1);color:#ff5577}
.tfix-btn{width:100%;margin-top:14px;background:var(--red);color:#fff;border:none;border-radius:var(--rs);padding:11px;font-size:13.5px;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}
.tfix-btn:hover{background:var(--red2)}
.tfix-btn:disabled{background:var(--s3);color:var(--t3);cursor:default}

/* BUTTONS */
.btn-red{background:var(--red);color:#fff;border:none;border-radius:var(--rs);padding:13px 28px;font-size:14.5px;font-weight:700;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.btn-red:hover{background:var(--red2);transform:translateY(-2px);box-shadow:0 6px 24px var(--red-glow)}
.btn-ghost{background:var(--s1);color:var(--t1);border:1px solid var(--b2);border-radius:var(--rs);padding:13px 28px;font-size:14.5px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.btn-ghost:hover{background:var(--s2)}
.btn-block{width:100%;justify-content:center}
.btn-sm-r{background:var(--red);color:#fff;border:none;border-radius:var(--rs);padding:8px 16px;font-size:12.5px;font-weight:700;cursor:pointer;transition:all .15s}
.btn-sm-r:hover{background:var(--red2)}
.btn-sm-g{background:var(--s2);color:var(--t2);border:1px solid var(--b1);border-radius:var(--rs);padding:8px 16px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-sm-g:hover{background:var(--s3);color:var(--t1)}

/* MODAL */
.tmodal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(10px)}
.tmodal-overlay.hidden{display:none}
.tmodal{background:var(--bg2);border:1px solid var(--b2);border-radius:var(--rl);width:100%;max-width:520px;max-height:92vh;overflow-y:auto}
.tmodal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--b1);position:sticky;top:0;background:var(--bg2);z-index:1}
.tmodal-head h2{font-family:var(--fd);font-size:17px;font-weight:800}
.tmodal-close{background:none;border:none;color:var(--t3);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .15s}
.tmodal-close:hover{background:var(--s1);color:var(--t1)}
.tmodal-body{padding:22px}
.tmodal-match{display:flex;align-items:center;justify-content:space-between;background:var(--s1);border-radius:var(--r);padding:16px;margin-bottom:20px;gap:10px}
.tmodal-team{text-align:center;flex:1;min-width:0}
.tmodal-team-logo{width:46px;height:46px;border-radius:50%;margin:0 auto 8px;overflow:hidden;background:var(--s2);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}
.tmodal-team-logo img{width:100%;height:100%;object-fit:contain}
.tmodal-team-name{font-size:13px;font-weight:700;line-height:1.2}
.tmodal-vs{text-align:center;flex-shrink:0;padding:0 8px}
.tmodal-vs-date{font-family:var(--fd);font-size:10px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.04em}
.tmodal-vs-time{font-size:22px;font-weight:800;color:var(--t2);margin:3px 0;font-family:var(--fd)}
.tmodal-vs-venue{font-size:11px;color:var(--t3)}
.ttier-list{display:grid;gap:8px;margin-bottom:18px}
.ttier{display:flex;align-items:center;justify-content:space-between;background:var(--s1);border:2px solid var(--b1);border-radius:var(--r);padding:13px 16px;cursor:pointer;transition:all .15s}
.ttier:hover,.ttier.active{border-color:var(--red);background:rgba(200,16,46,.06)}
.ttier-info h4{font-size:14px;font-weight:600}
.ttier-info p{font-size:11.5px;color:var(--t3);margin-top:2px}
.ttier-price{font-family:var(--fd);font-size:19px;font-weight:800;color:var(--gold);white-space:nowrap}
.tqty-row{display:flex;align-items:center;gap:14px;background:var(--s1);border-radius:var(--r);padding:13px 16px;margin-bottom:18px}
.tqty-label{flex:1;font-size:13.5px;font-weight:600}
.tqty-ctrl{display:flex;align-items:center;gap:12px}
.tqty-btn{width:32px;height:32px;border-radius:50%;background:var(--s2);border:1px solid var(--b2);color:var(--t1);font-size:18px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
.tqty-btn:hover{background:var(--red);border-color:var(--red)}
.tqty-num{font-family:var(--fd);font-size:18px;font-weight:800;min-width:28px;text-align:center}
.tsum{background:var(--s1);border-radius:var(--r);padding:14px 16px;margin-bottom:18px}
.tsum-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:8px;color:var(--t2)}
.tsum-row:last-child{margin-bottom:0;padding-top:10px;border-top:1px solid var(--b1);font-weight:700;font-size:14.5px;color:var(--t1)}
.tsum-row:last-child span:last-child{color:var(--gold)}
.tfan-form{display:grid;gap:12px;margin-bottom:18px}
.tfan-form label{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:5px}
.tfan-form input{width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:var(--rs);padding:10px 13px;color:var(--t1);font-size:13.5px;outline:none;transition:border-color .15s}
.tfan-form input:focus{border-color:rgba(200,16,46,.4)}
.tfan-form input::placeholder{color:var(--t3)}
.tcheckout-btn{width:100%;background:var(--red);color:#fff;border:none;border-radius:var(--rs);padding:14px;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px}
.tcheckout-btn:hover{background:var(--red2);box-shadow:0 4px 20px var(--red-glow)}
.tsecure{text-align:center;font-size:11px;color:var(--t3);margin-top:9px}

/* MY TICKETS */
.tticket-list{display:grid;gap:14px}
.tticket-card{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r);overflow:hidden;transition:all .18s}
.tticket-card:hover{border-color:var(--b2);box-shadow:var(--sh)}
.tticket-top{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid var(--b1)}
.tticket-logos{display:flex;align-items:center;gap:-6px}
.tticket-logos .tfix-logo{width:38px;height:38px;font-size:10px}
.tticket-logos .tfix-logo:last-child{margin-left:-10px;border-color:var(--s1)}
.tticket-info{flex:1;min-width:0}
.tticket-match{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tticket-meta{font-size:11.5px;color:var(--t3);margin-top:3px}
.tticket-status{flex-shrink:0}
.tticket-bottom{display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--bg3)}
.tticket-ref{font-family:'JetBrains Mono',monospace,'Courier New',monospace;font-size:11.5px;color:var(--t3);flex:1}
.tticket-seat{font-size:12px;color:var(--t2)}
.tticket-price{font-size:13px;font-weight:700;color:var(--gold);margin-left:auto}
.tticket-actions{display:flex;gap:8px;flex-shrink:0}

/* TICKET DETAIL / DIGITAL TICKET */
.digital-ticket{
  background:#fff;
  border-radius:var(--r);
  overflow:hidden;
  max-width:440px;
  margin:0 auto;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  color:#1a1a2e;
}
.dt-header{background:linear-gradient(135deg,#C8102E,#8B0820);color:#fff;padding:20px 24px;display:flex;align-items:center;gap:12px}
.dt-header-logo{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}
.dt-header h2{font-family:'Syne',sans-serif;font-size:16px;font-weight:800}
.dt-header p{font-size:11px;opacity:.8;margin-top:1px}
.dt-header-right{margin-left:auto;text-align:right}
.dt-header-right strong{display:block;font-size:13px;font-weight:700}
.dt-header-right span{font-size:10px;opacity:.75}
.dt-match{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:2px dashed #e5e7eb;background:#f9f9fc}
.dt-team{text-align:center;flex:1}
.dt-team-logo{width:52px;height:52px;border-radius:50%;margin:0 auto 8px;overflow:hidden;background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;color:#666}
.dt-team-logo img{width:100%;height:100%;object-fit:contain}
.dt-team-name{font-size:13.5px;font-weight:800;color:#1a1a2e;line-height:1.2}
.dt-vs{text-align:center;flex-shrink:0;padding:0 12px}
.dt-vs-date{font-size:10px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.05em}
.dt-vs-time{font-size:26px;font-weight:900;color:#1a1a2e;margin:4px 0;font-family:'Syne',sans-serif}
.dt-vs-venue{font-size:10.5px;color:#6b7280}
.dt-details{padding:18px 24px;display:grid;grid-template-columns:1fr 1fr;gap:12px;border-bottom:2px dashed #e5e7eb}
.dt-detail-item label{display:block;font-size:9.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;margin-bottom:4px}
.dt-detail-item span{font-size:13px;font-weight:700;color:#1a1a2e}
.dt-detail-item.full{grid-column:1/-1}
.dt-seat-map{padding:16px 24px;border-bottom:2px dashed #e5e7eb;background:#f9f9fc}
.dt-seat-map h4{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;margin-bottom:10px}
.dt-seat-svg{width:100%;max-width:380px;margin:0 auto;display:block}
.dt-qr{padding:20px 24px;display:flex;align-items:center;gap:20px;background:#fff}
.dt-qr-code{flex-shrink:0;background:#fff;padding:8px;border:2px solid #e5e7eb;border-radius:8px}
.dt-qr-code canvas,.dt-qr-code img{width:110px;height:110px}
.dt-qr-info{flex:1;min-width:0}
.dt-qr-info h3{font-size:13px;font-weight:800;color:#1a1a2e;margin-bottom:6px}
.dt-qr-info p{font-size:11px;color:#6b7280;line-height:1.5}
.dt-booking-id{font-family:'Courier New',monospace;font-size:10px;background:#f3f4f6;padding:5px 8px;border-radius:5px;color:#374151;margin-top:8px;word-break:break-all;display:block}
.dt-wallet-btns{padding:14px 24px;display:flex;gap:8px;background:#f9f9fc;flex-wrap:wrap}
.dt-wallet-btn{display:flex;align-items:center;gap:8px;background:#000;color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;flex:1;justify-content:center}
.dt-wallet-btn:hover{background:#222}
.dt-wallet-btn.goog{background:#fff;color:#000;border:1px solid #e5e7eb}
.dt-wallet-btn.goog:hover{background:#f5f5f5}
.dt-footer{padding:16px 24px;background:#f9f9fc;border-top:1px solid #e5e7eb;font-size:10.5px;color:#9ca3af;line-height:1.55}
.dt-footer strong{color:#6b7280}
.dt-footer-ids{display:flex;gap:16px;margin-top:8px;flex-wrap:wrap}
.dt-footer-ids span{font-family:'Courier New',monospace;font-size:9.5px}
.dt-tear{height:2px;background:repeating-linear-gradient(90deg,#e5e7eb 0,#e5e7eb 8px,transparent 8px,transparent 14px);margin:0}

/* AUTH FORMS */
.tauth-card{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r);padding:32px;width:100%;max-width:420px;margin:0 auto}
.tauth-card h1{font-family:var(--fd);font-size:22px;font-weight:800;margin-bottom:6px;letter-spacing:-.02em}
.tauth-card .sub{font-size:13px;color:var(--t3);margin-bottom:24px}
.tform-group{margin-bottom:16px}
.tform-group label{display:block;font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.tform-group input,.tform-group select{width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:var(--rs);padding:11px 14px;color:var(--t1);font-size:13.5px;outline:none;transition:border-color .15s}
.tform-group input:focus{border-color:rgba(200,16,46,.4);box-shadow:0 0 0 3px rgba(200,16,46,.1)}
.tform-group input::placeholder{color:var(--t3)}
.tauth-alt{text-align:center;margin-top:16px;font-size:13px;color:var(--t3)}
.tauth-alt a{color:var(--red);font-weight:600}

/* BADGE */
.tbadge{display:inline-flex;align-items:center;font-size:9.5px;font-weight:800;padding:2px 9px;border-radius:20px;white-space:nowrap}
.tbadge.ok{background:rgba(0,208,132,.1);color:var(--green)}
.tbadge.warn{background:rgba(245,158,11,.1);color:var(--warn)}
.tbadge.used{background:rgba(100,100,100,.15);color:var(--t3)}
.tbadge.cancelled{background:rgba(200,16,46,.1);color:#ff5577}

/* HOW IT WORKS */
.tsteps{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.tstep{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r);padding:22px;text-align:center}
.tstep-num{width:42px;height:42px;border-radius:50%;background:rgba(200,16,46,.1);border:2px solid rgba(200,16,46,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 13px;font-family:var(--fd);font-size:17px;font-weight:800;color:var(--red)}
.tstep h3{font-family:var(--fd);font-size:14px;font-weight:700;margin-bottom:7px}
.tstep p{font-size:12.5px;color:var(--t3);line-height:1.55}
.tfeatures{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.tfeature{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r);padding:20px}
.tfeature-ico{font-size:26px;margin-bottom:11px}
.tfeature h3{font-family:var(--fd);font-size:14px;font-weight:700;margin-bottom:6px}
.tfeature p{font-size:12.5px;color:var(--t3);line-height:1.55}

/* FOOTER */
.tfooter{background:var(--bg2);border-top:1px solid var(--b1);padding:40px 20px}
.tfooter-inner{max-width:1100px;margin:0 auto}
.tfooter-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.tfooter-links{display:flex;gap:20px;flex-wrap:wrap;font-size:12.5px;color:var(--t3);margin-bottom:20px}
.tfooter-links a:hover{color:var(--t1)}
.tfooter-bottom{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-top:20px;border-top:1px solid var(--b1);font-size:11px;color:var(--t3)}

/* PWA BANNER */
.tpwa{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:linear-gradient(135deg,#8B0820,var(--red));color:#fff;padding:13px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 -4px 24px rgba(0,0,0,.5);transform:translateY(100%);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.tpwa.show{transform:translateY(0)}
.tpwa-ico{width:40px;height:40px;border-radius:9px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.tpwa-text{flex:1}.tpwa-text strong{display:block;font-size:13px;font-weight:700}.tpwa-text span{font-size:11.5px;opacity:.85}
.tpwa-acts{display:flex;gap:7px;flex-shrink:0}
.tpwa-install{background:#fff;color:var(--red);border:none;border-radius:7px;padding:7px 14px;font-size:12.5px;font-weight:700;cursor:pointer}
.tpwa-skip{background:rgba(255,255,255,.15);color:#fff;border:none;border-radius:7px;padding:7px 11px;font-size:12.5px;cursor:pointer}
.ttoast{position:fixed;bottom:20px;right:20px;z-index:99999;background:var(--s2);border:1px solid var(--b2);border-radius:var(--rs);padding:12px 18px;font-size:13px;font-weight:600;box-shadow:var(--sh-lg);transform:translateY(70px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none;max-width:320px;display:flex;align-items:center;gap:8px}
.ttoast.show{transform:translateY(0);opacity:1}
.ttoast.ok{border-left:3px solid var(--green)}
.ttoast.err{border-left:3px solid var(--red)}

/* EMPTY STATE */
.tempty{text-align:center;padding:60px 20px;color:var(--t3)}
.tempty-ico{font-size:56px;margin-bottom:16px}
.tempty h3{font-family:var(--fd);font-size:20px;font-weight:800;color:var(--t2);margin-bottom:8px}
.tempty p{font-size:13.5px;margin-bottom:24px}

/* RESPONSIVE */
@media(max-width:768px){
  .tnav-links{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg2);border-bottom:1px solid var(--b1);flex-direction:column;padding:12px;gap:4px}
  .tnav-links.open{display:flex}
  .tnav-mob{display:block}
  .tnav-inner{position:relative}
  .thero{min-height:78vh;padding:40px 16px}
  .tsec{padding:48px 16px}
  .tpage{padding:24px 16px}
  .tpage-sm,.tpage-md{padding:24px 16px}
  .tfix-grid{grid-template-columns:1fr}
  .tmodal-overlay{align-items:flex-end;padding:0}
  .tmodal{border-radius:var(--rl) var(--rl) 0 0;max-height:92vh;max-width:100%}
  .tticket-card .tticket-actions{flex-wrap:wrap}
  .tsteps{grid-template-columns:1fr 1fr}
  .tfeatures{grid-template-columns:1fr}
  .thero-stats{gap:20px}
  .dt-details{grid-template-columns:1fr}
  .dt-match{padding:14px 16px}
  .digital-ticket{max-width:100%}
  .dt-qr{flex-direction:column;align-items:flex-start}
  .tfooter-bottom{flex-direction:column;align-items:flex-start}
  .tpwa-acts .tpwa-skip{display:none}
}
@media(max-width:480px){
  .tsteps{grid-template-columns:1fr}
  .thero h1{letter-spacing:-.03em}
  .thero-btns{flex-direction:column}
  .dt-wallet-btns{flex-direction:column}
  .tticket-bottom{flex-wrap:wrap}
}
@media print{
  .tnav,.tfooter,.tpwa,.tfix-btn,.tticket-actions,.dt-wallet-btns,.btn-red,.btn-ghost{display:none!important}
  body{background:#fff;color:#000}
  .digital-ticket{box-shadow:none;border:1px solid #ccc;max-width:100%}
}
