.leaflet-cluster-anim .leaflet-marker-icon,.leaflet-cluster-anim .leaflet-marker-shadow{-webkit-transition:-webkit-transform .3s ease-out,opacity .3s ease-in;-moz-transition:-moz-transform .3s ease-out,opacity .3s ease-in;-o-transition:-o-transform .3s ease-out,opacity .3s ease-in;transition:transform .3s ease-out,opacity .3s ease-in}.leaflet-cluster-spider-leg{-webkit-transition:-webkit-stroke-dashoffset .3s ease-out,-webkit-stroke-opacity .3s ease-in;-moz-transition:-moz-stroke-dashoffset .3s ease-out,-moz-stroke-opacity .3s ease-in;-o-transition:-o-stroke-dashoffset .3s ease-out,-o-stroke-opacity .3s ease-in;transition:stroke-dashoffset .3s ease-out,stroke-opacity .3s ease-in}:focus-visible{outline:2px solid var(--primary, #57068C);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--primary: #6C5CE7;--primary-light: #A29BFE;--primary-dark: #5541D9;--accent: #00BCD4;--bg: #F8F9FA;--bg-card: #FFFFFF;--bg-overlay: rgba(0, 0, 0, .5);--text: #1A1A2E;--text-secondary: #6B7280;--text-muted: #9CA3AF;--border: #E5E7EB;--border-light: #F3F4F6;--success: #10B981;--warning: #F59E0B;--danger: #EF4444;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .15);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--navbar-height: 60px}[data-dark=true]{--bg: #0F0F23;--bg-card: #1A1A2E;--text: #E8E8F0;--text-secondary: #9CA3AF;--text-muted: #6B7280;--border: #2D2D44;--border-light: #1F1F35}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}.app{height:100%;display:flex;flex-direction:column}.app-main{flex:1;overflow:hidden;position:relative}.loading-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.navbar{height:var(--navbar-height);background:color-mix(in srgb,var(--bg-card) 78%,transparent);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid color-mix(in srgb,var(--border) 70%,transparent);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:1000;box-shadow:0 1px #00000005;position:sticky;top:0}@supports not (backdrop-filter: blur(1px)){.navbar{background:var(--bg-card)}}.navbar-brand{display:flex;align-items:center;gap:8px;color:var(--primary);font-weight:700;font-size:18px}.brand-text{background:linear-gradient(135deg,var(--primary),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-links{display:flex;gap:4px}.nav-link{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);text-decoration:none;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all .2s}.nav-link:hover{background:var(--border-light);color:var(--text)}.nav-link.active{background:var(--primary);color:#fff}.nav-avatar{width:24px;height:24px;border-radius:50%;background:var(--primary-light);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.auth-page{height:100%;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-gradient, linear-gradient(135deg, #EDE7F6 0%, #E0F7FA 100%))}.auth-card{width:100%;max-width:440px;background:var(--bg-card);border-radius:var(--radius-lg);padding:40px 32px;box-shadow:var(--shadow-xl)}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{width:60px;height:60px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.auth-header h1{font-size:24px;font-weight:700;margin-bottom:4px}.auth-header p{color:var(--text-secondary);font-size:14px}.step-indicator{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}.step-dot.active{background:var(--primary);width:24px;border-radius:4px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-error{background:#fef2f2;color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;border:1px solid #FECACA}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-sans);color:var(--text);background:var(--bg);transition:border-color .2s,box-shadow .2s;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6c5ce71a}.form-group textarea{resize:vertical;min-height:80px}.password-field{position:relative}.password-field input{width:100%;padding-right:40px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.auth-actions{display:flex;gap:12px;margin-top:8px}.auth-actions .btn{flex:1}.auth-footer{text-align:center;margin-top:20px;font-size:14px;color:var(--text-secondary)}.link-btn{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;font-size:inherit}.link-btn:hover{text-decoration:underline}.demo-notice{margin-top:20px;padding:12px;background:#fef3c7;border-radius:var(--radius-sm);font-size:12px;color:#92400e;text-align:center}.demo-notice p+p{margin-top:4px}.university-preview{background:var(--bg);border-radius:var(--radius-sm);padding:16px;text-align:center}.uni-color-bar{height:4px;border-radius:2px;margin-bottom:12px}.university-preview h3{font-size:16px;margin-bottom:4px}.university-preview p{color:var(--text-secondary);font-size:13px}.verify-summary{background:var(--bg);border-radius:var(--radius-sm);padding:20px}.verify-summary h3{font-size:16px;margin-bottom:12px}.summary-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:14px}.summary-item span{color:var(--text-secondary)}.verify-note{margin-top:12px;font-size:13px;color:var(--text-muted);text-align:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--border-light);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-full{width:100%}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{padding:8px;width:36px;height:36px}.btn-xs{padding:4px;width:24px;height:24px}.btn-action{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-full);padding:8px 16px;font-size:13px}.btn-action:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-action.active.liked{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.btn-action.active.disliked{background:#fef2f2;border-color:var(--danger);color:var(--danger)}.btn-action.active{border-color:var(--primary);color:var(--primary);background:#6c5ce70d}.btn-danger{color:var(--danger)}.btn-danger:hover:not(:disabled){background:#fef2f2;border-color:var(--danger)}.btn-clear{color:var(--danger)}.campus-map-container{height:100%;position:relative}.campus-map{height:100%;width:100%;z-index:1}.leaflet-dark-navy{filter:invert(1) hue-rotate(183deg) brightness(.92) contrast(.86) saturate(.78)}[data-dark=true] .leaflet-container{background:#1a2336}[data-dark=true] .leaflet-marker-pane,[data-dark=true] .leaflet-popup-pane,[data-dark=true] .leaflet-overlay-pane,[data-dark=true] .leaflet-tooltip-pane{filter:none}.leaflet-control-attribution{font-size:10px!important;opacity:.7}.leaflet-popup-content-wrapper{border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;padding:0!important}.leaflet-popup-content{margin:0!important;min-width:220px!important}.leaflet-popup-tip{box-shadow:var(--shadow-md)!important}.custom-pin-icon{background:none!important;border:none!important}.pin-marker{width:var(--size);height:var(--size);border-radius:50% 50% 50% 0;background:var(--pin-color);border:3px solid var(--border-color);display:flex;align-items:center;justify-content:center;transform:rotate(-45deg);box-shadow:0 3px 10px #0003;position:relative;transition:transform .2s}.pin-marker:hover{transform:rotate(-45deg) scale(1.15)}.pin-marker.verified{box-shadow:0 0 0 3px #ffd70066,0 3px 10px #0003}.pin-emoji{transform:rotate(45deg);font-size:14px}.pin-verified-badge{position:absolute;top:-6px;right:-6px;font-size:12px;transform:rotate(45deg);filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.new-pin-marker{background:none!important;border:none!important}.new-pin-pulse{width:40px;height:40px;border-radius:50%;background:var(--primary);opacity:.6;animation:pulse 1.5s ease-out infinite}@keyframes pulse{0%{transform:scale(.8);opacity:.8}to{transform:scale(2);opacity:0}}.pin-popup-content{padding:16px}.pin-popup-header{display:flex;gap:6px;margin-bottom:8px}.pin-category-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);color:#fff;font-size:11px;font-weight:600}.pin-verified-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);background:#fef3c7;color:#92400e;font-size:11px;font-weight:600}.pin-transit-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);background:#fef2f2;color:var(--danger);font-size:11px;font-weight:600}.pin-popup-content h3{font-size:15px;font-weight:600;margin-bottom:4px}.pin-popup-content p{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.pin-popup-meta{display:flex;gap:12px;font-size:12px;color:var(--text-muted);margin-bottom:10px}.map-controls{position:absolute;top:12px;left:12px;right:12px;z-index:1000;display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - var(--navbar-height) - 40px);overflow-y:auto}.map-controls-top{display:flex;align-items:center;gap:8px}.category-filters{display:flex;gap:6px;overflow-x:auto;padding:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.category-filters::-webkit-scrollbar{display:none}.category-chip{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--bg-card);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s;box-shadow:var(--shadow-sm);font-family:var(--font-sans);color:var(--text)}.category-chip:hover{border-color:var(--chip-color);transform:translateY(-1px)}.category-chip.active{color:#fff;border-color:transparent;box-shadow:var(--shadow-md)}.chip-label{font-size:12px}.chip-count{background:#ffffff4d;padding:1px 6px;border-radius:var(--radius-full);font-size:10px;font-weight:700}.category-chip:not(.active) .chip-count{background:var(--border-light);color:var(--text-muted)}.search-controls{display:flex;gap:4px;margin-left:auto}.search-controls .btn-icon{background:var(--bg-card);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text-secondary)}.search-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-card);border-radius:var(--radius-sm);border:1.5px solid var(--border);box-shadow:var(--shadow-md);overflow:hidden}.search-bar .search-icon{color:var(--text-muted);flex-shrink:0}.search-bar input{flex:1;border:none;outline:none;font-size:14px;background:none;color:var(--text);font-family:var(--font-sans)}.map-recenter-btn{position:absolute;bottom:24px;right:12px;z-index:1000;width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:1.5px solid var(--border);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s}.map-recenter-btn:hover{color:var(--primary);border-color:var(--primary)}.fab-btn{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:1000;width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;border:none;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.fab-btn:hover{background:var(--primary-dark)}.pin-creator-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:flex-end;pointer-events:none}.pin-creator{width:100%;max-height:92vh;background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-xl);overflow-y:auto;pointer-events:all}.pin-creator-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px;position:sticky;top:0;background:var(--bg-card);z-index:1}.pin-creator-header h2{display:flex;align-items:center;gap:8px;font-size:18px}.pin-creator-prompt{padding:40px 20px;text-align:center;color:var(--text-secondary)}.pulse-dot{width:16px;height:16px;border-radius:50%;background:var(--primary);margin:0 auto 16px;animation:pulse 1.5s ease-out infinite}.pin-creator-form{padding:0 20px 20px;display:flex;flex-direction:column;gap:16px}.category-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.category-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:none;cursor:pointer;font-size:12px;font-family:var(--font-sans);color:var(--text);transition:all .2s}.category-option span:first-child{font-size:20px}.category-option.active{border-color:var(--cat-color);background:color-mix(in srgb,var(--cat-color) 10%,transparent)}.pin-creator-footer{margin-top:8px}.pin-expiry-note{text-align:center;font-size:12px;color:var(--text-muted);margin-bottom:12px}.pin-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:var(--bg-overlay);display:flex;justify-content:flex-end}.pin-detail{width:100%;max-width:420px;height:100%;background:var(--bg-card);box-shadow:var(--shadow-xl);overflow-y:auto}.pin-detail-header{display:flex;justify-content:flex-end;padding:12px;position:sticky;top:0;background:var(--bg-card);z-index:1}.pin-detail-content{padding:0 20px 20px}.pin-detail-top{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.pin-detail-title{font-size:22px;font-weight:700;margin-bottom:8px}.pin-detail-desc{color:var(--text-secondary);font-size:14px;margin-bottom:16px;line-height:1.6}.pin-detail-meta{display:flex;gap:16px;margin-bottom:16px}.meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}.pin-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-size:13px;font-weight:500;margin-bottom:16px;text-decoration:none}.pin-link:hover{text-decoration:underline}.pin-detail-stats{margin-bottom:20px}.stat-actions{display:flex;gap:8px;flex-wrap:wrap}.pin-detail-rating{background:var(--bg);border-radius:var(--radius-md);padding:16px;margin-bottom:20px}.pin-detail-rating h4{display:flex;align-items:center;gap:6px;font-size:14px;margin-bottom:10px}.rating-row{display:flex;align-items:center;gap:12px}.avg-rating{font-size:13px;color:var(--text-muted)}.star-rating{display:flex;gap:2px}.star-btn{background:none;border:none;cursor:pointer;padding:2px;color:var(--border);transition:transform .15s}.star-btn:hover:not(:disabled){transform:scale(1.2)}.star-btn.filled{color:#f59e0b}.chat-thread{border-top:1px solid var(--border);padding-top:16px}.chat-thread h4{font-size:14px;margin-bottom:12px}.chat-messages{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.chat-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:20px}.chat-message{background:var(--bg);border-radius:var(--radius-sm);padding:10px 12px}.chat-message.own{background:#6c5ce714;border-left:3px solid var(--primary)}.chat-message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.chat-message-header strong{font-size:13px}.chat-message-header span{font-size:11px;color:var(--text-muted)}.chat-message p{font-size:14px;line-height:1.5}.chat-input{display:flex;gap:8px}.chat-input input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-full);font-size:14px;outline:none;font-family:var(--font-sans);color:var(--text);background:var(--bg)}.chat-input input:focus{border-color:var(--primary)}.chat-input .btn{border-radius:50%;width:40px;height:40px;padding:0}.feed-split-view{display:flex;height:100%;overflow:hidden}.feed-split-map{width:50%;height:100%;position:relative;flex-shrink:0;border-right:1px solid var(--border-color)}.feed-split-feed{width:50%;height:100%;overflow-y:auto;position:relative;display:flex;flex-direction:column}.feed-split-feed-full{width:100%}.feed-split-toggle{position:absolute;z-index:1100;background:#fff;border:1px solid var(--border-color);border-radius:10px;cursor:pointer;box-shadow:0 2px 8px #0000001f;display:flex;align-items:center;gap:4px;transition:all .2s}.feed-split-toggle:hover{background:#f5f5f5}.feed-split-collapse{top:12px;right:12px;padding:6px 8px}.feed-split-expand{position:sticky;top:0;left:12px;margin:8px 0 0 12px;padding:6px 12px;font-size:13px;font-weight:500;color:var(--primary)}@media (max-width: 768px){.feed-split-map{display:none}.feed-split-feed,.feed-split-feed-full{width:100%}.feed-split-expand{display:none}.feed-split-feed>*{width:100%;min-width:0;max-width:100%;box-sizing:border-box}.feed-split-feed *:not([class*=tab]){max-width:100%}.feed-split-feed img,.feed-split-feed canvas{height:auto}.feed-tabs{overflow-x:auto}}.daily-feed{height:100%;overflow-y:auto;padding:20px;max-width:700px;margin:0 auto}.feed-split-feed .daily-feed,.feed-split-feed .collections-page,.feed-split-feed .dm-page,.feed-split-feed .user-profile{max-width:none}.feed-split-feed>:last-child{flex:1;overflow-y:auto;min-height:0}.feed-section{margin-bottom:32px}.feed-section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--text)}.feed-section-header h3{font-size:18px;font-weight:700}.feed-section-header.transit{color:var(--danger)}.transit-pulse{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:pulse 1.5s ease-out infinite}.feed-empty{color:var(--text-muted);font-size:14px;text-align:center;padding:24px;background:var(--bg);border-radius:var(--radius-md)}.feed-list{display:flex;flex-direction:column;gap:10px}.feed-pin-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:all .2s}.feed-pin-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md)}.feed-card-left{flex-shrink:0}.feed-card-emoji{font-size:28px}.feed-card-body{flex:1;min-width:0}.feed-card-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}.feed-card-category{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.feed-card-verified{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:#92400e;background:#fef3c7;padding:2px 6px;border-radius:var(--radius-full)}.feed-card-body h4{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-card-desc{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.feed-card-meta{display:flex;gap:12px;margin-top:6px;font-size:11px;color:var(--text-muted)}.feed-card-meta span{display:flex;align-items:center;gap:3px}.feed-card-arrow{color:var(--text-muted);flex-shrink:0}.user-profile{height:100%;overflow-y:auto;padding:24px 20px;max-width:600px;margin:0 auto}.profile-header{text-align:center;margin-bottom:24px}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:32px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:var(--shadow-md)}.profile-header h2{font-size:22px;margin-bottom:4px}.profile-email{color:var(--text-secondary);font-size:14px;margin-bottom:8px}.profile-uni{display:inline-block;padding:4px 14px;border-radius:var(--radius-full);border:2px solid;font-size:12px;font-weight:600}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:28px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 10px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-card svg{color:var(--primary)}.stat-value{font-size:22px;font-weight:700}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.profile-section{margin-bottom:24px}.profile-section h3{display:flex;align-items:center;gap:8px;font-size:16px;margin-bottom:14px;color:var(--text)}.profile-empty{color:var(--text-muted);font-size:14px;text-align:center;padding:20px;background:var(--bg);border-radius:var(--radius-md)}.upcoming-title{font-size:13px;color:var(--text-muted);margin:16px 0 10px}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.badge-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .2s}.badge-card.earned{border-color:var(--warning);background:#fffbeb}.badge-card.locked{opacity:.5;filter:grayscale(.5)}.badge-icon{font-size:28px}.badge-name{font-size:13px;font-weight:600}.badge-desc{font-size:11px;color:var(--text-muted)}.logout-btn{margin-top:8px}@media (max-width: 768px){.navbar{position:fixed;bottom:0;left:0;right:0;top:auto;border-top:1px solid var(--border);border-bottom:none;z-index:1000;height:64px;padding:0 8px}.navbar-brand{display:none}.navbar-links{flex:1;justify-content:space-around}.nav-link{flex-direction:column;gap:2px;padding:6px 12px;font-size:11px}.app-main{padding-bottom:64px}.profile-stats{grid-template-columns:repeat(2,1fr)}.pin-detail{max-width:100%}.category-selector{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.auth-card{padding:28px 20px}.badge-grid{grid-template-columns:repeat(2,1fr)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pin-step-bar{display:flex;align-items:center;justify-content:center;gap:8px;padding:0 20px 16px}.pin-step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}.pin-step-dot.active{width:24px;border-radius:var(--radius-full);background:var(--primary)}.pin-category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 20px 20px;max-height:60vh;overflow-y:auto}.pin-cat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px 8px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .2s;font-family:var(--font-sans);color:var(--text)}.pin-cat-card:hover{border-color:var(--cat-color);background:color-mix(in srgb,var(--cat-color) 8%,var(--bg-card));transform:translateY(-2px);box-shadow:var(--shadow-md)}.pin-cat-emoji{font-size:28px;line-height:1}.pin-cat-label{font-size:12px;font-weight:600;text-align:center;line-height:1.2}.location-confirmed{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px;margin-bottom:16px;border-radius:var(--radius-md);background:color-mix(in srgb,var(--success) 8%,var(--bg-card));border:1.5px solid color-mix(in srgb,var(--success) 25%,transparent)}.confirmed-emoji{font-size:36px;animation:bounceIn .5s ease-out}.location-confirmed p{font-weight:600;color:var(--success);font-size:15px}.coords{font-size:11px;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;letter-spacing:.3px}@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes pinDrop{0%{transform:translateY(-220px) scaleY(1.05);opacity:0}50%{transform:translateY(0) scale(1);opacity:1}60%{transform:translateY(0) scale(1.15,.85)}75%{transform:translateY(-12px) scaleY(1.05)}to{transform:translateY(0) scale(1)}}.pin-drop-anim{animation:pinDrop .7s cubic-bezier(.34,1.56,.64,1);transform-origin:bottom center}@keyframes pinPulse{0%,to{box-shadow:0 0 #f59e0b80}50%{box-shadow:0 0 0 12px #f59e0b00}}.pin-featured-anim{animation:pinPulse 1.8s ease-in-out infinite;border-radius:999px}.building-fields{display:flex;flex-direction:column;gap:8px}.building-fields input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-sans);color:var(--text);background:var(--bg-card);transition:border-color .2s}.building-fields input:focus{outline:none;border-color:var(--primary)}.building-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.label-hint{font-size:12px;font-weight:400;color:var(--text-muted);margin-left:4px}.label-sub{display:block;font-size:12px;font-weight:400;color:var(--text-muted);margin:2px 0 8px}.transit-line-grid{display:flex;flex-wrap:wrap;gap:6px}.transit-line-chip{width:42px;height:42px;border-radius:50%;border:2px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;font-family:var(--font-sans);color:var(--text);cursor:pointer;transition:all .2s}.transit-line-chip:hover{border-color:var(--line-color);transform:scale(1.1)}.transit-line-chip.active{background:var(--line-color);border-color:var(--line-color);color:#fff;box-shadow:0 2px 10px color-mix(in srgb,var(--line-color) 50%,transparent);transform:scale(1.1)}.transit-issue-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.transit-issue-chip{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans);color:var(--text);transition:all .2s}.transit-issue-chip:hover{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 5%,var(--bg-card))}.transit-issue-chip.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,var(--bg-card));color:var(--primary);font-weight:600}.transit-issue-chip span:first-child{font-size:18px;line-height:1}.transit-status-group{display:flex;flex-direction:column;gap:8px}.transit-status-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;font-size:14px;font-weight:500;color:var(--text);transition:all .2s}.transit-status-option input[type=radio]{display:none}.transit-status-option .status-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--border);transition:all .2s;flex-shrink:0}.transit-status-option.active{border-color:var(--status-color);background:color-mix(in srgb,var(--status-color) 8%,var(--bg-card))}.transit-status-option.active .status-dot{background:var(--status-color);border-color:var(--status-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--status-color) 25%,transparent)}.search-cat-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);font-size:16px;flex-shrink:0}.btn-xs{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-muted);cursor:pointer}.btn-xs:hover{background:var(--border-light);color:var(--text)}.transit-line-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:var(--radius-full);color:#fff;font-weight:700;margin-bottom:12px}.transit-badge-label{font-size:15px}.transit-badge-system{font-size:11px;font-weight:500;opacity:.85}.pin-transit-status-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.3px}.pin-verified-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:color-mix(in srgb,var(--success) 12%,transparent);color:var(--success)}.pin-building-info{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:var(--bg);border-radius:var(--radius-sm);margin-bottom:12px;font-size:13px;color:var(--text-secondary)}.pin-building-info>svg{margin-top:2px;flex-shrink:0;color:var(--text-muted)}.pin-building-info>div{display:flex;flex-direction:column;gap:2px}.building-name{font-weight:600;color:var(--text)}.building-detail{font-size:12px;color:var(--text-muted)}.chat-restricted{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 20px;margin-top:16px;background:var(--bg);border-radius:var(--radius-md);text-align:center}.chat-restricted svg{color:var(--text-muted)}.chat-restricted p{font-size:13px;color:var(--text-secondary);max-width:260px;line-height:1.5}.feed-tabs{display:flex;flex-wrap:nowrap;gap:4px;padding:12px 16px 8px;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.feed-tabs::-webkit-scrollbar{height:4px}.feed-tabs::-webkit-scrollbar-track{background:transparent}.feed-tabs::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.feed-tabs::-webkit-scrollbar-thumb:hover{background:#00000059}.feed-tab{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:var(--radius-sm);border:none;background:none;font-size:13px;font-weight:500;font-family:var(--font-sans);color:var(--text-muted);cursor:pointer;transition:all .2s;white-space:nowrap}.feed-tab:hover{background:var(--border-light);color:var(--text-secondary)}.feed-tab.active{background:var(--primary);color:#fff;font-weight:600;box-shadow:var(--shadow-sm)}.feed-card-building{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);margin-top:2px}.feed-card-building svg{flex-shrink:0}.transit-pulse{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:pulse 1.5s ease-out infinite;flex-shrink:0}@media (max-width: 480px){.pin-category-grid{grid-template-columns:repeat(2,1fr)}.transit-issue-grid{grid-template-columns:1fr}.transit-line-chip{width:36px;height:36px;font-size:12px}}.deal-highlight{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,#fdf2f8,#fae8ff);border-radius:10px;font-size:13px;color:#86198f;font-weight:500}[data-theme=dark] .deal-highlight{background:linear-gradient(135deg,#d946ef26,#a855f71f);color:#e879f9}.deal-badge{background:#d946ef;color:#fff;font-weight:700;padding:4px 10px;border-radius:6px;font-size:14px;white-space:nowrap}.pin-marker.mta-live-alert{animation:mta-pulse 2s ease-in-out infinite;box-shadow:0 0 #ef444480}@keyframes mta-pulse{0%{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}.mta-live-badge{position:absolute;top:-6px;right:-10px;background:#ef4444;color:#fff;font-size:8px;font-weight:800;padding:1px 4px;border-radius:4px;letter-spacing:.5px;line-height:1.2;box-shadow:0 1px 3px #0000004d}.popup-line-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;color:#fff;font-size:11px;font-weight:700;line-height:1}.pin-category-tag.mta-tag{font-size:10px;letter-spacing:.5px;text-transform:uppercase;font-weight:700}.mta-severity{text-transform:capitalize;font-weight:600;font-size:11px}.mta-popup .pin-popup-content{border-left:3px solid #EF4444}.transit-status-panel{padding:4px 0}.transit-status-header{display:flex;align-items:center;justify-content:space-between;padding:0 4px;margin-bottom:8px}.transit-status-title{display:flex;align-items:center;gap:8px}.transit-status-title h3{margin:0;font-size:16px;font-weight:700}.transit-status-meta{display:flex;align-items:center;gap:8px}.transit-mode-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:800;letter-spacing:1px;padding:2px 8px;border-radius:4px;text-transform:uppercase}.transit-mode-badge.live{background:#dcfce7;color:#16a34a}.transit-mode-badge.demo{background:#fef3c7;color:#d97706}[data-theme=dark] .transit-mode-badge.live{background:#16a34a26}[data-theme=dark] .transit-mode-badge.demo{background:#d9770626}.transit-refresh-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:4px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;transition:color .2s,border-color .2s}.transit-refresh-btn:hover{color:var(--primary);border-color:var(--primary)}.transit-last-updated{font-size:11px;color:var(--text-secondary);margin:0 0 12px 4px}.transit-loading,.transit-error{display:flex;align-items:center;gap:8px;padding:12px;font-size:13px;color:var(--text-secondary)}.transit-error{color:#ef4444;background:#ef444414;border-radius:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}@keyframes dm-typing-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-4px);opacity:1}}.feed-pin-card:hover .pin-card-dismiss,.feed-pin-card:focus-within .pin-card-dismiss{opacity:1!important}.pin-card-dismiss:hover{background:#ef44441f!important;color:#dc2626!important}.transit-line-grid-section{display:flex;flex-wrap:wrap;gap:6px;padding:8px;background:var(--surface);border-radius:12px;border:1px solid var(--border);margin-bottom:16px}.transit-line-group{display:flex;gap:4px}.transit-line-group+.transit-line-group:before{content:"";display:block;width:1px;background:var(--border);margin:2px}.transit-line-circle{position:relative;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:default;transition:transform .15s}.transit-line-circle:hover{transform:scale(1.15)}.transit-line-circle .line-letter{color:#fff;font-size:13px;font-weight:800;line-height:1}.transit-line-circle .line-status-dot{position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--surface, #fff)}.transit-line-circle.has-alert{animation:line-alert-pulse 2.5s ease-in-out infinite}@keyframes line-alert-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.transit-alerts-section{margin-top:4px}.transit-alerts-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-left:4px}.transit-alerts-header h4{margin:0;font-size:14px;font-weight:600}.transit-alerts-list{display:flex;flex-direction:column;gap:8px}.transit-alert-card{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid #EF4444;border-radius:10px;cursor:pointer;transition:border-color .2s,box-shadow .2s}.transit-alert-card:hover{border-color:#ef4444;box-shadow:0 2px 8px #ef44441f}.transit-alert-left{flex-shrink:0}.transit-alert-lines{display:flex;flex-direction:column;gap:3px}.transit-alert-line-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;color:#fff;font-size:13px;font-weight:800;line-height:1}.transit-alert-body{flex:1;min-width:0}.transit-alert-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.transit-alert-severity{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.transit-alert-time{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--text-secondary)}.transit-alert-body h4{margin:0 0 4px;font-size:13px;font-weight:600;line-height:1.3}.transit-alert-desc{margin:0 0 6px;font-size:12px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.transit-alert-station{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary)}.transit-alert-arrow{flex-shrink:0;color:var(--text-secondary);margin-top:4px}.transit-no-alerts{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;text-align:center;color:#10b981}.transit-no-alerts p{margin:0;font-size:13px;font-weight:500}.transit-section-tabs{display:flex;gap:4px;padding:8px 12px;background:var(--bg);border-bottom:1px solid var(--border)}.transit-section-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:none;border-radius:var(--radius-sm);background:none;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s}.transit-section-tab.active{background:var(--primary);color:#fff;font-weight:600}.shuttle-header{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px 10px}.shuttle-header-info h3{margin:0 0 2px;font-size:17px;font-weight:700}.shuttle-header-info p{margin:0;font-size:12px;color:var(--text-muted)}.shuttle-track-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:8px;background:var(--primary);color:#fff;font-size:11px;font-weight:600;text-decoration:none;white-space:nowrap}.shuttle-track-btn:hover{opacity:.9}.shuttle-routes-list{padding:0 12px 12px;display:flex;flex-direction:column;gap:8px}.shuttle-route-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.shuttle-route-header{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer}.shuttle-route-badge{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:16px;flex-shrink:0}.shuttle-route-info{flex:1;min-width:0}.shuttle-route-info h4{margin:0;font-size:14px;font-weight:600}.shuttle-route-desc{margin:1px 0 0;font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shuttle-route-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.shuttle-status-pill{padding:3px 8px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.shuttle-next-bus{display:flex;align-items:center;gap:6px;padding:6px 12px 8px;font-size:12px;color:var(--text-secondary);border-top:1px solid var(--border-light)}.shuttle-next-text{font-weight:600;color:var(--text-primary)}.shuttle-next-detail{color:var(--text-muted);font-size:11px}.shuttle-route-details{border-top:1px solid var(--border);padding:10px 12px 14px}.shuttle-schedule-section h5,.shuttle-stops-section h5{margin:0 0 6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.shuttle-schedule-table{margin-bottom:14px}.shuttle-schedule-row{display:flex;align-items:center;padding:5px 0;font-size:12px;border-bottom:1px solid var(--border-light)}.shuttle-schedule-row:last-child{border-bottom:none}.shuttle-sched-day{width:100px;font-weight:600;color:var(--text-primary)}.shuttle-sched-time{flex:1;color:var(--text-secondary)}.shuttle-sched-freq{color:var(--text-muted);font-size:11px}.shuttle-stops-section{margin-top:6px}.shuttle-stops-list{display:flex;flex-direction:column}.shuttle-stop-item{display:flex;align-items:flex-start;gap:10px;position:relative;padding:4px 0 4px 20px}.shuttle-stop-dot{position:absolute;left:3px;top:8px;width:10px;height:10px;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px #00000026;z-index:1}.shuttle-stop-line{position:absolute;left:7px;top:18px;width:2px;height:calc(100% - 6px);opacity:.3}.shuttle-stop-info{display:flex;flex-direction:column}.shuttle-stop-name{font-size:12px;font-weight:500;color:var(--text-primary)}.shuttle-stop-note{font-size:10px;color:var(--text-muted)}.shuttle-footer{padding:10px 16px 16px;text-align:center}.shuttle-footer p{margin:2px 0;font-size:11px;color:var(--text-muted)}.pin-rating-overview{display:flex;align-items:center;gap:16px;padding:14px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a20);border-radius:var(--radius-md);margin-bottom:16px;border:1px solid #FDE68A}[data-dark=true] .pin-rating-overview{background:linear-gradient(135deg,#f59e0b1f,#f59e0b0d);border-color:#f59e0b40}.rating-score-large{display:flex;align-items:center;gap:4px}.rating-number{font-size:28px;font-weight:800;color:var(--text);line-height:1}.rating-out-of{font-size:14px;color:var(--text-muted);margin-left:2px}.rating-details{display:flex;flex-direction:column;gap:3px}.rating-count{font-size:13px;color:var(--text-secondary);font-weight:500}.rating-rank{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#d97706;background:#d977061a;padding:2px 8px;border-radius:var(--radius-full)}.pin-address{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--border-light);border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary);margin-bottom:10px}.pin-address svg{flex-shrink:0;color:var(--primary)}[data-dark=true] .pin-address{background:#ffffff0d}.pin-venue-info{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.venue-type-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:#fef3c7;color:#92400e;border:1px solid #FDE68A}[data-dark=true] .venue-type-chip{background:#f59e0b1f;color:#fcd34d;border-color:#f59e0b40}.meal-time-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:#ede9fe;color:#5b21b6;border:1px solid #DDD6FE}[data-dark=true] .meal-time-chip{background:#8b5cf61f;color:#c4b5fd;border-color:#8b5cf640}.pin-dietary-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.dietary-tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}[data-dark=true] .dietary-tag-chip{background:#10b9811a;color:#6ee7b7;border-color:#10b98140}.dietary-tag-grid{display:flex;flex-wrap:wrap;gap:6px}.dietary-tag-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--bg-card);font-size:12px;font-weight:500;font-family:var(--font-sans);color:var(--text);cursor:pointer;transition:all .2s}.dietary-tag-btn:hover{border-color:#10b981;background:#ecfdf5}.dietary-tag-btn.active{background:#10b981;border-color:#10b981;color:#fff;box-shadow:0 2px 8px #10b9814d}.pin-fitness-types{margin-bottom:14px}.pin-fitness-types h4{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.fitness-types-list{display:flex;flex-wrap:wrap;gap:6px}.fitness-type-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:#f0fdf4;color:#166534;border:1px solid #BBF7D0}[data-dark=true] .fitness-type-chip{background:#10b9811a;color:#86efac;border-color:#10b98140}.pin-food-extras{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.food-extra-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;border:1px solid}.food-extra-chip.walk-in{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.food-extra-chip.reservation{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.food-extra-chip.groups{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.food-extra-chip.discount{background:#fdf2f8;color:#9d174d;border-color:#fbcfe8}[data-dark=true] .food-extra-chip.walk-in{background:#10b9811a;color:#86efac;border-color:#10b98140}[data-dark=true] .food-extra-chip.reservation{background:#f973161a;color:#fdba74;border-color:#f9731640}[data-dark=true] .food-extra-chip.groups{background:#3b82f61a;color:#93c5fd;border-color:#3b82f640}[data-dark=true] .food-extra-chip.discount{background:#ec48991a;color:#f9a8d4;border-color:#ec489940}.delivery-apps-row{width:100%;display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:4px}.delivery-label{font-size:11px;font-weight:600;color:var(--text-secondary)}.delivery-app-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:600;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.pin-menu-photos-section{margin-bottom:14px}.menu-photos-toggle{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--border);border-radius:var(--radius);padding:8px 14px;font-size:12px;font-weight:600;color:var(--text-primary);cursor:pointer;width:100%;transition:background .15s}.menu-photos-toggle:hover{background:var(--bg-tertiary)}.menu-photos-content{margin-top:10px}.menu-photos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:10px}.menu-photo-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--bg-secondary)}.menu-photo-img{width:100%;height:100px;object-fit:cover}.menu-photo-info{display:flex;justify-content:space-between;align-items:center;padding:6px 8px 2px}.menu-photo-name{font-size:11px;font-weight:600;color:var(--text-primary)}.menu-photo-price{font-size:11px;font-weight:700;color:var(--accent)}.menu-photo-by{display:block;padding:2px 8px 6px;font-size:9px;color:var(--text-muted)}.menu-photos-empty{font-size:12px;color:var(--text-muted);text-align:center;padding:12px 0}.menu-photo-upload{margin-top:8px}.menu-photo-fields{display:flex;gap:6px;margin-bottom:6px}.menu-photo-fields input{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;background:var(--bg-secondary);color:var(--text-primary)}.menu-photo-upload-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px dashed var(--border);border-radius:var(--radius);font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;transition:background .15s}.menu-photo-upload-btn:hover{background:var(--bg-tertiary)}.reservation-toggle-group{display:flex;gap:6px}.fitness-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.fitness-type-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-card);font-size:12px;font-weight:500;font-family:var(--font-sans);color:var(--text);cursor:pointer;transition:all .2s}.fitness-type-btn:hover{border-color:#10b981}.fitness-type-btn.active{background:#10b981;border-color:#10b981;color:#fff;box-shadow:0 2px 8px #10b9814d}.fitness-type-btn span:first-child{font-size:16px}.sub-filter-bar{background:var(--bg-card);border-radius:var(--radius-sm);border:1.5px solid var(--border);box-shadow:var(--shadow-md);padding:10px 14px}.sub-filter-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.sub-filter-chips{display:flex;flex-wrap:wrap;gap:5px}.sub-filter-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--bg-card);font-size:11px;font-weight:500;font-family:var(--font-sans);color:var(--text);cursor:pointer;transition:all .15s;white-space:nowrap}.sub-filter-chip:hover{border-color:var(--primary)}.sub-filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px 4px #6c5ce74d}.btn-filter-toggle{background:var(--bg-card);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text-secondary);transition:all .2s}.btn-filter-toggle:hover{border-color:var(--primary);color:var(--primary)}.btn-filter-toggle.active{border-color:transparent;box-shadow:var(--shadow-md)}.pin-menu-link{display:inline-flex;align-items:center;gap:6px;color:#d97706;font-size:13px;font-weight:600;margin-bottom:10px;text-decoration:none;padding:6px 14px;border-radius:var(--radius-full);background:#fef3c7;border:1px solid #FDE68A;transition:all .2s}.pin-menu-link:hover{background:#fde68a;transform:translateY(-1px)}[data-dark=true] .pin-menu-link{background:#d977061f;border-color:#d9770640;color:#fbbf24}.btn-reservation{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;font-size:14px;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:all .2s;margin-bottom:16px;box-shadow:0 4px 14px #6c5ce759}.btn-reservation:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6c5ce773}.reservation-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#0009;display:flex;align-items:center;justify-content:center;padding:20px}.reservation-modal{width:100%;max-width:600px;max-height:85vh;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;overflow:hidden}.reservation-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.reservation-modal-header h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700}.reservation-modal-body{flex:1;min-height:400px}.reservation-iframe{width:100%;height:100%;min-height:400px;border:none;background:var(--bg)}.reservation-modal-footer{padding:12px 20px;border-top:1px solid var(--border);text-align:center;font-size:12px;color:var(--text-muted)}.reservation-modal-footer a{color:var(--primary);font-weight:600;text-decoration:none}.reservation-modal-footer a:hover{text-decoration:underline}.pin-popular-items{background:var(--bg);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.pin-popular-items h4{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;margin-bottom:12px;color:var(--text)}.popular-items-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.popular-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:all .15s}.popular-item:hover{border-color:var(--border)}.popular-item-rank{font-size:16px;width:28px;text-align:center;flex-shrink:0}.popular-item-name{flex:1;font-size:13px;font-weight:500}.popular-item-vote{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:none;font-size:11px;font-weight:600;color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);transition:all .15s}.popular-item-vote:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.popular-items-empty{font-size:13px;color:var(--text-muted);text-align:center;padding:12px;margin-bottom:12px}.popular-item-add{display:flex;gap:8px}.popular-item-add input{flex:1;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-full);font-size:13px;font-family:var(--font-sans);color:var(--text);background:var(--bg-card);outline:none}.popular-item-add input:focus{border-color:var(--primary)}.popular-item-add .btn{border-radius:var(--radius-full)}.popular-items-subtitle{font-size:11px;color:var(--text-muted);margin-bottom:10px}.popular-item.top-3{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-sm);padding:8px 10px}.popular-item-vote.voted{background:#dbeafe;border-color:#3b82f6;color:#3b82f6;cursor:default}.popular-items-more{border-top:1px solid var(--border);margin-top:6px;padding-top:6px}.popular-items-more .popular-item{opacity:.8}.pin-edit-btn{display:inline-flex;align-items:center;gap:6px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius-full);padding:4px 12px;font-size:12px;color:#2563eb;cursor:pointer;margin:4px 0 8px;transition:all .15s}.pin-edit-btn:hover{background:#dbeafe}.edit-time-left{color:#6b7280;font-size:11px}.pin-edit-title{width:100%;font-size:1.2rem;font-weight:700;border:2px solid #3B82F6;border-radius:var(--radius-sm);padding:8px 12px;font-family:var(--font-sans);color:var(--text);background:var(--bg-card);outline:none;margin-bottom:6px}.pin-edit-desc{width:100%;border:2px solid #3B82F6;border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;font-family:var(--font-sans);color:var(--text);background:var(--bg-card);outline:none;resize:vertical}.pin-edit-address{flex:1;border:2px solid #3B82F6;border-radius:var(--radius-sm);padding:4px 8px;font-size:13px;font-family:var(--font-sans);color:var(--text);background:var(--bg-card);outline:none}.pin-edit-actions{display:flex;gap:8px;margin-bottom:12px}.recs-input-group{display:flex;flex-direction:column;gap:6px}.rec-input-row{display:flex;align-items:center;gap:8px}.rec-input-row .rec-rank{font-size:18px;min-width:28px;text-align:center}.rec-input-row input{flex:1;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);color:var(--text);background:var(--bg-card);outline:none}.rec-input-row input:focus{border-color:var(--primary)}.class-standing-badge{background:#eff6ff;padding:2px 10px;border-radius:var(--radius-full);color:#1d4ed8!important;font-weight:600}.class-standing-badge span{color:#1d4ed8!important}[data-dark=true] .class-standing-badge{background:#3b82f61f;color:#60a5fa!important}[data-dark=true] .class-standing-badge span{color:#60a5fa!important}.profile-class-year{display:inline-block;margin-top:6px;padding:3px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;background:#eff6ff;color:#1d4ed8;margin-left:6px}[data-dark=true] .profile-class-year{background:#3b82f61f;color:#60a5fa}@media (max-width: 480px){.fitness-type-grid{grid-template-columns:1fr}.reservation-modal{max-width:100%;max-height:95vh;border-radius:var(--radius-md)}.pin-rating-overview{flex-direction:column;text-align:center}.rating-details{align-items:center}}.pin-photo-gallery{position:relative;width:100%;border-radius:var(--radius-md);overflow:hidden;margin-bottom:16px;background:#000;aspect-ratio:16 / 10}.pin-photo-main{width:100%;height:100%;object-fit:cover;display:block}.photo-nav{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;border:none;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;z-index:2}.photo-nav:hover{background:#000c}.photo-nav-prev{left:8px}.photo-nav-next{right:8px}.photo-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:2}.photo-dot{width:8px;height:8px;border-radius:50%;background:#ffffff73;cursor:pointer;transition:all .2s}.photo-dot.active{background:#fff;transform:scale(1.2)}.photo-upload-area{display:flex;flex-wrap:wrap;gap:8px}.photo-preview-thumb{position:relative;width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:1.5px solid var(--border)}.photo-preview-thumb img{width:100%;height:100%;object-fit:cover}.photo-remove-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:#000000a6;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px}.photo-upload-btn{width:72px;height:72px;border-radius:var(--radius-sm);border:2px dashed var(--border);background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;color:var(--text-muted);font-size:11px;font-weight:600;transition:all .2s}.photo-upload-btn:hover{border-color:var(--primary);color:var(--primary);background:#6c5ce70d}.pin-quick-actions{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.quick-action-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--bg-card);font-size:13px;font-weight:600;font-family:var(--font-sans);color:var(--text);cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}.quick-action-btn:hover{border-color:var(--primary);color:var(--primary);background:#6c5ce70d;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.quick-action-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.directions-panel{background:var(--bg);border-radius:var(--radius-md);padding:16px;margin-bottom:16px;border:1px solid var(--border-light)}.directions-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.directions-modes{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.direction-mode-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .2s;font-family:var(--font-sans)}.direction-mode-btn:hover{border-color:#3b82f6;background:#eff6ff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}[data-dark=true] .direction-mode-btn:hover{background:#3b82f61a}.direction-mode-emoji{font-size:24px}.direction-mode-label{font-size:12px;font-weight:600;color:var(--text)}.directions-note{font-size:11px;color:var(--text-muted);text-align:center;margin-top:10px;margin-bottom:0}.reservation-direct-label,.reservation-auto-label{font-size:13px;color:var(--text-secondary);margin-bottom:14px;font-weight:500}.reservation-direct-link{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;font-size:14px;font-weight:700;text-decoration:none;margin-bottom:20px;transition:all .2s;box-shadow:0 4px 14px #6c5ce759}.reservation-direct-link:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6c5ce773}.reservation-sources{display:flex;flex-direction:column;gap:8px;padding:0 4px}.reservation-source-btn{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-card);text-decoration:none;color:var(--text);transition:all .2s}.reservation-source-btn:hover{border-color:var(--primary);background:#6c5ce70d;transform:translate(4px)}.reservation-source-icon{font-size:24px;width:36px;text-align:center}.reservation-source-label{flex:1;font-size:14px;font-weight:600}.reservation-source-btn svg{color:var(--text-muted);flex-shrink:0}.reservation-modal-body{flex:1;padding:20px;overflow-y:auto}@media (max-width: 480px){.directions-modes{grid-template-columns:repeat(2,1fr)}.pin-quick-actions{flex-wrap:wrap}.quick-action-btn{flex:1;min-width:0;justify-content:center;padding:8px 10px;font-size:12px}.pin-photo-gallery{aspect-ratio:16 / 9;border-radius:var(--radius-sm)}}.animated-fade-in{animation:fadeIn .25s ease-out}.pin-trending-tag{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#ff6b35,#ff3d00);color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 4px #ff3d004d}50%{box-shadow:0 0 12px #ff3d0099}}.feed-card-trending{display:inline-flex;align-items:center;gap:3px;background:linear-gradient(135deg,#ff6b35,#ff3d00);color:#fff;font-size:10px;font-weight:600;padding:2px 7px;border-radius:var(--radius-full)}.study-buddy-section{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #BFDBFE;border-radius:var(--radius);padding:10px 14px;margin:8px 0}.study-buddy-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#1e40af}.check-in-btn{margin-left:auto;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;border-radius:var(--radius-full);border:1px solid #3B82F6;background:#fff;color:#3b82f6;cursor:pointer;transition:all .15s}.check-in-btn:hover{background:#eff6ff}.check-in-btn.checked-in{background:#3b82f6;color:#fff}.study-buddy-list{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.study-buddy-chip{display:inline-flex;align-items:center;padding:3px 8px;background:#fff;border-radius:var(--radius-full);font-size:11px;color:#1e40af;border:1px solid #BFDBFE}.deal-qr-section{margin:8px 0}.deal-qr-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;border-radius:var(--radius);border:2px dashed #D946EF;background:linear-gradient(135deg,#fdf4ff,#fae8ff);color:#a21caf;font-weight:600;font-size:14px;cursor:pointer;transition:all .15s}.deal-qr-btn:hover{background:linear-gradient(135deg,#fae8ff,#f5d0fe)}.deal-qr-btn.redeemed{border-color:#10b981;background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#059669}.deal-qr-display{display:flex;flex-direction:column;align-items:center;padding:16px;margin-top:8px;background:#fff;border-radius:var(--radius);border:1px solid var(--border)}.deal-qr-img{width:160px;height:160px;border-radius:var(--radius-sm);margin-bottom:8px}.deal-qr-instructions{font-size:13px;text-align:center;color:var(--text);margin-bottom:4px}.deal-qr-count{font-size:11px;color:var(--text-muted)}.org-selector{display:flex;flex-wrap:wrap;gap:6px}.org-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg);font-size:11px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.org-chip:hover{border-color:var(--primary-light)}.org-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.feed-event-card{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:default;transition:all .15s}.feed-event-card:hover{border-color:var(--primary-light);transform:translateY(-1px)}.event-card-emoji{font-size:24px;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fef3c7;border-radius:var(--radius-sm)}.event-card-body h4{font-size:14px;font-weight:600;margin-bottom:4px}.event-card-meta{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--text-secondary)}.event-card-meta span{display:flex;align-items:center;gap:4px}.feed-subtitle{font-size:12px;color:var(--text-muted);padding:0 4px;margin-bottom:8px}.pin-hours-indicator{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--radius-sm);margin:6px 0;font-size:13px;border:1px solid}.pin-hours-indicator.open{background:#f0fdf4;border-color:#86efac}.pin-hours-indicator.closed{background:#fef2f2;border-color:#fecaca}.hours-status{font-weight:700;font-size:13px}.hours-status.open{color:#16a34a}.hours-status.closed{color:#dc2626}.hours-today{color:var(--text-muted);font-size:12px}.pin-price-range{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;color:var(--text-muted)}.price-label{font-weight:700;color:#16a34a;font-size:14px}.price-desc{color:var(--text-muted);font-size:12px}.price-range-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.price-range-btn{display:flex;flex-direction:column;align-items:center;padding:8px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:all .15s}.price-range-btn.active{border-color:#16a34a;background:#f0fdf4;color:#16a34a}.price-range-label{font-weight:700;font-size:16px}.price-range-desc{font-size:10px;color:var(--text-muted)}.noise-reports{font-weight:400;font-size:11px;color:#9ca3af;margin-left:4px}.noise-label{font-size:11px;color:#9ca3af;margin-right:2px}.noise-level-section{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #BFDBFE;border-radius:var(--radius-md);padding:10px 12px;margin:6px 0}.noise-level-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#1d4ed8}.noise-current{margin-left:auto;font-weight:700}.noise-report-btns{display:flex;align-items:center;gap:6px;margin-top:8px}.noise-btn{width:32px;height:32px;border-radius:50%;border:2px solid;background:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}.noise-btn:hover{transform:scale(1.15)}.listings-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.listings-popup{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040}.listings-popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.listings-popup-header h3{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px;margin:0}.listings-popup-body{overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.dm-compose-popup{background:#fff;border-radius:16px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000040}.listing-actions{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.06)}.listing-action-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;border:1px solid var(--border-color);background:#fff;font-size:11px;font-weight:500;cursor:pointer;color:var(--text-secondary);transition:all .2s}.listing-action-btn:hover{background:var(--primary-light, #F3E8FF);color:var(--primary);border-color:var(--primary)}.listing-action-dm{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.listing-action-dm:hover{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.roommate-section{background:linear-gradient(135deg,#f0fdfa,#ccfbf1);border:1px solid #99F6E4;border-radius:var(--radius-md);padding:12px;margin:8px 0}.roommate-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#0f766e}.roommate-count{margin-left:auto;font-weight:400;font-size:12px;color:#5eead4;background:#0f766e;padding:2px 8px;border-radius:10px}.roommate-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.roommate-card{background:#fff;border:1px solid #E5E7EB;border-radius:var(--radius-sm);padding:10px}.roommate-card-top{display:flex;align-items:center;gap:8px}.rm-class{font-size:11px;color:#9ca3af;background:#f3f4f6;padding:1px 6px;border-radius:8px}.rm-major{font-size:12px;color:#6b7280;margin-top:2px}.rm-bio{font-size:12px;color:#374151;margin:4px 0;line-height:1.4}.rm-details{display:flex;gap:6px;margin-top:4px}.rm-tag{font-size:11px;background:#f0fdfa;border:1px solid #99F6E4;padding:2px 8px;border-radius:8px;color:#0f766e}.roommate-form{display:flex;flex-direction:column;gap:6px;margin-top:8px}.roommate-form input,.roommate-form textarea{padding:6px 10px;border:1px solid #D1D5DB;border-radius:var(--radius-sm);font-size:12px}.rm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.rm-form-actions{display:flex;gap:6px}.shuttle-toggle-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#fff;border:2px solid #D1D5DB;border-radius:20px;cursor:pointer;font-size:12px;font-weight:600;color:#374151;box-shadow:0 2px 6px #0000001a;transition:all .2s}.shuttle-toggle-btn.active{background:#57068c;color:#fff;border-color:#57068c}.shuttle-toggle-btn:hover{transform:scale(1.05)}.shuttle-legend{position:absolute;top:120px;right:12px;z-index:1000;background:#fff;border-radius:var(--radius-md);padding:12px;box-shadow:0 4px 16px #0000001f;width:220px}.shuttle-legend h4{font-size:13px;font-weight:700;margin-bottom:8px;color:#57068c}.shuttle-legend-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}.shuttle-legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:2px}.shuttle-legend-item strong{font-size:12px;display:block}.shuttle-legend-desc{font-size:11px;color:#6b7280;display:block}.shuttle-legend-schedule{font-size:10px;color:#9ca3af;display:block}.navbar-links{justify-content:space-around}.nav-dm-icon{position:relative;display:flex}.nav-unread-badge{position:absolute;top:-6px;right:-8px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.collections-page{padding:16px 16px 100px;max-width:600px;margin:0 auto}.collections-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid var(--border)}.collections-header h2{margin:0;font-size:20px;font-weight:700;letter-spacing:-.3px}.collections-header .btn{border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600}.collections-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.collections-empty svg{margin-bottom:12px;opacity:.4}.collections-empty h3{margin:8px 0;color:var(--text-primary)}.collections-empty p{margin:8px 0 20px;font-size:14px}.collections-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.collection-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;transition:transform .15s,box-shadow .15s}.collection-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.collection-card-cover{height:90px;display:flex;align-items:center;justify-content:center;position:relative}.collection-card-emoji{font-size:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.collection-card-body{padding:10px 12px 12px}.collection-card-body h4{margin:0 0 4px;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collection-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-muted)}.collection-card-meta span{display:flex;align-items:center;gap:3px}.collection-card-visibility{background:var(--bg);padding:2px 6px;border-radius:4px;font-size:10px}.collection-creator-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.collection-creator{width:100%;max-width:400px;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden}.collection-creator-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-color)}.collection-creator-header h3{margin:0}.collection-creator form{padding:16px}.collection-cover-upload{margin-bottom:14px}.collection-cover-preview{display:flex;align-items:center;justify-content:center;height:120px;border-radius:var(--radius-md);cursor:pointer;position:relative;overflow:hidden}.collection-cover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#0000004d;color:#fff;font-size:12px;font-weight:600;opacity:0;transition:opacity .2s}.collection-cover-preview:hover .collection-cover-overlay{opacity:1}.collection-cover-emoji-preview{font-size:40px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.collection-emoji-picker{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.emoji-pick{width:38px;height:38px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-card);font-size:20px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.emoji-pick.active{border-color:var(--primary);background:#22c55e1a;transform:scale(1.1)}.collection-name-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;margin-bottom:14px}.collection-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:2000;display:flex;align-items:flex-end;justify-content:center}.collection-detail{width:100%;max-width:500px;max-height:85vh;background:var(--bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow-y:auto}.collection-detail-banner{position:relative;height:140px;display:flex;align-items:flex-end;padding:16px}.collection-detail-banner-info{display:flex;align-items:center;gap:10px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.4)}.collection-detail-banner-info h3{margin:0;font-size:18px;font-weight:700}.collection-detail-close{position:absolute;top:10px;right:10px;background:#0006!important;color:#fff!important;border-radius:50%;width:32px;height:32px}.collection-detail-close:hover{background:#0009!important}.collection-detail-cover-btn{position:absolute;top:10px;left:10px;background:#0006;color:#fff;border:none;border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;transition:background .2s}.collection-detail-cover-btn:hover{background:#0009}.collection-detail-emoji{font-size:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.collection-detail-count{font-size:12px;color:#ffffffd9}.collection-detail-actions{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color)}.collection-pins{padding:8px 16px 20px}.collection-empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.collection-empty svg{margin-bottom:8px;opacity:.4}.collection-empty-hint{font-size:12px;margin-top:6px}.collection-pin-card{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .15s}.collection-pin-card:hover{background:#00000005}.collection-pin-card:last-child{border-bottom:none}.collection-pin-emoji{font-size:22px}.collection-pin-info{flex:1}.collection-pin-info h4{margin:0 0 2px;font-size:14px}.collection-pin-meta{display:flex;gap:8px;font-size:11px;color:var(--text-muted)}.collection-pin-meta span{display:flex;align-items:center;gap:2px}.collection-picker{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:10px;margin:4px 0}.collection-picker-header{display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;margin-bottom:8px}.collection-picker-empty{font-size:12px;color:var(--text-muted);margin:0}.collection-picker-list{display:flex;flex-direction:column;gap:4px}.collection-picker-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;font-size:13px;transition:all .15s}.collection-picker-item:hover{border-color:var(--primary)}.collection-picker-item.saved{background:#22c55e14;border-color:var(--primary)}.collection-picker-check{font-weight:700;color:var(--primary)}.dm-page{padding:16px 16px 100px;max-width:600px;margin:0 auto}.dm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.dm-header h2{margin:0;font-size:22px}.dm-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.dm-empty svg{margin-bottom:12px;opacity:.4}.dm-empty h3{margin:8px 0;color:var(--text-primary)}.dm-empty p{margin:8px 0 20px;font-size:14px}.dm-conversation-list{display:flex;flex-direction:column}.dm-conversation-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:none;background:none;border-bottom:1px solid var(--border-color);cursor:pointer;text-align:left;width:100%;transition:background .15s}.dm-conversation-item:hover{background:#00000008}.dm-conversation-item.unread{background:#22c55e0a}.dm-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#34D399);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0;position:relative}.dm-unread-dot{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;background:#ef4444;border:2px solid var(--bg-card)}.dm-conversation-info{flex:1;min-width:0}.dm-conversation-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.dm-conversation-name{font-weight:600;font-size:14px}.dm-conversation-time{font-size:11px;color:var(--text-muted)}.dm-conversation-preview{font-size:13px;color:var(--text-muted);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dm-unread-badge{background:var(--primary);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}.dm-chat-view{display:flex;flex-direction:column;height:calc(100vh - 70px);max-width:600px;margin:0 auto}.dm-chat-header{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-color);background:var(--bg-card)}.dm-chat-header-info{display:flex;align-items:center;gap:10px}.dm-chat-header .dm-avatar{width:36px;height:36px;font-size:14px}.dm-chat-name{font-weight:600;font-size:15px;display:block}.dm-chat-uni{font-size:11px;color:var(--text-muted);display:block}.dm-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:6px}.dm-empty-chat{text-align:center;padding:60px 20px;color:var(--text-muted);flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.dm-message{display:flex;max-width:80%}.dm-message.sent{align-self:flex-end}.dm-message.received{align-self:flex-start}.dm-message-bubble{padding:8px 12px;border-radius:16px;max-width:100%}.dm-message.sent .dm-message-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.dm-message.received .dm-message-bubble{background:var(--bg-secondary);border-bottom-left-radius:4px}.dm-message-bubble p{margin:0;font-size:14px;line-height:1.4;word-break:break-word}.dm-message-time{font-size:10px;opacity:.7;display:block;margin-top:2px}.dm-input-bar{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border-color);background:var(--bg-card)}.dm-input-bar input{flex:1;padding:10px 14px;border:1px solid var(--border-color);border-radius:20px;font-size:14px;outline:none}.dm-input-bar input:focus{border-color:var(--primary)}.dm-input-bar .btn-icon{width:40px;height:40px;border-radius:50%}.dm-new-conversation{max-width:600px;margin:0 auto;height:calc(100vh - 70px);display:flex;flex-direction:column}.dm-new-header{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-color)}.dm-new-header h3{margin:0;font-size:16px}.dm-search-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border-color);color:var(--text-muted)}.dm-search-bar input{flex:1;border:none;outline:none;font-size:14px;background:transparent}.dm-user-list{flex:1;overflow-y:auto}.dm-user-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:none;background:none;border-bottom:1px solid var(--border-color);cursor:pointer;text-align:left;width:100%;transition:background .15s}.dm-user-item:hover{background:#00000008}.dm-user-item .dm-avatar{width:40px;height:40px;font-size:15px}.dm-user-info{flex:1}.dm-user-name{font-weight:600;font-size:14px;display:block}.dm-user-email{font-size:12px;color:var(--text-muted);display:block}.dm-no-users{text-align:center;padding:40px 20px;color:var(--text-muted)}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{background:#0000000a;transform:translateY(-1px)}.follow-list-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin:0 0 16px;overflow:hidden}.follow-list-header{padding:10px 14px;border-bottom:1px solid var(--border-color);background:#00000005}.follow-list-header h4{margin:0;font-size:14px}.follow-list{max-height:240px;overflow-y:auto}.follow-list-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border-color)}.follow-list-item:last-child{border-bottom:none}.follow-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#34D399);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.follow-info{flex:1;min-width:0}.follow-name{font-weight:600;font-size:13px;display:block}.follow-email{font-size:11px;color:var(--text-muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-danger{background:#fee2e2;color:#dc2626;border:1px solid #FECACA}.btn-danger:hover{background:#fca5a5}.pin-category-extras{margin:12px 0;padding:12px;background:var(--bg-secondary);border-radius:12px;display:flex;flex-direction:column;gap:10px}.category-extras-grid{display:flex;flex-wrap:wrap;gap:8px}.extra-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;background:var(--bg-primary);border:1px solid var(--border);line-height:1.3}.extra-chip strong{font-weight:600}.extra-chip small{font-size:10px;color:var(--text-muted);display:block}.extra-chip .btn-xs{margin-left:6px;padding:2px 8px;font-size:10px}.extra-chip.wifi{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.extra-chip.outlet{background:#fef3c7;border-color:#fcd34d;color:#92400e}.extra-chip.seating{background:#f3f4f6;border-color:#d1d5db;color:#374151}.extra-chip.studying{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.extra-chip.loyalty{background:#fdf4ff;border-color:#d8b4fe;color:#6b21a8}.extra-chip.light{background:#fffbeb;border-color:#fcd34d;color:#92400e}.extra-chip.whiteboard{background:#f9fafb;border-color:#d1d5db;color:#374151}.extra-chip.printing{background:#f0f9ff;border-color:#7dd3fc;color:#0369a1}.extra-chip.trainer{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.extra-chip.locker{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.extra-chip.daypass{background:#fef3c7;border-color:#fcd34d;color:#92400e}.extra-chip.id-policy{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.extra-chip.dress-code{background:#f5f3ff;border-color:#c4b5fd;color:#5b21b6}.extra-chip.music-genres{background:#fdf4ff;border-color:#d8b4fe;color:#6b21a8}.extra-chip.rsvp{background:#fdf2f8;border-color:#f9a8d4;color:#9d174d}.extra-chip.recurring{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.extra-chip.walk-in{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.extra-chip.telehealth{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.extra-chip.flash-deal{background:#fef3c7;border-color:#f59e0b;color:#92400e;animation:pulse-glow 2s ease-in-out infinite}.extra-chip.expiry{background:#fef9c3;border-color:#fde047;color:#854d0e}.extra-chip.expiry.urgent{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.extra-chip.stack-alert{background:#f0fdf4;border-color:#86efac;color:#166534}.extra-info-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;padding:4px 0;color:var(--text-secondary)}.extra-info-row span:first-child{flex-shrink:0}[data-theme=dark] .extra-chip{background:var(--bg-tertiary);border-color:var(--border)}[data-theme=dark] .extra-chip.wifi{background:#1e293b;border-color:#334155;color:#93c5fd}[data-theme=dark] .extra-chip.outlet{background:#1c1917;border-color:#44403c;color:#fcd34d}[data-theme=dark] .extra-chip.studying{background:#064e3b;border-color:#065f46;color:#6ee7b7}[data-theme=dark] .extra-chip.rsvp{background:#831843;border-color:#9d174d;color:#f9a8d4}[data-theme=dark] .extra-chip.flash-deal{background:#78350f;border-color:#92400e;color:#fcd34d}[data-theme=dark] .extra-chip.expiry{background:#422006;border-color:#854d0e;color:#fde047}[data-theme=dark] .extra-chip.expiry.urgent{background:#7f1d1d;border-color:#991b1b;color:#fca5a5}.group-rooms-section h4{font-size:13px;font-weight:600;margin:4px 0 8px}.group-room-card{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.group-room-info{display:flex;flex-direction:column;gap:2px}.group-room-info strong{font-size:13px}.group-room-info span{font-size:11px;color:var(--text-muted)}.special-collections h4{font-size:13px;font-weight:600;margin:4px 0 8px}.special-collection-card{padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.special-collection-card strong{font-size:13px;display:block}.special-collection-card .sc-floor{font-size:11px;color:var(--text-muted);margin-left:8px;background:var(--bg-secondary);padding:1px 6px;border-radius:4px}.special-collection-card p{font-size:12px;margin:4px 0 0;color:var(--text-secondary)}.class-schedule-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.class-card{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;font-size:12px}.class-card strong{font-weight:600}.class-instructor{color:var(--text-muted);font-style:italic}.drink-specials-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.drink-special-card{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;font-size:12px}.drink-special-card strong{min-width:70px;color:var(--primary);font-weight:600}.ticket-tiers-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.ticket-tiers-grid{display:flex;gap:8px;flex-wrap:wrap}.ticket-tier-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;background:var(--bg-primary);border:2px solid var(--border);border-radius:12px;font-size:12px;min-width:80px;text-align:center}.ticket-tier-card .tier-emoji{font-size:18px}.ticket-tier-card strong{font-size:12px}.ticket-tier-card .tier-price{font-size:11px;color:var(--text-muted)}.calendar-sync-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.calendar-btns{display:flex;gap:8px;flex-wrap:wrap}.calendar-btns .btn{font-size:12px;padding:6px 12px}.carpool-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.carpool-card{padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;font-size:12px}.carpool-card strong{display:block;font-size:13px;margin-bottom:2px}.carpool-form{display:flex;flex-direction:column;gap:8px;margin-top:8px}.carpool-form input{width:100%;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:12px;background:var(--bg-primary);color:var(--text-primary)}.event-reviews-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.event-review-card{padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.event-review-card .review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.event-review-card .review-header strong{font-size:13px}.event-review-card .review-header span{color:#f59e0b;font-size:13px}.event-review-card p{font-size:12px;margin:0;color:var(--text-secondary)}.event-review-form{display:flex;flex-direction:column;gap:8px;margin-top:8px;padding:10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px}.review-rating-row{display:flex;gap:4px}.review-star{background:none;border:none;font-size:22px;cursor:pointer;color:#d1d5db;padding:0;line-height:1}.review-star.active{color:#f59e0b}.event-review-form textarea{width:100%;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:12px;resize:none;background:var(--bg-secondary);color:var(--text-primary)}.amenities-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.amenities-grid{display:flex;flex-wrap:wrap;gap:6px}.amenity-chip{padding:4px 10px;border-radius:16px;font-size:12px;background:var(--bg-primary);border:1px solid var(--border)}.sublet-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.sublet-card{padding:10px 12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.sublet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.sublet-header strong{font-size:13px}.sublet-header span{font-size:11px;color:var(--text-muted)}.sublet-price{font-size:14px;font-weight:700;color:var(--primary);display:block;margin:4px 0}.sublet-card p{font-size:12px;margin:0;color:var(--text-secondary)}.sublet-form{display:flex;flex-direction:column;gap:8px;margin-top:8px}.sublet-form input,.sublet-form textarea{width:100%;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:12px;background:var(--bg-primary);color:var(--text-primary)}.sublet-form textarea{resize:none}.specialty-section h4,.insurance-section h4{font-size:13px;font-weight:600;margin:0 0 8px}.specialty-grid{display:flex;flex-wrap:wrap;gap:6px}.specialty-chip{padding:4px 10px;border-radius:16px;font-size:12px;background:#eff6ff;border:1px solid #BFDBFE;color:#1e40af}[data-theme=dark] .specialty-chip{background:#1e293b;border-color:#334155;color:#93c5fd}.insurance-list{display:flex;flex-wrap:wrap;gap:6px}.insurance-chip{padding:4px 10px;border-radius:16px;font-size:12px;background:#f0fdf4;border:1px solid #BBF7D0;color:#166534}[data-theme=dark] .insurance-chip{background:#064e3b;border-color:#065f46;color:#6ee7b7}.btn-active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}.btn-xs{padding:3px 8px;font-size:11px;border-radius:6px;cursor:pointer;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary)}.btn-xs:hover{background:var(--bg-secondary)}@keyframes pulse-glow{0%,to{box-shadow:0 0 #f59e0b00}50%{box-shadow:0 0 8px 2px #f59e0b4d}}.app-main>*{animation:pageSlideIn .3s ease-out}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.skeleton{background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 50%,var(--border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-circle{border-radius:50%}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text-sm{height:10px;width:60%;margin-bottom:6px}.skeleton-card{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);margin-bottom:8px}.btn{transition:transform .15s ease,box-shadow .15s ease,background .2s ease}.btn:active{transform:scale(.96)}.feed-pin-card{transition:transform .2s ease,box-shadow .2s ease}.feed-pin-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.feed-pin-card:active{transform:scale(.98)}.nav-link{transition:color .2s ease,transform .15s ease}.nav-link:hover{transform:translateY(-1px)}.collection-card{transition:transform .2s ease,box-shadow .2s ease}.collection-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.badge-card{transition:transform .2s ease,box-shadow .2s ease}.badge-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat-card.clickable{transition:transform .2s ease}.stat-card.clickable:hover{transform:scale(1.05)}.collection-creator-overlay,.collection-detail-overlay{animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.collection-creator,.collection-detail{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fab-btn{transition:background .2s ease,box-shadow .2s ease}.fab-btn:hover{background:var(--primary-dark);box-shadow:0 6px 20px #6c5ce766}.feed-tab{transition:color .2s ease,border-color .2s ease,background .2s ease}.profile-avatar{transition:transform .2s ease,box-shadow .2s ease}.profile-avatar:hover{transform:scale(1.05);box-shadow:0 4px 16px #6c5ce74d}.search-result-item{transition:background .15s ease,transform .15s ease}.search-result-item:hover{background:var(--border-light);transform:translate(4px)}.pin-popup{animation:popIn .2s ease-out}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
