.top-bar{position:sticky;top:0;z-index:50;background-color:var(--primary-color);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.top-bar-content{max-width:430px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md)}.logo-button{background:none;border:none;cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;transition:transform var(--transition-fast)}.logo-button:active{transform:scale(.95)}.logo{height:32px;width:auto}.school-selector-wrapper{position:relative}.school-selector{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:#fff;cursor:pointer;transition:all var(--transition-base);min-height:36px;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;-moz-appearance:none}.school-selector svg{color:#fff;stroke:#fff;transition:transform .3s ease-out;pointer-events:none}.school-selector .chevron-rotated{transform:rotate(180deg)}.school-selector:hover{border-color:#ffffff80;background-color:#ffffff4d}.school-selector:active{transform:scale(.98)}.school-selector:focus{outline:none}.school-dropdown{position:absolute;top:calc(100% + var(--spacing-sm));right:0;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;min-width:180px;overflow:hidden;animation:slideDown .3s ease-out;transform-origin:top right}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{display:block;width:100%;padding:var(--spacing-md);text-align:left;background:none;border:none;color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-fast);font-size:.875rem;border-radius:0;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;-moz-appearance:none}.dropdown-item:first-child{border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.dropdown-item:last-child{border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.dropdown-item:focus{outline:none;background-color:var(--bg-primary)}.dropdown-item:hover{background-color:var(--bg-primary)}.dropdown-item.active{background-color:var(--primary-color);color:#fff;font-weight:500}.layout{display:flex;flex-direction:column;min-height:100vh;position:relative;padding-bottom:80px}.main-content{flex:1;width:100%;max-width:430px;margin:0 auto;padding:0;position:relative;overflow:hidden;--slide-duration: .3s}.content-wrapper{width:100%;min-height:100%;position:relative;will-change:transform,opacity}.main-content.slide-left .content-wrapper{animation:slideInLeft var(--slide-duration) cubic-bezier(.4,0,.2,1)}.main-content.slide-right .content-wrapper{animation:slideInRight var(--slide-duration) cubic-bezier(.4,0,.2,1)}@keyframes slideInLeft{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;display:flex;justify-content:space-around;align-items:center;background-color:var(--secondary-color);border-top:1px solid var(--border-color);padding:var(--spacing-sm) 0;z-index:100;box-shadow:0 -2px 10px #0000000d}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);border:none;background:none;color:#fff;cursor:pointer;transition:all var(--transition-base);min-width:60px;min-height:60px}.nav-item svg{color:#fff;stroke:#fff}.nav-item span{font-size:.75rem;font-weight:500;color:#fff}.nav-item.active{color:#fff!important;opacity:1}.nav-item.active svg{stroke-width:2.5;color:#fff;stroke:#fff}.nav-item:not(.active){opacity:.7}.nav-item:active{transform:scale(.95)}.spring-crawl-banner{position:relative;background-color:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);cursor:pointer;overflow:hidden;transition:padding .5s ease-out}.spring-crawl-banner.expanded{padding:var(--spacing-md) var(--spacing-lg)}.spring-crawl-banner.collapsed{padding:var(--spacing-sm) var(--spacing-lg)}.spring-crawl-banner:active{transform:scale(.98);box-shadow:var(--shadow-md)}.spring-crawl-banner-accent{position:absolute;top:0;left:0;width:4px;height:100%;background-color:var(--primary-color)}.spring-crawl-banner-content{position:relative;padding-left:var(--spacing-md)}.spring-crawl-banner-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0;min-height:60px;transition:margin-bottom .5s ease-out}.spring-crawl-banner.expanded .spring-crawl-banner-header{margin-bottom:var(--spacing-md)}.spring-crawl-banner-title-section{display:flex;align-items:flex-start;flex:1}.spring-crawl-banner-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.spring-crawl-banner-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--primary-color);color:#fff;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.spring-crawl-banner-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px;transition:all var(--transition-base);flex-shrink:0;margin-left:var(--spacing-sm)}.spring-crawl-banner-toggle:hover{color:var(--primary-color)}.spring-crawl-banner-toggle:active{transform:scale(.9)}.spring-crawl-banner-expanded-content{overflow:hidden;max-height:500px;opacity:1}.spring-crawl-banner-expanded-content.expanded{transition:max-height .6s ease-out,opacity .5s ease-out;pointer-events:auto}.spring-crawl-banner-expanded-content.collapsed{max-height:0;opacity:0;transition:max-height .3s ease-out,opacity .4s ease-out;pointer-events:none}.spring-crawl-banner-info{margin-bottom:var(--spacing-md)}.spring-crawl-banner-date{font-size:.875rem;color:var(--text-secondary);margin:0 0 var(--spacing-sm) 0;font-weight:500}.spring-crawl-banner-benefits{list-style:none;padding:0;margin:var(--spacing-sm) 0 0 0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.spring-crawl-banner-benefits li{font-size:.875rem;color:var(--text-primary);padding-left:var(--spacing-md);position:relative}.spring-crawl-banner-benefits li:before{content:"•";position:absolute;left:0;color:var(--primary-color);font-weight:700}.spring-crawl-banner-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.spring-crawl-banner-button{width:100%;justify-content:center}.spring-crawl-banner-microcopy{font-size:.75rem;color:var(--text-secondary);text-align:center;margin:0;font-style:italic}.bars-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.category-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.category-chip{padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--radius-full);background-color:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);min-height:36px}.category-chip:hover{border-color:var(--primary-color);background-color:var(--bg-primary)}.category-chip.active{background-color:var(--primary-color)!important;color:#fff!important;border-color:var(--primary-color)!important}.bars-list{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:#f5f5f5;padding:var(--spacing-md);border-radius:var(--radius-lg)}.bar-card{background-color:var(--secondary-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all var(--transition-base);cursor:pointer}.bar-card:active{transform:scale(.98);box-shadow:var(--shadow-md)}.bar-category-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--bg-primary);color:var(--text-secondary);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:uppercase}.favorite-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);min-width:36px;min-height:36px}.bar-card-deals{margin-bottom:var(--spacing-md);min-height:24px}.deals-preview{color:var(--text-secondary);font-size:.875rem;margin:0;line-height:1.4}.deals-preview:not(:last-child){margin-bottom:.25rem}.deals-more{color:var(--primary-color);font-weight:500;margin-top:.25rem}.bar-detail-page{min-height:100vh;background-color:var(--bg-primary)}.bar-detail-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.bar-name-header{font-size:1rem;font-weight:600;flex:1;text-align:center;margin:0 var(--spacing-md);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.favorite-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;transition:all var(--transition-base)}.favorite-button.favorited{color:var(--primary-color)}.favorite-button:active{transform:scale(1.1)}.bar-detail-content{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.bar-info-section{margin-bottom:var(--spacing-xl)}.bar-title-section{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.bar-title-section h1{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.bar-category-badge{padding:var(--spacing-xs) var(--spacing-md);background-color:var(--primary-color);color:#fff;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.bar-meta{display:flex;flex-direction:column;gap:var(--spacing-sm)}.meta-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem;text-decoration:none;transition:color var(--transition-fast)}.meta-item:hover{color:var(--primary-color)}.deals-section,.deals-group{margin-bottom:var(--spacing-xl)}.deals-group h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.deals-list{list-style:none;padding:0;margin:0}.deals-list li{padding:var(--spacing-sm) 0;padding-left:var(--spacing-lg);position:relative;color:var(--text-primary);line-height:1.6}.deals-list li:before{content:"•";position:absolute;left:0;color:var(--primary-color);font-weight:700;font-size:1.2rem}.no-deals{color:var(--text-secondary);font-style:italic;padding:var(--spacing-md) 0}.bar-actions{display:flex;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.bar-actions .btn{flex:1}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--spacing-md)}.sign-in-prompt{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:var(--spacing-xl)}.sign-in-content{text-align:center;max-width:320px}.sign-in-content h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.sign-in-content p{color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.sign-in-buttons{display:flex;flex-direction:column;gap:var(--spacing-md)}.sign-in-buttons .btn{width:100%}.favorites-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.favorites-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.bar-card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all var(--transition-base);cursor:pointer}.bar-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.bar-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.bar-card-header h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.bar-category-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--bg-primary);color:var(--text-secondary);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.favorite-button{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);min-width:36px;min-height:36px}.favorite-button:active{transform:scale(1.2)}.bar-card-deals{margin-bottom:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.deal-box{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);font-size:.875rem;line-height:1.5;transition:all var(--transition-base)}.deal-box:hover{border-color:var(--primary-color);background-color:var(--bg-secondary)}.deal-box.no-deals{color:var(--text-secondary);font-style:italic;border-color:transparent;background-color:transparent}.view-details-button{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-xs);color:var(--primary-color);font-weight:500;font-size:.875rem;padding:var(--spacing-xs) 0;transition:all var(--transition-base);width:100%;pointer-events:none}.friends-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.page-subtitle{color:var(--text-secondary);font-size:.875rem}.friends-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.tab-button{flex:1;padding:var(--spacing-md);background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-base);font-size:.875rem}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.friends-content{min-height:200px}.friends-list,.requests-list,.search-results{display:flex;flex-direction:column;gap:var(--spacing-md)}.friend-card,.request-card,.user-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.clickable-card{cursor:pointer;transition:opacity var(--transition-base)}.clickable-card:hover{opacity:.8}.request-card{display:flex;align-items:center;gap:var(--spacing-md)}.request-card-content{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.user-card{display:flex;align-items:center;gap:var(--spacing-md)}.user-card-content{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.friend-avatar{width:48px;height:48px;border-radius:var(--radius-full);background-color:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0;overflow:hidden}.friend-avatar img{width:100%;height:100%;object-fit:cover}.friend-info{flex:1;min-width:0}.friend-info h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-info p{font-size:.875rem;color:var(--text-secondary)}.request-actions{display:flex;gap:var(--spacing-sm)}.accept-button,.decline-button{width:40px;height:40px;border-radius:var(--radius-full);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base)}.accept-button{background-color:var(--success-color);color:#fff}.accept-button:hover{background-color:var(--success-color);filter:brightness(.9);transform:scale(1.05)}.decline-button{background-color:var(--error-color);color:#fff}.decline-button:hover{background-color:var(--error-color);filter:brightness(.9);transform:scale(1.05)}.search-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.search-bar svg{color:var(--text-secondary);flex-shrink:0}.search-bar input{flex:1;border:none;background:none;padding:0;min-height:auto}.search-bar input:focus{box-shadow:none}.user-card .btn{flex-shrink:0;min-width:100px}.loading-state{display:flex;justify-content:center;padding:var(--spacing-xl)}.profile-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.profile-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.profile-header{text-align:center;padding:var(--spacing-xl) 0}.profile-avatar{position:relative;width:120px;height:120px;margin:0 auto var(--spacing-lg);border-radius:var(--radius-full);background-color:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;overflow:visible}.profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.profile-avatar span{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.avatar-edit-button{position:absolute;bottom:0;right:0;width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--primary-color);border:3px solid var(--bg-primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);box-shadow:0 2px 8px #00000026;z-index:20;transform:translate(4px,4px)}.avatar-edit-button:hover{background-color:var(--secondary-color);transform:scale(1.05);box-shadow:0 4px 12px #0003}.profile-header h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.profile-header p{color:var(--text-secondary);font-size:.875rem}.profile-section{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.profile-section h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.profile-fields{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.profile-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profile-field label{font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.profile-field p{font-size:1rem;color:var(--text-primary)}.profile-actions{display:flex;gap:var(--spacing-md)}.profile-actions .btn{flex:1}.profile-action-button{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);background:none;border:none;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:1rem;text-align:left;cursor:pointer;transition:background-color var(--transition-fast);text-decoration:none}.profile-action-button:last-child{border-bottom:none}.profile-action-button:hover{background-color:var(--bg-primary)}.profile-action-button.danger{color:var(--error-color)}.contact-info{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.contact-link{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem;text-decoration:none;transition:color var(--transition-fast)}.contact-link:hover{color:var(--primary-color)}.modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);overflow-y:auto;overscroll-behavior:contain;margin:0;box-sizing:border-box;top:0!important;left:0!important}.modal-content{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:calc(100% - 2 * var(--spacing-md));max-width:min(400px,calc(100vw - 2 * var(--spacing-md)));box-shadow:var(--shadow-lg);position:relative;flex-shrink:0;margin:auto;align-self:center}.modal-content h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.modal-content p{color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.modal-actions{display:flex;gap:var(--spacing-md)}.modal-actions .btn{flex:1}.photo-options-modal{max-width:320px}.photo-options{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.photo-option-button{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-lg);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;cursor:pointer;transition:all var(--transition-base)}.photo-option-button:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.photo-option-button:disabled{opacity:.5;cursor:not-allowed}.photo-option-button svg{flex-shrink:0}.photo-option-button span{font-weight:500}.uploading-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.uploading-indicator{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);background-color:var(--bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.uploading-indicator p{color:var(--text-secondary);font-size:.875rem;margin:0}.user-profile-page{min-height:100vh;padding-bottom:var(--spacing-xl)}.user-profile-page .page-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--border-color);background-color:var(--bg-primary);position:sticky;top:0;z-index:10}.back-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:none;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-base)}.back-button:hover{background-color:var(--bg-secondary)}.user-profile-page .page-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.profile-content{padding:var(--spacing-lg)}.profile-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.profile-avatar-large{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));display:flex;align-items:center;justify-content:center;overflow:hidden;border:4px solid var(--bg-secondary);box-shadow:var(--shadow-md)}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-avatar-large span{font-size:2.5rem;font-weight:600;color:#fff}.profile-info{text-align:center}.profile-info h2{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.profile-info .username{font-size:1rem;color:var(--text-secondary);margin:0 0 var(--spacing-md) 0}.add-friend-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.add-friend-button:hover:not(:disabled){background-color:var(--secondary-color);transform:translateY(-1px);box-shadow:var(--shadow-md)}.add-friend-button:disabled{opacity:.6;cursor:not-allowed}.add-friend-button svg{flex-shrink:0}.profile-actions{display:flex;gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-md);flex-wrap:wrap}.share-profile-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.share-profile-button:hover{background-color:var(--bg-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.share-profile-button svg{flex-shrink:0}.profile-section{margin-top:var(--spacing-xl)}.section-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.section-header svg{color:var(--primary-color)}.section-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.count-badge{background-color:var(--bg-secondary);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:.875rem;font-weight:500}.favorite-bars-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.favorite-bar-card{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.favorite-bar-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.bar-card-content{flex:1}.bar-card-content h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.bar-card-content .bar-location{font-size:.875rem;color:var(--text-secondary);margin:0}.favorite-bar-card .arrow-icon{color:var(--text-secondary);transform:rotate(180deg);transition:transform var(--transition-base)}.favorite-bar-card:hover .arrow-icon{transform:rotate(180deg) translate(-4px)}.empty-state-small{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.empty-state-small p{margin:0;font-size:.875rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.loading-state .spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;gap:var(--spacing-md)}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.empty-state p{color:var(--text-secondary);margin:0}.about-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.about-content{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.about-section{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.about-section h2{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.about-section p{color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-md)}.about-section p:last-child{margin-bottom:0}.contact-links{display:flex;flex-direction:column;gap:var(--spacing-md)}.store-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.page-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.store-content{display:flex;justify-content:center;align-items:center;min-height:400px}.store-card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-2xl);border:1px solid var(--border-color);text-align:center;max-width:400px;width:100%}.store-card h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.store-card p{color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-xl)}.store-button{width:100%;justify-content:center;gap:var(--spacing-sm)}.fallcrawl-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px)}.page-header h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.event-status{color:var(--text-secondary);font-size:.875rem;font-style:italic}.fallcrawl-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.event-section{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.event-section h2{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.event-section p{color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-md)}.event-section p:last-child{margin-bottom:0}.contact-links{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.contact-link{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--primary-color);text-decoration:none;font-weight:500;transition:all var(--transition-base);padding:var(--spacing-sm) 0}.contact-link:hover{gap:var(--spacing-md);color:var(--secondary-color)}.spring-crawl-page{min-height:100vh;background-color:var(--bg-primary)}.spring-crawl-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.spring-crawl-header-title{font-size:1rem;font-weight:600;flex:1;text-align:center;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spring-crawl-header-spacer{width:44px;min-width:44px}.back-button{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;transition:transform var(--transition-fast)}.back-button:active{transform:scale(.9)}.spring-crawl-content{padding:0;padding-bottom:calc(var(--spacing-lg) + 80px)}.spring-crawl-hero{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;padding:var(--spacing-2xl) var(--spacing-md);text-align:center}.spring-crawl-hero-content{max-width:430px;margin:0 auto}.spring-crawl-hero-image{width:100%;max-width:300px;height:auto;margin:0 auto var(--spacing-lg) auto;display:block;border-radius:var(--radius-md)}.spring-crawl-product-title{font-size:2rem;font-weight:700;margin:0 0 var(--spacing-xs) 0;color:#fff}.spring-crawl-product-subtitle{font-size:1rem;opacity:.9;margin:0 0 var(--spacing-md) 0;font-weight:500}.spring-crawl-hero-date{font-size:1rem;opacity:.95;font-weight:500;margin-top:var(--spacing-sm)}.spring-crawl-purchase-section{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--spacing-lg) var(--spacing-md);position:sticky;top:56px;z-index:5;box-shadow:var(--shadow-sm)}.spring-crawl-purchase-info{text-align:center;margin-bottom:var(--spacing-md)}.spring-crawl-purchase-price{font-size:2.5rem;font-weight:700;color:var(--primary-color);margin-bottom:var(--spacing-xs)}.spring-crawl-purchase-tagline{font-size:.875rem;color:var(--text-secondary);margin:0;font-style:italic}.spring-crawl-buy-button-large{width:100%;font-size:1.125rem;font-weight:600;padding:var(--spacing-md) var(--spacing-lg);min-height:52px}.spring-crawl-product-section{padding:var(--spacing-xl) var(--spacing-md);background-color:var(--bg-secondary);margin-bottom:var(--spacing-md)}.spring-crawl-product-section:first-of-type{margin-top:0}.spring-crawl-product-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-lg) 0}.spring-crawl-product-section p{color:var(--text-primary);line-height:1.7;margin:0 0 var(--spacing-md) 0;font-size:.9375rem}.spring-crawl-product-section p:last-child{margin-bottom:0}.spring-crawl-card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin:var(--spacing-md) var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.spring-crawl-card h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.spring-crawl-card p{color:var(--text-primary);line-height:1.6;margin:0 0 var(--spacing-md) 0}.spring-crawl-card p:last-child{margin-bottom:0}.spring-crawl-benefits-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.spring-crawl-benefits-list li{display:flex;align-items:flex-start;gap:var(--spacing-sm);color:var(--text-primary)}.benefit-icon{color:var(--primary-color);flex-shrink:0;margin-top:2px}.spring-crawl-benefits-list li div{flex:1;line-height:1.6}.spring-crawl-social-card{text-align:center}.spring-crawl-social-link{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--primary-color);text-decoration:none;font-weight:500;margin-top:var(--spacing-md);transition:opacity var(--transition-fast)}.spring-crawl-social-link:hover{opacity:.8}.legal-page{padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + 80px);max-width:800px;margin:0 auto}.page-header{margin-bottom:var(--spacing-xl)}.page-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.last-updated{color:var(--text-secondary);font-size:.875rem;margin:0}.legal-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.legal-section{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.legal-section h2{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.legal-section h3{font-size:1rem;font-weight:600;margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm);color:var(--text-primary)}.legal-section p{color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-md)}.legal-section p:last-child{margin-bottom:0}.legal-section ul{color:var(--text-secondary);line-height:1.8;margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md)}.legal-section li{margin-bottom:var(--spacing-xs)}.legal-section strong{color:var(--text-primary);font-weight:600}.legal-section a{color:var(--primary-color);text-decoration:none;font-weight:500;transition:color var(--transition-base)}.legal-section a:hover{color:var(--secondary-color);text-decoration:underline}.auth-callback-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-primary)}.loading-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.sign-in-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);background-color:var(--bg-primary)}.sign-in-container{max-width:400px;width:100%;text-align:center}.sign-in-header{margin-bottom:var(--spacing-2xl)}.sign-in-logo{height:64px;width:auto;margin-bottom:var(--spacing-xl)}.sign-in-header h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.sign-in-header p{color:var(--text-secondary);line-height:1.6}.sign-in-buttons{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.sign-in-button{width:100%;justify-content:center;gap:var(--spacing-sm);min-height:52px;font-size:1rem;font-weight:600}.apple-button-wrapper{position:relative}.apple-button{background-color:#000;color:#fff;opacity:.5;cursor:not-allowed}.apple-button:hover:not(:disabled){background-color:#1a1a1a}.apple-button:disabled{opacity:.5;cursor:not-allowed}.apple-unavailable-badge{position:absolute;top:-8px;right:-8px;background-color:var(--error-color);color:#fff;font-size:.625rem;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);white-space:nowrap;z-index:10;box-shadow:0 2px 4px #0003}.sign-in-footer{font-size:.75rem;color:var(--text-secondary);line-height:1.6}.sign-in-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.sign-in-footer a:hover{text-decoration:underline}.onboarding-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);background-color:var(--bg-primary)}.onboarding-container{max-width:400px;width:100%}.onboarding-header{text-align:center;margin-bottom:var(--spacing-2xl)}.onboarding-header h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.onboarding-header p{color:var(--text-secondary);line-height:1.6}.onboarding-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-field label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-field small{font-size:.75rem;color:var(--text-secondary);margin-top:calc(var(--spacing-xs) * -1)}.onboarding-form .btn{width:100%;margin-top:var(--spacing-md)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md)}.loading-state p{color:var(--text-secondary)}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #faf9f6;--bg-secondary: #ffffff;--text-primary: #1a1a1a;--text-secondary: #666666;--primary-color: #9e1b32;--secondary-color: #c8102e;--accent-color: #1a1a1a;--border-color: #e0e0e0;--success-color: #10b981;--error-color: #ef4444;--warning-color: #f59e0b;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}@media(min-width:768px){body{display:flex;justify-content:center}#root{max-width:430px;width:100%;box-shadow:0 0 0 1px var(--border-color)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.container{width:100%;max-width:430px;margin:0 auto;padding:0 var(--spacing-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);min-height:44px;gap:var(--spacing-sm)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color)!important;color:#fff!important}.btn-primary:hover:not(:disabled){background-color:var(--secondary-color)!important;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-primary);border-color:var(--primary-color)}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--error-color);filter:brightness(.9)}.card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.input{width:100%;padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;background-color:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-base);min-height:44px}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #9e1b321a}.input::placeholder{color:var(--text-secondary)}.toast-container{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:1000;max-width:430px;width:calc(100% - 2rem)}.toast{background-color:var(--text-primary);color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);margin-bottom:var(--spacing-sm);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.spinner{border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-secondary)}.empty-state svg{width:64px;height:64px;margin-bottom:var(--spacing-lg);opacity:.5}.empty-state h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.empty-state p{margin-bottom:var(--spacing-lg)}
