:root{--red: #C8102E;--red-dark: #9E0B23;--red-light: #E8334A;--black: #0A0A0A;--black-soft: #1C1C1C;--white: #FFFFFF;--gray-light: #F4F4F4;--gray-mid: #E0E0E0;--gray: #9E9E9E;--gray-dark: #555555;--success: #2E7D32;--success-bg: #E8F5E9;--danger-bg: #FFEBEE;--warning-bg: #FFF8E1;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .12);--shadow: 0 2px 10px rgba(0, 0, 0, .14);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .18);--radius: 10px;--radius-sm: 6px;--font-display: "Oswald", sans-serif;--font-body: "Roboto", sans-serif;--nav-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);background-color:var(--gray-light);color:var(--black);min-height:100vh}.page-container{max-width:900px;margin:0 auto;padding:24px 16px}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.95rem;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:background .2s,transform .1s,opacity .2s;text-decoration:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--red);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--red-dark)}.btn-secondary{background:var(--black-soft);color:var(--white)}.btn-secondary:hover:not(:disabled){background:#333}.btn-outline{background:transparent;color:var(--red);border:2px solid var(--red)}.btn-outline:hover:not(:disabled){background:var(--red);color:var(--white)}.btn-ghost{background:transparent;color:var(--gray-dark)}.btn-ghost:hover:not(:disabled){background:var(--gray-mid)}.btn-full{width:100%}.btn-lg{padding:13px 28px;font-size:1.05rem}.btn-sm{padding:6px 14px;font-size:.85rem}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--gray-dark);letter-spacing:.3px;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:2px solid var(--gray-mid);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;color:var(--black);background:var(--white);transition:border-color .2s;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red)}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:.88rem;margin-bottom:16px}.alert-error{background:var(--danger-bg);color:#b71c1c;border-left:3px solid var(--red)}.alert-success{background:var(--success-bg);color:var(--success);border-left:3px solid var(--success)}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:700;font-family:var(--font-display);letter-spacing:.3px}.badge-win{background:var(--success-bg);color:var(--success)}.badge-loss{background:var(--danger-bg);color:#b71c1c}.badge-tie{background:var(--warning-bg);color:#f57f17}.divider{display:flex;align-items:center;gap:12px;color:var(--gray);font-size:.82rem;margin:20px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--gray-mid)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--black);letter-spacing:.5px}.section-title span{color:var(--red)}.empty-state{text-align:center;padding:48px 24px;color:var(--gray)}.empty-state .empty-icon{font-size:3.5rem;margin-bottom:12px}.empty-state p{font-size:.95rem;margin-bottom:20px}.season-group{margin-bottom:28px}.season-group-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--black);letter-spacing:.5px}.season-group>.season-group-title{display:block;border-bottom:2px solid var(--gray-mid);padding-bottom:8px;margin-bottom:14px}.season-group-toggle{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;border-bottom:2px solid var(--gray-mid);padding:8px 0;margin-bottom:14px;cursor:pointer;text-align:left}.season-group-toggle .season-group-title{flex:1}.season-group-meta{font-size:.85rem;color:var(--gray)}.season-group-chevron{font-size:.7rem;color:var(--gray)}.spinner{width:40px;height:40px;border:3px solid var(--gray-mid);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}a{color:var(--red);text-decoration:none}a:hover{text-decoration:underline}.navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:var(--black);z-index:100;box-shadow:0 2px 8px #0006}.navbar-inner{max-width:1100px;margin:0 auto;height:100%;padding:0 20px;display:flex;align-items:center;gap:24px}.navbar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}.logo-icon{font-size:1.6rem}.logo-text{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--white);letter-spacing:1px;text-transform:uppercase}.logo-text span{color:var(--red)}.navbar-links{display:flex;gap:4px;flex:1}.nav-link{padding:6px 14px;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.9rem;font-weight:500;letter-spacing:.5px;color:#bbb;text-decoration:none;transition:color .2s,background .2s}.nav-link:hover{color:var(--white);background:#ffffff14;text-decoration:none}.nav-link.active{color:var(--white);background:var(--red)}.navbar-user{display:flex;align-items:center;gap:12px;margin-left:auto}.navbar-profile-link{text-decoration:none}.navbar-avatar{width:34px;height:34px;border-radius:50%;background:var(--red);color:var(--white);font-family:var(--font-display);font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.navbar-avatar:hover{opacity:.85}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;margin-left:auto}.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px}.mobile-menu{background:var(--black-soft);border-top:1px solid #333;display:flex;flex-direction:column}.mobile-link{padding:14px 20px;color:#ccc;font-family:var(--font-display);font-size:1rem;text-decoration:none;border-bottom:1px solid #2A2A2A;background:none;border-left:none;border-right:none;border-top:none;text-align:left;cursor:pointer;letter-spacing:.3px}.mobile-link:hover{background:#ffffff0f;color:var(--white)}.mobile-logout{color:var(--red-light)}@media (max-width: 680px){.navbar-links,.navbar-user{display:none}.hamburger{display:flex}}.auth-page{min-height:100vh;background:var(--black);display:flex;align-items:center;justify-content:center;padding:24px 16px;background-image:radial-gradient(circle at 20% 50%,rgba(200,16,46,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(200,16,46,.06) 0%,transparent 40%)}.auth-card{background:var(--white);border-radius:16px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 8px 40px #00000080;border-top:4px solid var(--red)}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{font-size:3rem;margin-bottom:8px;display:block}.auth-title{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--black);text-transform:uppercase;letter-spacing:2px;margin-bottom:6px}.auth-title span{color:var(--red)}.auth-subtitle{color:var(--gray);font-size:.9rem}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 20px;background:var(--white);border:2px solid var(--gray-mid);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;font-weight:500;color:var(--black-soft);cursor:pointer;transition:background .2s,border-color .2s}.btn-google:hover:not(:disabled){background:var(--gray-light);border-color:var(--gray)}.btn-google:disabled{opacity:.55;cursor:not-allowed}.auth-footer{text-align:center;margin-top:20px;font-size:.88rem;color:var(--gray-dark)}@media (max-width: 480px){.auth-card{padding:28px 20px}}.dashboard-banner{background:linear-gradient(135deg,var(--black) 0%,var(--black-soft) 70%,#2A0A10 100%);border-radius:var(--radius);padding:28px 32px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;overflow:hidden;position:relative}.dashboard-banner:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--red);border-radius:4px 0 0 4px}.banner-content h1{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--white);letter-spacing:.5px;margin-bottom:6px}.banner-content h1 span{color:var(--red-light)}.banner-content p{color:var(--gray);font-size:.88rem}.banner-decoration{font-size:4rem;opacity:.25}.season-tabs{display:flex;gap:8px;margin-bottom:20px}.season-tab{font-family:var(--font-display);font-size:.95rem;font-weight:700;letter-spacing:.5px;padding:8px 20px;border-radius:20px;border:2px solid var(--gray-mid);background:var(--white);color:var(--gray-dark);cursor:pointer;transition:all .15s}.season-tab:hover{border-color:var(--red);color:var(--red)}.season-tab--active,.season-tab--active:hover{background:var(--red);border-color:var(--red);color:var(--white)}.dashboard-stats-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.attended-count{display:flex;align-items:baseline;gap:8px}.attended-count-value{font-family:var(--font-display);font-size:2.8rem;font-weight:700;color:var(--black);line-height:1}.attended-count-label{font-size:.9rem;color:var(--gray);font-weight:500}.btn-register-visit{flex-shrink:0;white-space:nowrap}.pass-stats-list{display:flex;flex-direction:column;gap:10px}.pass-stat-item{position:relative;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;min-height:64px}.pass-stat-bar{position:absolute;left:0;top:0;bottom:0;background:#c8102e1a;transition:width .6s ease;min-width:4px;border-radius:var(--radius) 0 0 var(--radius)}.pass-stat-content{position:relative;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:12px}.pass-stat-info{display:flex;flex-direction:column;gap:3px}.pass-stat-section{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--black);letter-spacing:.3px}.pass-stat-seat{font-size:.8rem;color:var(--gray)}.pass-stat-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.pass-stat-pct{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--red);line-height:1}.pass-stat-attended{font-size:.78rem;color:var(--gray)}@media (max-width: 640px){.dashboard-banner{padding:20px}.banner-content h1{font-size:1.2rem}.dashboard-stats-row{flex-direction:column;align-items:flex-start}.btn-register-visit{width:100%;justify-content:center}}.passes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.pass-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border-top:4px solid var(--red)}.pass-card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--black)}.pass-card-seat{font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--white);letter-spacing:.5px}.pass-card-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.pass-name-input{flex:1;background:transparent;border:none;border-bottom:1px solid var(--gray);color:var(--white);font-family:var(--font-display);font-size:.95rem;font-weight:700;letter-spacing:.5px;padding:2px 4px;outline:none;min-width:0}.pass-action-btn{color:var(--gray)!important;padding:4px 6px;font-size:.9rem}.pass-action-btn:hover{color:var(--white)!important}.pass-delete-btn{color:var(--gray)!important;padding:4px 8px;font-size:1rem}.pass-delete-btn:hover{color:var(--red-light)!important}.pass-card--lent{border-top-color:var(--gray);opacity:.85}.pass-card--borrowed{border-top-color:#1565c0}.pass-borrowed-label{font-size:.72rem;font-weight:600;color:#90caf9;letter-spacing:.5px;text-transform:uppercase}.lending-section-title{color:#1565c0}.pass-card-footer-actions{padding:10px 16px 12px;border-top:1px solid var(--gray-mid);display:flex;flex-direction:column;gap:8px}.pass-lend-btn{font-size:.82rem!important;color:var(--gray-dark)!important;padding:4px 0!important;text-align:left}.pass-lend-btn:hover{color:var(--black)!important}.pass-lent-info{display:flex;align-items:center;justify-content:space-between;gap:8px}.pass-lent-badge{font-size:.78rem;color:var(--gray-dark);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pass-retrieve-btn{font-size:.78rem!important;color:var(--red)!important;padding:2px 6px!important;flex-shrink:0}.pass-retrieve-btn:hover{color:var(--red-dark)!important}.pass-lend-form{display:flex;flex-direction:column;gap:6px}.pass-lend-row{display:flex;gap:8px}.pass-lend-input{flex:1;font-size:.85rem;padding:6px 10px;border:1px solid var(--gray-mid);border-radius:var(--radius-sm);outline:none;min-width:0}.pass-lend-input:focus{border-color:var(--red)}.pass-lend-error{font-size:.8rem;color:var(--red)}.pass-card-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.pass-detail-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.pass-detail-label{color:var(--gray);font-weight:500}.pass-detail-value{font-weight:700;color:var(--black);font-family:var(--font-display);font-size:1rem;letter-spacing:.3px}.pass-picker-hint{color:var(--gray);font-size:.9rem;margin-bottom:16px}.pass-picker-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.pass-picker-card{width:100%;text-align:left;display:flex;flex-direction:row;align-items:center;gap:16px;cursor:pointer;border:2px solid transparent;transition:border-color .15s,box-shadow .15s;background:var(--white)}.pass-picker-card:hover{border-color:var(--gray-mid);box-shadow:var(--shadow-md)}.pass-picker-card--selected{border-color:var(--red)!important;box-shadow:var(--shadow-md)}.pass-picker-card-check{font-size:1.4rem;flex-shrink:0}.pass-picker-card-info{display:flex;flex-direction:column;gap:6px}.pass-picker-card-name{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--black);margin-bottom:4px}.pass-picker-select-all{background:none;border:1px dashed var(--gray-mid);border-radius:var(--radius);color:var(--gray);font-size:.9rem;font-weight:500;padding:10px 16px;cursor:pointer;text-align:center;transition:border-color .15s,color .15s}.pass-picker-select-all:hover,.pass-picker-select-all--active{border-color:var(--red);color:var(--red)}.btn-confirm-passes{width:100%;justify-content:center;margin-top:8px}.register-visit-game-card{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;border-left:4px solid var(--red)}.game-card-rival{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--black);margin-bottom:4px}.game-card-date{font-size:.85rem;color:var(--gray);text-transform:capitalize}.register-visit-no-game{text-align:center;color:var(--gray);font-style:italic;margin-bottom:16px;padding:20px}.visits-full-list{display:flex;flex-direction:column;gap:12px}.visit-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border-left:4px solid var(--gray-mid)}.visit-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px 10px;gap:12px}.visit-card-date{font-size:.78rem;color:var(--gray);display:block;margin-bottom:4px;text-transform:capitalize}.visit-card-rival{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--black-soft)}.visit-card-rival span{color:var(--red)}.visit-delete{opacity:.5;padding:2px 6px}.visit-delete:hover{opacity:1}.visit-card-footer{padding:10px 20px 14px;border-top:1px solid var(--gray-mid)}.visit-passes{display:flex;flex-wrap:wrap;gap:6px}.pass-season-badge--sm{font-size:.75rem;padding:2px 8px}.pass-season-badge--lent{background:#e3f2fd;color:#1565c0;border-color:#90caf9}.pass-picker-card--borrowed{border-left:3px solid #1565C0}.profile-card{display:flex;align-items:center;gap:20px;margin-bottom:16px}.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--red);color:var(--white);font-family:var(--font-display);font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-info{flex:1;min-width:0}.profile-name-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}.profile-display-name{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--black)}.profile-email{font-size:.85rem;color:var(--gray)}.profile-name-edit{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.profile-name-input{font-family:var(--font-display);font-size:1.1rem;font-weight:700;border:1px solid var(--gray-mid);border-radius:var(--radius-sm);padding:6px 10px;outline:none;width:100%}.profile-name-input:focus{border-color:var(--red)}.profile-name-actions{display:flex;gap:8px}.profile-msg{font-size:.85rem;color:var(--gray);margin-top:4px}.profile-msg--success{color:var(--success)}.profile-msg--error{color:var(--red)}.profile-section{margin-bottom:16px}.profile-section-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--black);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--gray-mid)}.profile-section-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.profile-section-label{font-weight:600;font-size:.95rem;color:var(--black-soft);margin-bottom:2px}.profile-section-hint{font-size:.82rem;color:var(--gray)}.profile-provider-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:6px 0}.profile-provider-info{display:flex;align-items:center;gap:12px}.profile-provider-icon{font-size:1.3rem;flex-shrink:0}.profile-divider{border:none;border-top:1px solid var(--gray-mid);margin:12px 0}.provider-btn--disconnect{color:var(--red)!important;border-color:var(--red)!important}.provider-btn--disconnect:disabled{opacity:.35;cursor:not-allowed}.profile-link-password{margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-mid);display:flex;flex-direction:column;gap:4px}.install-banner{position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:3px solid var(--red);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 -4px 20px #0000001f;z-index:1000}.install-banner-icon{font-size:1.8rem;flex-shrink:0}.install-banner-text{flex:1;display:flex;flex-direction:column;gap:2px;font-size:.85rem;min-width:0}.install-banner-text strong:first-child{font-family:var(--font-display);font-size:.95rem;color:var(--black)}.install-banner-text span{color:var(--gray)}.install-banner-btn{flex-shrink:0}.install-banner-close{color:var(--gray)!important;flex-shrink:0;padding:4px 8px!important}
