/* ============================================
   X™ — TrageLink-Inspired Design
   Dark theme + Green (#4ADE80) accents
   ============================================ */
:root {
  --bg:#0A0A0A;--bg2:#111111;--bg3:#1A1A1A;--bg4:#222222;
  --green:#4ADE80;--green-dim:rgba(74,222,128,.12);--green-glow:rgba(74,222,128,.25);
  --lime:#BEF264;--amber:#FBBF24;--red:#EF4444;--blue:#60A5FA;
  --txt:#FFFFFF;--txt2:rgba(255,255,255,.55);--txt3:rgba(255,255,255,.28);
  --border:rgba(255,255,255,.06);--border2:rgba(255,255,255,.1);
  --r:16px;--rs:12px;--rx:8px;
  --nav:72px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --font2:'Space Grotesk',var(--font);
  /* Fallbacks for modals added recently */
  --panel: var(--bg2);
  --text: var(--txt);
  --text-dim: var(--txt2);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{font-family:var(--font);background:#FFFFFF;color:var(--txt);overflow:hidden;height:100%;width:100%;-webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none;transition:background 0.5s ease;}
.hidden{display:none!important}
.app{height:100%;width:100%;position:relative}

/* ===== SPLASH — X™ text ===== */
.splash{position:fixed;inset:0;z-index:1000;background:#FFFFFF;display:flex;align-items:center;justify-content:center;flex-direction:column;animation:splashOut .6s ease 2.6s forwards}
.splash-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;position:relative;width:100%}
.splash-x{font-family:var(--font2);font-size:120px;font-weight:900;color:#0A0A0A;line-height:1;animation:splashXIn .8s cubic-bezier(.34,1.56,.64,1)}
.splash-tm{font-size:24px;font-weight:700;vertical-align:super;color:#0A0A0A}
.splash-bar{width:120px;height:3px;background:#E5E5E5;border-radius:3px;overflow:hidden;margin-top:30px}
.splash-bar-fill{height:100%;width:0;background:#0A0A0A;border-radius:3px;animation:splashBarFill 2.2s ease forwards .3s}
.splash-copy{position:absolute;bottom:40px;left:0;right:0;text-align:center;font-size:10px;letter-spacing:3px;color:#AAAAAA;font-weight:500}
@keyframes splashXIn{0%{opacity:0;transform:scale(.5)}100%{opacity:1;transform:scale(1)}}
@keyframes splashBarFill{0%{width:0}100%{width:100%}}
@keyframes splashOut{to{opacity:0;pointer-events:none}}

/* SCREENS */
.screen{position:absolute;inset:0;bottom:var(--nav);display:none;flex-direction:column;opacity:0;transform:translateX(20px);transition:opacity .3s,transform .3s}
.screen.active{display:flex;opacity:1;transform:none}
.screen-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:16px}
.screen-scroll::-webkit-scrollbar{display:none}

/* TOP BAR */
.top-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;position:sticky;top:0;z-index:10;background:linear-gradient(180deg,var(--bg) 70%,transparent)}
.top-title{font-size:17px;font-weight:700}
.btn-back{width:40px;height:40px;border:none;background:var(--bg3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--txt);cursor:pointer;transition:.2s}
.btn-back:active{transform:scale(.9);background:var(--bg4)}

/* HEADER */
.header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0}
.header-left{display:flex;align-items:center;gap:12px}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;font-weight:800;color:#0A0A0A}
.header-welcome{display:block;font-size:12px;color:var(--txt2)}
.header-name{display:block;font-size:15px;font-weight:700}
.header-bell{width:40px;height:40px;border:none;background:var(--bg3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--txt2);cursor:pointer;position:relative}
.bell-dot{display:none;position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green-glow)}
.bell-dot.show{display:block}

/* HERO */
.hero-title{font-family:var(--font2);font-size:28px;font-weight:700;line-height:1.15;letter-spacing:-.5px;padding:16px 20px 0}

/* CAT TABS */
.cat-tabs{display:flex;gap:0;margin:20px 20px 0;background:var(--bg3);border-radius:var(--rs);padding:3px;border:1px solid var(--border)}
.cat-tab{flex:1;padding:10px;border:none;background:none;border-radius:10px;color:var(--txt2);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:.25s}
.cat-tab.active{background:var(--green);color:#0A0A0A}
.cat-tab:active{transform:scale(.97)}

/* TAB CONTENT */
.tab-content{display:none;animation:fadeUp .35s ease}
.tab-content.active{display:block}
@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}100%{opacity:1;transform:none}}

/* DATE SCROLLER — animated, smooth */
.date-scroller-wrap{overflow:visible;padding:0;position:relative}
.date-scroller-wrap::after{content:'';position:absolute;top:0;right:0;width:50px;height:100%;background:linear-gradient(90deg,transparent,var(--bg));pointer-events:none;z-index:2}
.date-scroller{display:flex;gap:10px;padding:20px 20px 8px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scrollbar-width:none;cursor:grab}
.date-scroller:active{cursor:grabbing}
.date-scroller::-webkit-scrollbar{display:none}
.date-item{min-width:60px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:5px;border-radius:var(--rs);background:var(--bg3);border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--txt2);cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);scroll-snap-align:start;flex-shrink:0;opacity:0;animation:dateSlideIn .5s cubic-bezier(.4,0,.2,1) forwards;position:relative;overflow:hidden}
.date-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(74,222,128,.06),transparent 70%);opacity:0;transition:opacity .3s}
.date-item:hover::before{opacity:1}
.date-item:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.3)}
.date-item .di-day{font-size:20px;font-weight:800;color:var(--txt);transition:all .3s}
.date-item .di-month{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;transition:all .3s}
.date-item.today{border-color:var(--green);background:var(--green-dim);box-shadow:0 0 15px rgba(74,222,128,.15)}
.date-item.today .di-day{color:var(--green)}
.date-item.today::after{content:'';position:absolute;bottom:3px;width:16px;height:2px;border-radius:2px;background:var(--green)}
.date-item.event{border-color:rgba(74,222,128,.3)}
.date-item.event .di-day{color:var(--green)}
.date-item.event:hover{border-color:var(--green);box-shadow:0 0 20px rgba(74,222,128,.15)}
.date-item.booked{border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.06)}
.date-item.booked .di-day{color:var(--red)}
.date-item.booked::after{content:'';position:absolute;top:5px;right:5px;width:5px;height:5px;border-radius:50%;background:var(--red);animation:dotPulse 2s infinite}
.date-item:active{transform:scale(.9)!important;transition-duration:.1s}
@keyframes dateSlideIn{0%{opacity:0;transform:translateX(20px) scale(.85)}60%{transform:translateX(-3px) scale(1.02)}100%{opacity:1;transform:none}}

