: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}.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}.user-email{font-size:.82rem;color:var(--gray);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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-season{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--white);letter-spacing:.5px}.pass-delete-btn{color:var(--gray)!important;padding:4px 8px;font-size:1rem}.pass-delete-btn:hover{color:var(--red-light)!important}.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}.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}