/* SEASON BANNER */
.season-banner{margin:16px 20px 0;padding:18px 20px;background:linear-gradient(135deg,rgba(74,222,128,.08),rgba(190,242,100,.04));border:1px solid rgba(74,222,128,.15);border-radius:var(--r);position:relative;overflow:hidden}
.season-banner-glow{position:absolute;top:-30px;right:-30px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(74,222,128,.2),transparent 70%);animation:glowPulse 3s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}
.season-banner-content{position:relative;z-index:1}
.season-banner-badge{display:inline-block;padding:3px 10px;background:var(--green);color:#0A0A0A;border-radius:6px;font-size:11px;font-weight:800;letter-spacing:1px;margin-bottom:8px}
.season-banner-title{display:block;font-family:var(--font2);font-size:16px;font-weight:700}
.season-banner-sub{display:block;font-size:12px;color:var(--txt2);margin-top:2px}

/* EVENTS LIST */
.events-section{padding:0 0 0}
.section-top{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px}
.section-title{font-size:17px;font-weight:700}
.section-link{font-size:13px;color:var(--green);font-weight:600;cursor:pointer}
.section-badge-sm{padding:3px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;font-size:10px;font-weight:700;letter-spacing:1px;color:var(--txt3)}
.events-list{padding:0 20px}

.event-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;cursor:pointer;transition:.25s;position:relative;overflow:hidden}
.event-card:active{transform:scale(.98)}
.event-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--green);border-radius:0 3px 3px 0}
.event-card.booked-card::before{background:var(--red)}
.ec-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.ec-badge{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--green)}
.ec-badge .ec-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:dotPulse 2s infinite}
@keyframes dotPulse{0%,100%{opacity:1}50%{opacity:.3}}
.ec-stage{padding:3px 8px;background:var(--green-dim);border-radius:6px;font-size:10px;font-weight:700;color:var(--green);letter-spacing:.5px}
.ec-name{font-family:var(--font2);font-size:18px;font-weight:700;margin-bottom:4px}
.ec-dates{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.ec-date-chip{padding:5px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rx);font-size:11px;font-weight:600;color:var(--txt2);display:flex;align-items:center;gap:4px}
.ec-date-chip.booked-chip{border-color:rgba(239,68,68,.3);color:var(--red);background:rgba(239,68,68,.06)}
.ec-slots{margin-top:10px;display:flex;align-items:center;gap:6px}
.ec-slot-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700}
.ec-slot-badge.open{background:var(--green-dim);color:var(--green);border:1px solid rgba(74,222,128,.2)}
.ec-slot-badge.limited{background:rgba(251,191,36,.08);color:var(--amber);border:1px solid rgba(251,191,36,.2)}
.ec-slot-badge.full{background:rgba(239,68,68,.08);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.ec-book-btn{margin-top:12px;width:100%;padding:10px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--rx);color:var(--txt);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:6px}
.ec-book-btn:active{background:var(--bg4)}
.ec-book-btn.ec-book-green{background:var(--green-dim);border-color:rgba(74,222,128,.2);color:var(--green)}

/* OFFER CARD */
.offer-card{margin:16px 20px 0;padding:0;background:linear-gradient(145deg,var(--bg2),var(--bg3));border:1px solid rgba(74,222,128,.15);border-radius:var(--r);overflow:hidden;position:relative}
.offer-ribbon{position:absolute;top:28px;right:-30px;background:var(--green);color:#0A0A0A;font-size:9px;font-weight:800;letter-spacing:1.5px;padding:4px 40px;transform:rotate(30deg);z-index:1;overflow:hidden}
.offer-ribbon::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.7),transparent);animation:ribbonShine 2.5s ease-in-out infinite}
@keyframes ribbonShine{0%{left:-100%}100%{left:200%}}
.offer-content{padding:24px 20px 20px;position:relative}
.offer-title{font-family:var(--font2);font-size:20px;font-weight:700;margin-bottom:8px}
.offer-desc{font-size:13px;color:var(--txt2);line-height:1.5;margin-bottom:12px}
.offer-desc strong{color:var(--green)}
.offer-timer{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--green);font-weight:600;line-height:1.4}

/* PRICING CATEGORY CARDS */
.pricing-cats{padding:0 20px;display:flex;flex-direction:column;gap:10px}
.pcat-card{display:flex;align-items:center;gap:14px;padding:18px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.pcat-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(74,222,128,.04),transparent);opacity:0;transition:opacity .3s}
.pcat-card:hover::before{opacity:1}
.pcat-card:hover{border-color:rgba(74,222,128,.2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.pcat-card:active{transform:scale(.98)}
.pcat-icon{font-size:32px;width:56px;height:56px;border-radius:14px;background:var(--green-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pcat-info{flex:1;min-width:0}
.pcat-name{font-family:var(--font2);font-size:17px;font-weight:700}
.pcat-sub{font-size:12px;color:var(--txt2);margin-top:3px}
.pcat-price{font-size:14px;font-weight:800;color:var(--green);margin-top:5px}
.pcat-arrow{color:var(--txt3);flex-shrink:0;transition:transform .3s}
.pcat-card:hover .pcat-arrow{transform:translateX(3px);color:var(--green)}

/* PRICING DETAIL SUB-VIEW */
.pricing-detail{padding:0}
.pricing-detail.hidden{display:none}
.pricing-back{display:flex;align-items:center;gap:6px;padding:12px 20px;font-family:var(--font);font-size:14px;font-weight:600;color:var(--green);background:none;border:none;cursor:pointer;transition:.2s}
.pricing-back:active{opacity:.6}
.pd-subtitle{padding:4px 20px;font-size:12px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:1px}

/* LOYALTY PROGRAM */
.loyalty-card{margin:0 20px;padding:20px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);position:relative;overflow:hidden}
.loyalty-card::before{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(74,222,128,.08),transparent 70%)}
.loyalty-progress{width:100%;height:6px;background:var(--bg4);border-radius:4px;overflow:hidden;margin-bottom:12px}
.lp-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--lime));border-radius:4px;transition:width .6s ease}
.loyalty-status{font-size:13px;color:var(--txt2);margin-bottom:14px}
.loyalty-status strong{color:var(--txt)}
.loyalty-tiers{display:flex;gap:8px}
.lt-tier{flex:1;padding:12px 8px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);text-align:center;transition:all .3s;position:relative}
.lt-tier.active{border-color:var(--green);background:var(--green-dim)}
.lt-tier.active .lt-name{color:var(--green)}
.lt-medal{font-size:24px;margin-bottom:4px}
.lt-name{font-size:12px;font-weight:700;margin-bottom:2px}
.lt-req{font-size:9px;color:var(--txt3);margin-bottom:4px}
.lt-perk{font-size:11px;font-weight:800;color:var(--green)}

/* SEASON CALC — clickable */
.season-calc{padding:0 20px}
.sc-section-lbl{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--txt3);padding:8px 0 6px;text-transform:uppercase}
.sc-row{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);margin-bottom:8px;animation:fadeUp .3s ease backwards;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.sc-row::after{content:'Купить →';position:absolute;right:14px;bottom:6px;font-size:9px;font-weight:700;color:var(--green);opacity:0;transform:translateY(4px);transition:all .3s}
.sc-row:hover{border-color:rgba(74,222,128,.25);background:rgba(74,222,128,.03);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.2)}
.sc-row:hover::after{opacity:1;transform:none}
.sc-row:active{transform:scale(.98)}
.sc-icon{font-size:16px;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sc-icon.personal{background:rgba(96,165,250,.1)}
.sc-icon.team{background:rgba(74,222,128,.1)}
.sc-info{flex:1;min-width:0}
.sc-name{font-size:13px;font-weight:700}
.sc-sub{font-size:10px;color:var(--txt2);margin-top:2px}
.sc-prices{text-align:right;flex-shrink:0}
.sc-price-old{font-size:10px;color:var(--txt3);text-decoration:line-through}
.sc-price{font-size:15px;font-weight:800;color:var(--green)}

/* TARIFF LIST */
.tariffs-list{padding:0 20px}
.tariff-row{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:10px;cursor:pointer;transition:.25s;position:relative;overflow:hidden}
.tariff-row:active{transform:scale(.98)}
.tariff-row.featured{border-color:rgba(74,222,128,.25)}
.tariff-row.featured::after{content:'ТОП';position:absolute;top:8px;right:8px;padding:2px 7px;background:var(--green);color:#0A0A0A;border-radius:4px;font-size:9px;font-weight:800;letter-spacing:.5px}
.tr-num{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.tr-num.n1{background:rgba(74,222,128,.1)}
.tr-num.n2{background:rgba(96,165,250,.1)}
.tr-num.n3{background:rgba(251,191,36,.1)}
.tr-info{flex:1;min-width:0}
.tr-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pb-date {font-size: 11px; color: var(--text-dim); margin-top: 5px; opacity: 0.8;}

/* MODALS */
.modal {
  position: fixed; inset: 0; background: rgba(0,0,0,0.8); z-index: 1000;
  display: flex; align-items: center; justify-content: center; backdrop-filter: blur(5px);
}
.modal.hidden { display: none; }
.modal-content {
  background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
  padding: 20px; width: 90%; max-width: 360px; box-shadow: 0 10px 40px rgba(0,0,0,0.5);
  animation: slideUp 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* AVATARS */
.avatar-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-height: 400px;
  overflow-y: auto; padding-right: 5px;
}
.av-opt {
  aspect-ratio: 1; border-radius: 8px; border: 2px solid transparent; cursor: pointer;
  background-size: cover; background-position: center; transition: 0.2s;
  background-color: #222;
}
.av-opt.sel { border-color: var(--green); transform: scale(1.05); box-shadow: 0 0 10px var(--green); }
.av-letter { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:24px; font-weight:700; color:var(--text); background:#222; border-radius:8px; }

/* Clickable Status */
.ts-status-b { cursor: pointer; transition: 0.2s; }
.ts-status-b:hover { transform: scale(1.05); opacity: 0.9; }
.lty-tier { cursor: pointer; transition: 0.2s; }
.lty-tier:hover { transform: translateY(-2px); }
.tr-desc{font-size:11px;color:var(--txt2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tr-prices{text-align:right;flex-shrink:0}
.tr-price{font-size:16px;font-weight:800}
.tr-season{font-size:10px;color:var(--green);margin-top:2px}

/* TEAMS */
.div-filter{display:flex;gap:6px;padding:16px 20px 0;overflow-x:auto}
.div-filter::-webkit-scrollbar{display:none}
.div-btn{padding:8px 18px;border:1px solid var(--border);background:var(--bg3);border-radius:20px;color:var(--txt2);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:.2s;white-space:nowrap;flex-shrink:0}
.div-btn.active{background:var(--green);color:#0A0A0A;border-color:var(--green)}
.div-btn:active{transform:scale(.95)}
.teams-stats{padding:12px 20px 8px;font-size:12px;color:var(--txt3)}
.teams-list{padding:0 20px}
.team-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);margin-bottom:8px;animation:teamIn .3s ease backwards}
@keyframes teamIn{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:none}}
.team-badge{width:32px;height:32px;border-radius:8px;background:var(--green-dim);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--green);flex-shrink:0}
.team-name{font-size:13px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team-div-badge{padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px}
.team-div-badge.td1{background:rgba(239,68,68,.1);color:var(--red)}
.team-div-badge.td2{background:rgba(251,191,36,.1);color:var(--amber)}
.team-div-badge.td3{background:rgba(96,165,250,.1);color:var(--blue)}
.team-div-badge.td4{background:rgba(74,222,128,.1);color:var(--green)}

/* CALENDAR */
.month-nav{display:flex;align-items:center;justify-content:center;gap:20px;padding:8px 20px}
.mn-btn{width:34px;height:34px;border:none;background:var(--bg3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--txt2);cursor:pointer;transition:.2s}
.mn-btn:active{transform:scale(.85);background:var(--bg4)}
.mn-label{font-size:15px;font-weight:700;min-width:140px;text-align:center}
.cal-grid{padding:8px 16px}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:6px}
.cal-head span{font-size:11px;font-weight:600;color:var(--txt3);padding:6px 0}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cd{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--rs);font-size:14px;font-weight:600;cursor:pointer;border:none;background:none;color:var(--txt);font-family:var(--font);transition:.2s;position:relative;gap:2px}
.cd:active{transform:scale(.88)}
.cd.other{color:var(--txt3)}
.cd.past{color:var(--txt3);cursor:default}.cd.past:active{transform:none}
.cd.today{background:var(--bg3);border:1px solid var(--border2)}
.cd.free{background:rgba(74,222,128,.06)}
.cd.free:hover{background:rgba(74,222,128,.12)}
.cd.event-day{background:rgba(74,222,128,.1);color:var(--green)}
.cd.booked-day{background:rgba(239,68,68,.08);color:var(--red);cursor:default}.cd.booked-day:active{transform:none}
.cd.selected{background:var(--green)!important;color:#0A0A0A!important;box-shadow:0 0 20px var(--green-glow);transform:scale(1.05)}
.cd .cd-dot{width:4px;height:4px;border-radius:50%;position:absolute;bottom:4px}
.cd.free .cd-dot{background:var(--green)}
.cd.booked-day .cd-dot{background:var(--red)}
.cd-rxl{position:absolute;bottom:1px;font-size:7px;font-weight:800;text-transform:uppercase;color:var(--green);animation:pulseRXL 1.5s infinite;}
@keyframes pulseRXL{0%,100%{opacity:0.4}50%{opacity:1;text-shadow:0 0 5px var(--green)}}
.cal-legend{display:flex;justify-content:center;gap:14px;padding:8px 20px;flex-wrap:wrap}
.lg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--txt2)}
.lg-dot{width:10px;height:10px;border-radius:50%}
.lg-free{background:rgba(74,222,128,.2);border:2px solid var(--green)}
.lg-event{background:var(--green)}
.lg-booked{background:rgba(239,68,68,.2);border:2px solid var(--red)}
.cal-selected{margin:12px 20px;padding:16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);animation:fadeUp .3s ease}
.cs-date{font-size:16px;font-weight:700;margin-bottom:4px}
.cs-event{font-size:12px;color:var(--green);margin-bottom:10px}
.cs-fullday{font-size:12px;color:var(--txt2);padding:8px 12px;background:var(--bg3);border-radius:var(--rx);display:inline-block}
.cal-action{padding:12px 20px}
.btn-primary{width:100%;padding:16px;border:none;background:var(--green);border-radius:var(--rs);color:#0A0A0A;font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-primary:active{transform:scale(.97);opacity:.9}
.btn-primary.disabled{opacity:.25;cursor:default}.btn-primary.disabled:active{transform:none;opacity:.25}

/* FORM */
.form-wrap{padding:0 20px}
.fg{margin-bottom:14px}.fl{display:block;font-size:12px;font-weight:600;color:var(--txt2);margin-bottom:5px}
.fi-wrap{display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);transition:.2s}
.fi-wrap:focus-within{border-color:var(--green)}
.fi-wrap svg{color:var(--txt3);flex-shrink:0}
.fi{flex:1;padding:13px 0;border:none;background:none;color:var(--txt);font-family:var(--font);font-size:14px;outline:none}
.fi::placeholder{color:var(--txt3)}
.fi-tag{padding:3px 8px;background:var(--green-dim);border:1px solid rgba(74,222,128,.2);border-radius:6px;font-size:10px;font-weight:700;color:var(--green);white-space:nowrap}
.fi-sel{appearance:none;-webkit-appearance:none}
.fi-sel-wrap{position:relative}
.f-type-toggle{display:flex;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);overflow:hidden;padding:2px;margin-bottom:14px}
.ft-opt-btn{flex:1;position:relative;cursor:pointer}
.ft-opt-btn input{position:absolute;opacity:0}
.ft-opt-btn span{display:block;text-align:center;padding:12px;font-size:13px;font-weight:600;color:var(--txt2);transition:all .2s;border-radius:calc(var(--rs) - 2px)}
.ft-opt-btn input:checked + span{background:var(--green-dim);color:var(--green)}
.sel-arr{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--txt3);pointer-events:none}
.form-row{display:flex;gap:10px}.fg-half{flex:1}
.f-tariffs{display:flex;flex-direction:column;gap:6px}
.tariff-details{background:var(--bg3);border:1.5px dashed var(--border);border-radius:var(--rs);padding:14px;margin-top:6px;animation:fadeUp 0.3s ease;}
.tariff-details ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.tariff-details li{font-size:13px;color:var(--txt2);display:flex;align-items:flex-start;gap:6px}
.tariff-details li::before{content:'✓';color:var(--green);font-weight:bold;}
.ft-opt{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--rs);cursor:pointer;transition:.2s}
.ft-opt:active{transform:scale(.98)}
.ft-opt.sel{border-color:var(--green);background:var(--green-dim)}
.ft-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.2s}
.ft-opt.sel .ft-radio{border-color:var(--green)}
.ft-opt.sel .ft-radio::after{content:'';width:9px;height:9px;border-radius:50%;background:var(--green)}
.ft-info{flex:1;min-width:0}
.ft-name{font-size:13px;font-weight:700}.ft-sub{font-size:10px;color:var(--txt2);margin-top:1px}
.ft-price{font-size:14px;font-weight:800;flex-shrink:0}
.season-row{display:flex;align-items:center;justify-content:space-between;padding:14px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);margin-bottom:14px}
.sr-label{font-size:13px;font-weight:600}.sr-sub{display:block;font-size:11px;color:var(--green);margin-top:2px}
.switch{position:relative;width:46px;height:26px;cursor:pointer}
.switch input{opacity:0;width:0;height:0}
.switch-sl{position:absolute;inset:0;background:var(--bg4);border-radius:13px;border:1px solid var(--border);transition:.3s}
.switch-sl::before{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--txt3);transition:.3s}
.switch input:checked+.switch-sl{background:var(--green-dim);border-color:var(--green)}
.switch input:checked+.switch-sl::before{transform:translateX(20px);background:var(--green)}
.summary{padding:14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);margin-bottom:16px}
.sum-r{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;color:var(--txt2)}
.sum-r span:last-child{font-weight:600;color:var(--txt)}
.sum-div{height:1px;background:var(--border);margin:8px 0}
.sum-total span:first-child{font-size:14px;font-weight:700;color:var(--txt)}
.sum-total span:last-child{font-size:18px;font-weight:800;color:var(--green)}
.form-bottom{padding:0 20px 16px}
.btn-pay{background:linear-gradient(135deg,var(--green),#34D399);color:#0A0A0A}

/* TICKET */
.ticket-wrap{padding:16px 20px}
.ticket{background:#FAFAFA;border-radius:20px;overflow:hidden;color:#0A0A0A;animation:ticketIn .6s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px rgba(0,0,0,.5)}
@keyframes ticketIn{0%{opacity:0;transform:translateY(40px) scale(.92)}100%{opacity:1;transform:none}}
.ticket-top{padding:22px 22px 14px}
.ticket-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.ticket-brand{font-family:var(--font2);font-size:24px;font-weight:900;color:#0A0A0A}
.ticket-badge{padding:3px 9px;background:var(--green);border-radius:5px;font-size:9px;font-weight:800;color:#0A0A0A;letter-spacing:1px}
.ticket-id-row{margin-bottom:10px}.ticket-lbl{display:block;font-size:10px;color:#999}.ticket-id{font-size:13px;font-weight:700;font-family:'Courier New',monospace}
.ticket-main{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ticket-c-lbl{display:block;font-size:10px;color:#999;margin-bottom:3px}
.ticket-c-val{font-size:18px;font-weight:800}
.ticket-team-name{font-size:22px}
.ticket-c-r{text-align:right}
.ticket-arrow-wrap{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:0 12px}
.ticket-arrow-line{height:1px;flex:1;background:linear-gradient(90deg,transparent,#ccc,transparent)}
.ticket-arrow-dot{width:8px;height:8px;border-radius:50%;background:var(--green);position:absolute;animation:arrowSlide 3s ease-in-out infinite}
@keyframes arrowSlide{0%{left:20%}50%{left:75%}100%{left:20%}}
.ticket-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ticket-d-lbl{display:block;font-size:10px;color:#999}.ticket-d-val{font-size:13px;font-weight:700}
.ticket-tear{display:flex;align-items:center}.tear-hole{width:22px;height:22px;border-radius:50%;background:var(--bg);flex-shrink:0}
.tear-l{margin-left:-11px}.tear-r{margin-right:-11px}
.tear-line{flex:1;border-top:2px dashed #ddd}
.ticket-bot{padding:14px 22px 22px;text-align:center}
.ticket-price-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.ticket-plbl{font-size:11px;color:#999}.ticket-price{font-size:22px;font-weight:800;color:#16A34A}
.ticket-barcode{display:flex;align-items:center;justify-content:center;gap:2px;height:44px;margin-bottom:6px}
.ticket-barcode .bar{height:100%;background:#0A0A0A;border-radius:1px}
.ticket-bc-text{font-size:10px;color:#999;font-family:'Courier New',monospace;letter-spacing:2px}
.ticket-msg{text-align:center;font-size:13px;color:var(--txt2);margin:16px 0;line-height:1.5}
.ticket-btns{display:flex;gap:10px}
.ticket-btn{flex:1;padding:12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);color:var(--txt);font-family:var(--font);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:.2s}
.ticket-btn:active{transform:scale(.97);background:var(--bg4)}

/* MY BOOKINGS */
.mb-tabs{display:flex;margin:0 20px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);padding:3px}
.mb-tab{flex:1;padding:9px;border:none;background:none;border-radius:10px;color:var(--txt2);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:.2s}
.mb-tab.active{background:var(--bg4);color:var(--txt);border:1px solid var(--border2)}
.mb-list{padding:12px 20px}
.mb-empty{text-align:center;padding:50px 20px;color:var(--txt3);font-size:13px}
.mb-card{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);margin-bottom:8px;cursor:pointer;transition:.2s}
.mb-card:active{transform:scale(.98)}
.mb-icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--green-dim),rgba(74,222,128,.05));display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border:1px solid rgba(74,222,128,.1)}
.mb-info{flex:1;min-width:0}.mb-team{font-size:13px;font-weight:700}.mb-meta{font-size:11px;color:var(--txt2);margin-top:2px}
.mb-price{font-size:14px;font-weight:700;color:var(--green);flex-shrink:0}

/* PROFILE */
@keyframes rotateNeon {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes pulseNeon {
  0%, 100% { opacity: 0.8; text-shadow: 0 0 8px var(--green-glow); }
  50% { opacity: 1; text-shadow: 0 0 16px var(--green); }
}
.avatar-ring {
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--green);
  border-right-color: var(--green);
  animation: rotateNeon 1.5s linear infinite;
  z-index: 1;
  box-shadow: 0 0 10px var(--green-glow);
}
.profile-wrap{padding:16px 20px;text-align:center}
.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;margin:16px auto;font-family:var(--font2);font-size:36px;font-weight:900;color:#0A0A0A}
.profile-name{font-size:20px;font-weight:700;margin-bottom:4px}
.profile-tg{font-size:13px;color:var(--txt2);display:block;margin-bottom:20px}
.profile-card{text-align:left;padding:16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);margin-bottom:12px}
.pc-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.pc-row:last-child{border-bottom:none}
.pc-label{color:var(--txt2)}.pc-val{font-weight:600}
.pc-heading{font-size:14px;font-weight:700;margin-bottom:10px;color:var(--txt)}
.p-purchases{min-height:40px}
.p-purchase-row{display:flex;justify-content:space-between;padding:6px 0;font-size:12px;border-bottom:1px solid var(--border)}
.p-purchase-row:last-child{border-bottom:none}
.p-purchase-row span:last-child{color:var(--green);font-weight:600}
.btn-outline{width:100%;padding:12px;background:none;border:1px solid var(--border2);border-radius:var(--rs);color:var(--red);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:.2s;margin-top:8px}
.btn-outline:active{background:rgba(239,68,68,.06)}
/* GOLD SHIMMER EFFECTS */
.gold-shimmer {
    background: linear-gradient(90deg, #b8860b 0%, #ffd700 25%, #fff 50%, #ffd700 75%, #b8860b 100%);
    background-size: 200% auto;
    color: #000;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shineGold 2.5s linear infinite;
    display: inline-block;
}
@keyframes shineGold {
    to { background-position: -200% center; }
}

.gold-bg-shimmer {
    background: linear-gradient(90deg, #b8860b 0%, #ffd700 20%, #fff 40%, #ffd700 60%, #b8860b 100%) !important;
    background-size: 200% auto !important;
    animation: shineGoldBg 2s linear infinite !important;
}
@keyframes shineGoldBg {
    to { background-position: -200% center; }
}
/* NAV */
.nav{position:absolute;bottom:0;left:0;right:0;height:var(--nav);background:linear-gradient(180deg,rgba(10,10,10,.85) 0%,var(--bg) 40%);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom,0);border-top:1px solid var(--border);z-index:100}
.nav-i{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 14px;border:none;background:none;color:var(--txt3);font-family:var(--font);font-size:10px;font-weight:600;cursor:pointer;transition:.2s;position:relative}
.nav-i.active{color:var(--green)}
.nav-i.active svg{color:var(--green)}
.nav-i.active::after{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:22px;height:3px;border-radius:0 0 3px 3px;background:var(--green)}
.nav-i:active{transform:scale(.88)}


/* ADMIN PANEL STYLING */
.admin-booking-item {
    padding: 12px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--rs);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    text-align: left;
}
.admin-booking-info {
    flex: 1;
    min-width: 0;
}
.admin-booking-team {
    font-size: 13px;
    font-weight: 700;
    color: var(--txt);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.admin-booking-meta {
    font-size: 11px;
    color: var(--txt2);
    margin-top: 3px;
    line-height: 1.4;
}
.admin-booking-price {
    font-size: 13px;
    font-weight: 700;
    color: var(--green);
}
.btn-admin-delete {
    padding: 6px 10px;
    background: rgba(255, 68, 68, 0.08);
    border: 1px solid rgba(255, 68, 68, 0.25);
    border-radius: 6px;
    color: #ff4444;
    font-family: var(--font);
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: 0.2s;
}
.btn-admin-delete:active {
    background: rgba(255, 68, 68, 0.18);
    transform: scale(0.95);
}

@media(min-width:430px){body{display:flex;justify-content:center}.app{max-width:430px}.splash{max-width:430px;left:50%;transform:translateX(-50%)}}
@keyframes shake{0%,100%{transform:translateX(0)}25%,75%{transform:translateX(-5px)}50%{transform:translateX(5px)}}

