*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow-x:hidden}:root{--bg-primary:#000;--bg-secondary:#111;--bg-tertiary:#1a1a1a;--text-primary:#fff;--text-secondary:#e5e5e5;--text-muted:#a3a3a3;--border-color:#333;--accent-blue:#3b82f6;--accent-blue-hover:#2563eb;--accent-green:#10b981;--accent-red:#ef4444;--accent-yellow:#f59e0b;--shadow:0 4px 6px -1px rgba(0,0,0,.5);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.6)}body.dark-theme{color:var(--text-primary);background:var(--bg-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}a{color:inherit;text-decoration:none}button{font-family:inherit}.text-center{text-align:center}.mt-4{margin-top:1rem}.mb-4,.message{margin-bottom:1rem}.message{padding:.75rem;border-radius:6px;font-size:.875rem}.message.success{background:rgba(16,185,129,.2);color:var(--accent-green);border:1px solid var(--accent-green)}.message.error{background:rgba(239,68,68,.2);color:var(--accent-red);border:1px solid var(--accent-red)}.form-error{color:var(--accent-red);font-size:.85rem}.form-success{color:#34d399;font-size:.85rem}.spacer{flex:1 1!important}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}@keyframes camera-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-container{min-height:100vh;background:var(--bg-primary);padding:20px 0 60px}.app-header{background:var(--bg-secondary);padding:1rem 0;border-bottom:1px solid var(--border-color);text-align:center;box-shadow:var(--shadow)}.app-header h1{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.app-header p{color:var(--text-secondary);font-size:1.125rem}.main-content{max-width:512px;margin:0 auto;padding:0 1rem}.content-grid{display:flex;flex-direction:column;gap:.75rem}.navigation{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.nav-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.nav-brand{font-size:1.5rem;font-weight:700;color:var(--text-primary);text-decoration:none}.nav-brand-button{background:none;border:none;cursor:pointer;transition:color .2s;font-family:inherit}.nav-brand-button:hover{color:var(--accent-blue)}.nav-links{display:flex;gap:1.5rem}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.nav-link:hover{color:var(--text-primary)}.nav-link.admin-link{color:var(--accent-yellow);font-weight:600}.nav-link.admin-link:hover{color:#fbbf24}.auth-status{position:fixed;top:20px;right:20px;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;z-index:1000;box-shadow:var(--shadow)}.auth-status.logged-in{background:rgba(16,185,129,.2);color:var(--accent-green);border:1px solid var(--accent-green)}.auth-status.logged-out{background:rgba(239,68,68,.2);color:var(--accent-red);border:1px solid var(--accent-red)}.impersonation-banner{background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:101}.impersonation-content{display:flex;align-items:center;gap:.5rem}.impersonation-icon{font-size:1.25rem}.impersonation-text{font-weight:500}.exit-impersonation-btn{background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.3);color:#fff;padding:.375rem .75rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.exit-impersonation-btn:hover{background:hsla(0,0%,100%,.3)}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;text-align:center;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-blue-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--border-color)}.btn-danger{background:var(--bg-tertiary);color:var(--accent-red);border:1px solid var(--accent-red)}.btn-danger:hover:not(:disabled){background:rgba(239,68,68,.1)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-small{padding:.375rem .75rem;font-size:.8rem}.form-group{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500}.form-input,.form-label{color:var(--text-primary)}.form-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;background:var(--bg-tertiary)}.form-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px rgba(59,130,246,.2)}.auth-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:2rem 1rem}.auth-card{background:var(--bg-secondary);padding:2rem;border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:400px;border:1px solid var(--border-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.25rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.25rem;border-top:1px solid var(--border-color)}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:1000}.image-modal-content,.image-modal-overlay{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.image-modal-content{position:relative}.image-modal-close{position:fixed;top:1rem;right:1rem;background:rgba(0,0,0,.7);color:#fff;border:none;width:3rem;height:3rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .2s;z-index:1001}.image-modal-close:hover{background:rgba(239,68,68,.8);transform:scale(1.1)}.image-modal-img{width:100vw;height:100vh;object-fit:contain;display:block;-webkit-user-select:none;-moz-user-select:none;user-select:none;will-change:transform}.camera-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:11000}.camera-modal{width:100%;max-width:420px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:16px;padding:1.25rem;box-shadow:var(--shadow-lg)}.camera-modal h4{margin:0 0 .35rem;text-align:center;color:var(--text-primary)}.camera-modal-actions{display:flex;flex-direction:column;gap:.75rem}.camera-option-btn{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:12px;padding:1.54rem;font-weight:700;font-size:1.05rem;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.camera-option-btn.primary{font-size:1.15rem}.camera-option-btn.cancel{font-size:.95rem;padding:.85rem;background:transparent}.camera-option-btn:hover:not(:disabled){border-color:var(--accent-blue);background:rgba(59,130,246,.12)}.camera-option-btn:disabled{opacity:.6;cursor:not-allowed}.camera-uploading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem .5rem}.camera-uploading p{margin:0;color:var(--text-primary);font-weight:600}.camera-spinner{width:48px;height:48px;border:4px solid hsla(0,0%,100%,.12);border-top:4px solid var(--accent-blue);border-radius:50%;animation:camera-spin .9s linear infinite}.badge{padding:.125rem .375rem;border-radius:3px;font-size:.7rem;font-weight:500;text-align:center;min-width:50px;line-height:1.2;background:var(--bg-tertiary);color:var(--text-secondary)}.badge-admin{background:var(--accent-red);color:#fff}.badge-on{background:#34d399;color:#064e3b;border:none}.empty-state,.loading-state{text-align:center;padding:3rem;color:var(--text-muted);font-style:italic}@media (max-width:768px){.auth-container{padding:1rem;min-height:100svh}.auth-card{padding:1.5rem;max-width:350px}.modal-content{margin:1rem;max-width:calc(100vw - 2rem)}}.empty-feed{padding:3rem 2rem;text-align:center;color:var(--text-muted)}.checkins-list{display:flex;flex-direction:column;gap:.75rem}.day-section{margin-bottom:2rem}.day-header{margin:1.25rem 0 .75rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:8px;border-left:4px solid var(--accent-yellow)}.day-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.day-checkins{display:flex;flex-direction:column;gap:.75rem}.checkin-item{padding:1.5rem 2rem;margin:.75rem 0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.checkin-header{margin-bottom:1rem}.emoji-time-info{display:flex;align-items:center;gap:1rem}.checkin-emoji{font-size:2.5rem;display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex-shrink:0}.clickable-emoji{cursor:pointer;border-radius:50%;transition:background-color .2s ease,transform .1s ease}.clickable-emoji:hover{background-color:hsla(0,0%,100%,.1);transform:scale(1.05)}.clickable-emoji:active{transform:scale(.95)}.time-location{flex:1 1;display:flex;align-items:center}.checkin-time{font-size:.875rem;color:var(--text-muted)}.checkin-content{margin-bottom:1rem}.checkin-message{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.message-text{font-size:1.125rem;font-weight:500;color:var(--text-primary)}.checkin-comment{margin-top:.75rem}.checkin-comment p{color:var(--text-secondary);font-style:italic;background:var(--bg-tertiary);padding:.75rem;border-radius:6px;border-left:3px solid var(--border-color)}.checkin-image{margin:1rem 0;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border-color)}.feed-image{width:100%;max-height:400px;object-fit:contain;display:block;cursor:pointer;transition:opacity .2s}.venue-info{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem;background:var(--bg-tertiary);border-radius:6px;font-size:.875rem}.venue-icon{font-size:1rem}.venue-name{color:var(--text-primary);font-weight:500}.venue-brand{color:var(--text-muted);font-size:.8rem}.location-link{color:inherit;text-decoration:none;cursor:pointer}.location-link:hover{text-decoration:underline}.touch-checkin{background:var(--bg-secondary);padding:1rem;border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);margin-bottom:0}.touch-checkin h3{margin-bottom:1.5rem;color:var(--text-primary);font-size:1.25rem;text-align:center}.icon-checkin{gap:1rem}.beer-hero,.icon-checkin{display:flex;flex-direction:column;align-items:center}.beer-hero{gap:.35rem;width:100%}.beer-hero-btn{width:150px;height:150px;background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:24px;font-size:3.4rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center}.beer-hero-btn:hover:not(:disabled){border-color:var(--accent-yellow);background:rgba(245,158,11,.08);transform:translateY(-2px)}.beer-hero-btn:disabled{opacity:.6;cursor:not-allowed}.icon-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.75rem;gap:.75rem;width:100%}.icon-btn{width:100%;background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:14px;padding:.95rem .75rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;cursor:pointer;font-weight:600;transition:all .2s ease}.icon-btn:hover:not(:disabled){border-color:var(--accent-green);background:rgba(16,185,129,.12);transform:translateY(-1px)}.icon-btn.camera:hover:not(:disabled){border-color:var(--accent-blue);background:rgba(59,130,246,.12)}.icon-btn:disabled{opacity:.6;cursor:not-allowed}.icon-emoji{font-size:2rem}.category-emoji{font-size:1.125rem}.category-name{font-weight:600;color:var(--text-primary)}.checkin-section{display:flex;flex-direction:column;gap:1.5rem}@media (max-width:640px){.beer-hero-btn{width:125px;height:125px;font-size:3rem}.icon-row{gap:.5rem}}@media (min-width:769px){.touch-checkin{position:-webkit-sticky;position:sticky;top:70px}}.profile-container{max-width:600px;margin:0 auto;padding:2rem 1rem}.profile-card{background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);overflow:hidden}.profile-header{padding:2rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:1.5rem}.profile-info h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:.25rem}.profile-username{color:var(--text-muted);font-size:.875rem;margin-bottom:.5rem}.admin-badge{background:rgba(245,158,11,.2);color:var(--accent-yellow);padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;border:1px solid var(--accent-yellow)}.profile-actions{display:flex;gap:.75rem;padding:1rem 2rem;border-bottom:1px solid var(--border-color)}.settings-section{padding:1.5rem 2rem}.settings-section h4{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.settings-status{background:rgba(59,130,246,.1);color:var(--accent-blue);padding:.5rem .75rem;border-radius:6px;font-size:.85rem;margin-bottom:1rem}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;gap:1rem}.setting-info{display:flex;flex-direction:column;gap:.125rem;min-width:0;flex:1 1}.setting-label{font-size:.95rem;font-weight:500;color:var(--text-primary)}.setting-desc{font-size:.8rem;color:var(--text-muted)}.toggle-btn{min-width:52px;padding:.4rem .75rem;border-radius:16px;font-size:.8rem;font-weight:600;border:none;cursor:pointer;transition:all .15s ease;flex-shrink:0}.toggle-btn.toggle-on{background:#34d399;color:#064e3b}.toggle-btn.toggle-off{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color)}.toggle-btn.toggle-disabled{opacity:.5;cursor:not-allowed}.toggle-btn:disabled{cursor:wait}.toggle-btn:hover:not(:disabled):not(.toggle-disabled){transform:scale(1.02)}.settings-group{margin-top:.75rem;margin-left:.75rem;padding-left:1rem;border-left:2px solid var(--border-color)}.settings-group .setting-row{padding:.5rem 0}.settings-group .setting-label{font-size:.9rem}.settings-group-disabled{opacity:.5}.settings-group-disabled .setting-desc,.settings-group-disabled .setting-label{color:var(--text-muted)}.settings-group-disabled .toggle-btn{cursor:not-allowed}.setting-row.nested{align-items:flex-start;gap:.75rem}.watchlist-pills{display:flex;flex-wrap:wrap;gap:.4rem;max-width:320px;justify-content:flex-end}.profile-card .setting-row.nested{padding-left:1.25rem}.profile-card .watchlist-pills.profile-watchlist{margin-left:auto;flex-direction:column;flex-wrap:nowrap;align-items:flex-end;justify-content:flex-start;gap:.5rem;width:max-content}.profile-card .watchlist-pills.profile-watchlist .multi-pill{width:100%;text-align:right}.profile-card .watchlist-pills.profile-watchlist .multi-pill.active{background:#34d399;color:#064e3b;border:none;box-shadow:0 8px 20px rgba(52,211,153,.35)}.password-form{padding:1rem 2rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.password-form input{padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.password-form input:focus{outline:none;border-color:var(--accent-blue)}@media (max-width:768px){.profile-header{text-align:center}.profile-actions,.profile-header{flex-direction:column}}.admin-overview{padding:1rem;max-width:1200px;margin:0 auto}.admin-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.admin-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;text-decoration:none;color:inherit;transition:all .3s ease;display:flex;flex-direction:column;gap:.5rem}.admin-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent-blue)}.admin-card h3{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.admin-card-action{font-size:.875rem;display:flex;align-items:center;gap:.5rem}.admin-card-action,.admin-nav-link{color:var(--accent-blue);font-weight:500}.admin-nav-link{text-decoration:none;padding:.5rem 1rem;border-radius:6px;background:var(--bg-secondary);border:1px solid var(--border-color);display:inline-block;transition:all .2s ease}.admin-nav-link:hover{background:var(--bg-tertiary);border-color:var(--accent-blue)}.user-controls{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-section{flex:1 1;min-width:250px}.search-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1rem;gap:1rem}.user-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:all .3s ease}.user-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent-blue)}.user-header{gap:.75rem}.user-avatar,.user-header{display:flex;align-items:center}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-blue);justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;flex-shrink:0}.user-info{flex:1 1}.user-info h3{font-size:1rem;font-weight:600;margin-bottom:.125rem;color:var(--text-primary);line-height:1.2}.user-username{color:var(--text-muted);font-size:.8rem;line-height:1.2}.user-badges{display:flex;flex-direction:column;gap:.125rem}.user-meta{margin-top:.75rem;color:var(--text-muted);font-size:.85rem}.user-actions{margin-top:1rem;display:flex;gap:.5rem}.admin-watchlist{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end;max-width:360px}.admin-watchlist.disabled{opacity:.6}.admin-watchlist .multi-pill.active{background:#34d399;color:#064e3b;border:none;box-shadow:0 8px 20px rgba(52,211,153,.35)}.admin-watchlist .multi-pill:disabled{cursor:not-allowed}@media (max-width:768px){.admin-overview{padding:1rem}.admin-cards{grid-template-columns:1fr;gap:1.5rem}.admin-card{padding:1.5rem}.users-grid{grid-template-columns:1fr}.user-controls{flex-direction:column}.search-section{min-width:auto}}.reaction-bar{flex-direction:row;margin-top:.75rem;position:relative}.reaction-bar,.reaction-display{display:flex;align-items:center;flex-wrap:wrap}.reaction-display{gap:.5rem}.reaction-add{display:flex;gap:.25rem;flex-wrap:wrap;position:relative;align-items:center}.reaction-display:not(:empty)+.reaction-add{margin-left:.5rem}.reaction-add-btn{background:none;border:1px solid transparent;border-radius:8px;padding:.25rem;font-size:1rem;cursor:pointer;transition:all .2s;opacity:.6;line-height:1}.reaction-add-btn:hover:not(:disabled){opacity:1;background:rgba(59,130,246,.1);border-color:var(--accent-blue);transform:scale(1.1)}.reaction-add-btn:disabled{opacity:.4;cursor:not-allowed}.reaction-delete-btn{background:none;border:1px solid transparent;border-radius:8px;padding:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s;opacity:.6;color:var(--text-muted)}.reaction-delete-btn:hover:not(:disabled){opacity:1;background:rgba(239,68,68,.1);border-color:var(--accent-red);color:var(--accent-red)}.reaction-delete-btn:disabled{opacity:.4;cursor:not-allowed}.reaction-edit-btn{background:none;border:1px solid transparent;border-radius:8px;padding:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s;opacity:.6;color:var(--text-muted)}.reaction-edit-btn:hover:not(:disabled){opacity:1;background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--accent-blue)}.reaction-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:.25rem .75rem;font-size:1.125rem;cursor:pointer;transition:all .2s;color:var(--text-secondary);display:flex;align-items:center;gap:.375rem;line-height:1;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.reaction-count{font-size:.875rem;font-weight:500}.reaction-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent-blue);transform:scale(1.05)}.reaction-btn.user-reacted{background:rgba(59,130,246,.15);border-color:var(--accent-blue);color:var(--accent-blue)}.reaction-btn.user-reacted:hover:not(:disabled){background:rgba(59,130,246,.25)}.reaction-btn.highlight-reaction{animation:highlightPulse .5s ease-out}.reaction-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes highlightPulse{0%{transform:scale(1)}50%{transform:scale(1.15);background:rgba(59,130,246,.3)}to{transform:scale(1)}}.react-toggle-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:.25rem .75rem;font-size:.875rem;cursor:pointer;transition:all .2s;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.react-toggle-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--text-primary)}.react-toggle-btn.expansion-open{background:rgba(59,130,246,.2);border-color:var(--accent-blue);color:var(--accent-blue)}.react-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.reaction-add-plus-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:.25rem .5rem;font-size:1rem;cursor:pointer;transition:all .2s;color:var(--text-secondary);line-height:1}.reaction-add-plus-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--text-primary)}.reaction-add-plus-btn.expansion-open{background:rgba(59,130,246,.2);border-color:var(--accent-blue);color:var(--accent-blue)}.reaction-add-plus-btn:disabled{opacity:.5;cursor:not-allowed}.reaction-emoji-row{display:flex;gap:.25rem;flex-wrap:wrap;margin-left:.5rem}.reaction-wrapper{position:relative}.reaction-tooltip{bottom:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem .75rem;box-shadow:var(--shadow-lg);z-index:1000;white-space:nowrap;margin-bottom:.5rem;max-width:200px;overflow:hidden;text-overflow:ellipsis}.reaction-tooltip,.tooltip-arrow{position:absolute;left:50%;transform:translateX(-50%)}.tooltip-arrow{top:100%;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--border-color)}.tooltip-arrow:after{content:"";position:absolute;top:-7px;left:-5px;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--bg-primary)}.tooltip-content{color:var(--text-primary);font-size:.8rem;font-weight:500}.emoji-expansion{position:absolute;bottom:50%;left:50%;width:320px;height:auto;margin-left:-160px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:1000;animation:slideUp .2s ease-out;transform-origin:center bottom}.emoji-expansion *,.emoji-expansion:focus-within,.emoji-expansion:hover{animation:none!important}.emoji-expansion.stable{animation:none!important}.emoji-expansion-header{display:flex;align-items:center;justify-content:flex-end;padding:.5rem;border-bottom:1px solid var(--border-color)}.emoji-close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.emoji-close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.emoji-grid-inline{padding:1rem;display:grid;grid-gap:.5rem;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(40px,1fr));max-width:100%}.emoji-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:.5rem;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;aspect-ratio:1}.emoji-btn:hover:not(:disabled){background:var(--accent-blue);border-color:var(--accent-blue);transform:scale(1.05)}.emoji-btn:disabled{opacity:.5;cursor:not-allowed}.emoji-btn.recent-emoji{border-color:var(--accent-blue)!important;background:rgba(59,130,246,.1)!important}.emoji-btn.recent-emoji:hover:not(:disabled){background:var(--accent-blue)!important;transform:scale(1.1)}.more-emojis-btn{font-size:1.5rem!important;color:var(--text-secondary)}.more-emojis-btn:hover{color:var(--text-primary)}.custom-emoji-btn{border:2px dashed var(--border-color)!important;background:var(--bg-secondary)!important;color:var(--text-muted)!important}.custom-emoji-btn:hover:not(:disabled){border-color:var(--accent-blue)!important;background:rgba(59,130,246,.1)!important;color:var(--accent-blue)!important}.custom-emoji-input-container{padding:1rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.custom-emoji-input-row{display:flex;gap:.5rem;align-items:center}.custom-emoji-input{flex:1 1;padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;outline:none}.custom-emoji-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px rgba(59,130,246,.2)}.custom-emoji-cancel-btn,.custom-emoji-submit-btn{padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;font-size:.9rem;min-width:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.custom-emoji-submit-btn:hover:not(:disabled){background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.custom-emoji-submit-btn:disabled{opacity:.5;cursor:not-allowed}.custom-emoji-cancel-btn:hover{background:rgba(239,68,68,.1);color:#ef4444;border-color:#ef4444}@media (min-width:400px){.emoji-grid-inline{grid-template-columns:repeat(6,1fr)}}@media (max-width:399px){.emoji-grid-inline{grid-template-columns:repeat(5,1fr)}}@media (max-width:320px){.emoji-grid-inline{grid-template-columns:repeat(4,1fr)}}.comments-section{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color);animation:slideDown .3s ease-out}.comments-header{margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.comments-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.comments-loading{padding:1rem;text-align:center;color:var(--text-muted);font-size:.875rem}.comments-list{margin-bottom:1rem}.no-comments{padding:1rem;text-align:center;color:var(--text-muted);font-size:.875rem;font-style:italic}.comment-item{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid hsla(0,0%,100%,.05)}.comment-item:last-child{margin-bottom:0;border-bottom:none;padding-bottom:0}.comment-header{gap:.75rem;margin-bottom:.5rem}.comment-header,.comment-meta{display:flex;align-items:center}.comment-meta{gap:.5rem;flex:1 1}.comment-author{font-weight:500;color:var(--text-primary);font-size:.875rem}.comment-time{font-size:.75rem;color:var(--text-muted)}.comment-delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;font-size:.875rem;opacity:.7;transition:all .2s}.comment-delete-btn:hover{opacity:1;background:rgba(239,68,68,.1);color:var(--accent-red)}.comment-content{color:var(--text-secondary);font-size:.875rem;line-height:1.4;word-wrap:break-word}.comment-content,.comment-image{margin-bottom:.5rem}.comment-image-preview{width:120px;height:68px;border-radius:4px;cursor:pointer;transition:opacity .2s;object-fit:cover;border:1px solid var(--border-color);display:block;margin:.5rem auto 0}.comment-image-preview:hover{opacity:.8}.comment-image-preview-container{margin-bottom:1rem;position:relative;display:inline-block;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border-color)}.comment-preview-img{max-width:120px;max-height:80px;object-fit:cover;display:block}.remove-preview-btn{position:absolute;top:.25rem;right:.25rem;background:rgba(0,0,0,.7);color:#fff;border:none;width:1.5rem;height:1.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;transition:all .2s}.remove-preview-btn:hover{background:rgba(239,68,68,.8)}.comment-form{padding-top:1rem;border-top:1px solid var(--border-color)}.comment-input-container{display:flex;gap:.25rem;align-items:stretch;width:100%}.comment-input{flex:1 1;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;resize:none;min-height:40px}.comment-input:focus{outline:none;border-color:var(--accent-blue)}.add-comment-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;padding:.375rem .625rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.5rem;float:right}.add-comment-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--accent-blue)}.add-comment-btn:disabled{opacity:.5;cursor:not-allowed}.comment-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:.25rem .75rem;font-size:.875rem;cursor:pointer;transition:all .2s;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.comment-btn:hover{background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--text-primary)}.comment-btn.active{background:rgba(59,130,246,.2);border-color:var(--accent-blue);color:var(--accent-blue)}.character-count{font-size:.75rem;color:var(--text-muted);text-align:right;margin-top:.25rem}.character-count-inline{font-size:.7rem;color:var(--text-muted);margin-left:.5rem;display:flex;align-items:center}.comment-image-btn,.comment-submit-btn{padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;font-size:1.1rem;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.comment-image-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--accent-blue);transform:scale(1.05)}.comment-submit-btn:hover:not(:disabled){background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);transform:scale(1.05)}.comment-image-btn:disabled,.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed}.compact-comments-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.compact-comments-list{margin-bottom:.75rem}.compact-comment-item{padding:.375rem 0;font-size:.875rem}.compact-comment-item:first-child{padding-top:0}.compact-comment-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.compact-comment-main{flex:1 1;min-width:0;line-height:1.4}.compact-comment-author{font-weight:500;color:var(--text-primary);font-size:.875rem;margin-right:.375rem}.compact-comment-text{color:var(--text-secondary);font-size:.875rem;word-wrap:break-word}.compact-comment-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.compact-comment-time{font-size:.75rem;color:var(--text-muted)}.compact-comment-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;line-height:1;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.compact-comment-item:hover .compact-comment-delete{opacity:.6}.compact-comment-delete:hover{opacity:1;background:rgba(239,68,68,.1);color:var(--accent-red)}@media (hover:none){.compact-comment-delete{opacity:.6}}.compact-comment-image{margin-top:.375rem;margin-left:0}.compact-comment-image-preview{width:80px;height:45px;border-radius:4px;cursor:pointer;transition:opacity .2s;object-fit:cover;border:1px solid var(--border-color)}.compact-comment-image-preview:hover{opacity:.8}.compact-comment-form{margin-top:.5rem}.compact-image-preview{position:relative;display:inline-block;margin-bottom:.5rem}.compact-image-preview img{max-width:80px;max-height:60px;border-radius:4px;object-fit:cover;border:1px solid var(--border-color)}.compact-image-preview .remove-preview{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-muted);font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.compact-image-preview .remove-preview:hover{background:rgba(239,68,68,.1);border-color:var(--accent-red);color:var(--accent-red)}.compact-comment-input-row{display:flex;gap:.375rem;align-items:center;width:100%}.compact-comment-input{flex:1 1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;height:36px}.compact-comment-input:focus{outline:none;border-color:var(--accent-blue)}.compact-comment-input::placeholder{color:var(--text-muted)}.compact-image-btn,.compact-submit-btn{padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:all .2s}.compact-image-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent-blue);color:var(--accent-blue)}.compact-submit-btn:hover:not(:disabled){background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.compact-image-btn:disabled,.compact-submit-btn:disabled{opacity:.4;cursor:not-allowed}.compact-image-btn svg,.compact-submit-btn svg{flex-shrink:0}.android-install-section{text-align:center;padding:1rem}.android-install-button{background:var(--accent-blue);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.android-install-button:hover{background:var(--accent-blue-hover);transform:translateY(-1px)}.ios-install-instructions{padding:1rem;background:var(--bg-tertiary);border-radius:8px;margin:1rem 0}.ios-install-step{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;padding:.5rem}.ios-install-step:last-child{margin-bottom:0}.step-number{background:var(--accent-blue);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.step-text{color:var(--text-secondary);font-size:.9rem;line-height:1.4}.push-banner{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(139,92,246,.1));border:1px solid rgba(59,130,246,.3);border-radius:12px;padding:1rem;margin:1rem 0}.push-banner-content{display:flex;flex-direction:column;gap:.75rem}.push-banner-text{color:var(--text-primary);font-size:.9rem}.push-banner-actions{display:flex;gap:.5rem}.push-enable-btn{background:var(--accent-blue);color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s}.push-enable-btn:hover{background:var(--accent-blue-hover)}.push-dismiss-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border-color);border-radius:6px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s}.push-dismiss-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.beer-calendar{gap:1rem;--day-header-height:70px;--hour-step:54px;--planner-body-height:calc(var(--hour-step) * 12);--planner-height:calc(var(--planner-body-height) + var(--day-header-height))}.beer-calendar,.beer-controls{display:flex;flex-direction:column}.beer-controls{gap:.75rem}.beer-filter-pills{display:flex;gap:.5rem;flex-wrap:wrap}.beer-pill{padding:.5rem .9rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .2s}.beer-pill:hover:not(:disabled){border-color:rgba(245,158,11,.65);color:#fcd34d}.beer-pill.active{background:linear-gradient(135deg,#f59e0b,#f97316);color:#0f172a;border:none;box-shadow:0 10px 30px rgba(245,158,11,.25)}.beer-pill:disabled{opacity:.5;cursor:not-allowed}.planner-controls{display:flex;flex-direction:column;gap:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;padding:.75rem;box-shadow:var(--shadow)}.control-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.control-row.stacked{align-items:flex-start;flex-direction:column}.location-multi{display:flex;flex-wrap:wrap;gap:.4rem}.location-swatch{width:10px;height:10px;border-radius:999px;display:inline-block;margin-right:.4rem;box-shadow:0 0 0 2px rgba(0,0,0,.2)}.multi-pill{padding:.35rem .8rem;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;font-weight:600;transition:all .2s ease}.multi-pill.active{background:linear-gradient(135deg,#22d3ee,#3b82f6);color:#0b1221;border:none;box-shadow:0 12px 30px rgba(59,130,246,.35)}.multi-pill.ghost{background:transparent;border-style:dashed;color:var(--text-muted)}.multi-pill:disabled{opacity:.5;cursor:not-allowed}.planner-stage{display:grid;grid-template-columns:auto 1fr;grid-gap:.75rem;gap:.75rem;align-items:stretch;margin-top:.25rem}.planner-actions{display:flex;justify-content:flex-end;margin:.5rem 0}.time-rail{position:relative;height:var(--planner-height);min-width:74px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow)}.time-rail-body{top:var(--day-header-height);height:var(--planner-body-height)}.time-mark,.time-rail-body{position:absolute;left:0;right:0}.time-mark{font-size:.9rem;color:var(--text-muted);padding-left:.75rem;transform:translateY(-35%);font-weight:700}.time-mark:after{content:"";position:absolute;left:.65rem;right:.65rem;top:50%;height:1px;background:hsla(0,0%,100%,.08)}.day-grid{position:relative;height:var(--planner-height);display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,1fr);overflow-x:auto;overflow-y:hidden;border:1px solid var(--border-color);border-radius:16px;background:var(--bg-secondary);box-shadow:var(--shadow-lg)}.day-grid.is-selecting{box-shadow:0 0 0 2px rgba(59,130,246,.45)}.day-grid::-webkit-scrollbar{height:16px}.day-grid::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.18);border-radius:999px}.day-column{position:relative;border-right:1px solid var(--border-color);overflow:hidden;height:var(--planner-height)}.day-column:last-child{border-right:none}.day-header{position:absolute;top:0;left:0;right:0;padding:.65rem .85rem;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(120deg,rgba(15,23,42,.9),rgba(59,130,246,.1));-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2}.day-name{font-weight:800;letter-spacing:.02em}.day-body{position:relative;margin-top:var(--day-header-height);height:var(--planner-body-height);background-image:repeating-linear-gradient(to bottom,hsla(0,0%,100%,.06) 0,hsla(0,0%,100%,.06) 1px,transparent 1px,transparent var(--hour-step))}.past-mask{top:0;background:rgba(15,23,42,.45);z-index:1}.now-line,.past-mask{position:absolute;left:0;right:0}.now-line{height:2px;background:linear-gradient(90deg,transparent,#22d3ee,transparent);z-index:3}.now-line span{position:absolute;right:8px;top:-10px;background:#0f172a;padding:.1rem .4rem;border-radius:8px;font-size:.75rem;color:#7dd3fc;border:1px solid rgba(34,211,238,.35)}.heatband{position:absolute;left:0;right:0;z-index:0;pointer-events:none}.heatband.level-0{background:transparent}.heatband.level-1{background:rgba(59,130,246,.08)}.heatband.level-2{background:rgba(59,130,246,.14)}.heatband.level-3{background:rgba(236,72,153,.18)}.selection-block{position:absolute;left:6px;right:6px;background:rgba(34,211,238,.24);border:1px dashed rgba(34,211,238,.7);border-radius:10px;box-shadow:inset 0 0 0 1px rgba(34,211,238,.35);z-index:6;display:flex;align-items:flex-start;padding:6px;pointer-events:none}.selection-label{background:rgba(14,165,233,.92);color:#0b1221;border:1px solid rgba(34,211,238,.6);border-radius:8px;padding:2px 9px;font-size:.8rem;font-weight:700;box-shadow:0 4px 16px rgba(14,165,233,.35)}.slot-cell{position:absolute;left:8px;right:8px;display:flex;align-items:center;z-index:5}.slot-cell-pills{display:flex;gap:.25rem;flex-wrap:wrap}.slot-pill{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:24px;padding:0 .4rem;border-radius:999px;font-weight:800;letter-spacing:.01em;color:#e2e8f0;border:1px solid transparent;background:hsla(0,0%,100%,.08);text-transform:uppercase;box-shadow:0 6px 12px rgba(0,0,0,.25)}.planner-footer{justify-content:space-between;gap:.75rem;margin-top:.5rem}.legend,.planner-footer{display:flex;align-items:center;flex-wrap:wrap}.legend{gap:.5rem;color:var(--text-muted);font-size:.9rem}.legend-dot{width:16px;height:8px;border-radius:999px;display:inline-block}.legend-dot.selection{background:rgba(34,211,238,.6)}.legend-dot.heat.low{background:rgba(59,130,246,.35)}.legend-dot.heat.mid{background:rgba(59,130,246,.5)}.legend-dot.heat.high{background:rgba(236,72,153,.55)}.cell-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);display:grid;place-items:center;z-index:40;padding:1rem}.cell-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow-lg);max-width:520px;width:min(520px,100%);max-height:72vh;overflow:hidden;display:flex;flex-direction:column}.cell-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem .9rem;border-bottom:1px solid var(--border-color)}.cell-modal-header h3{margin:0;font-size:1.1rem}.cell-modal-body{padding:.6rem .9rem .85rem;overflow-y:auto;display:flex;flex-direction:column;gap:.6rem}.cell-modal-empty{color:var(--text-muted);text-align:center}.cell-slot-card{border:1px solid var(--border-color);border-radius:10px;padding:.55rem .65rem;background:var(--bg-tertiary);display:flex;flex-direction:column;gap:.45rem}.cell-slot-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.cell-slot-time-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.cell-slot-time{font-weight:800;font-size:.98rem;line-height:1.3}.cell-slot-meta{display:flex;flex-direction:column;gap:.2rem;color:var(--text-secondary);font-size:.93rem}.cell-slot-user{font-weight:700}.cell-slot-location{background:rgba(59,130,246,.15);padding:.08rem .38rem;border-radius:10px;border:1px solid rgba(59,130,246,.4);font-size:.85rem}.cell-slot-note{color:var(--text-muted);font-size:.85rem;line-height:1.35}.beer-list{display:flex;flex-direction:column;gap:.75rem}.beer-placeholder{background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:12px;padding:1rem;text-align:center;color:var(--text-muted)}.beer-day{display:flex;flex-direction:column;gap:.5rem}.beer-day-heading{font-weight:700;letter-spacing:.03em;color:#fcd34d}.beer-slot-grid{display:flex;flex-direction:column;gap:.6rem}.beer-slot-card{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);padding:.75rem;box-shadow:var(--shadow);position:relative}.beer-slot-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:12px 0 0 12px;background:linear-gradient(180deg,var(--slot-accent,#f59e0b),var(--slot-accent,#f97316))}.beer-slot-meta{display:flex;align-items:center;gap:.75rem}.beer-avatar{width:42px;height:42px;border-radius:50%;position:relative;background:linear-gradient(135deg,rgba(245,158,11,.4),rgba(59,130,246,.4));border:1px solid hsla(0,0%,100%,.12);display:grid;place-items:center;font-weight:700;color:#0f172a;overflow:hidden;flex-shrink:0}.beer-avatar img{width:100%;height:100%;object-fit:cover}.beer-slot-text{flex:1 1;display:flex;flex-direction:column;gap:.2rem}.beer-slot-time{font-weight:800;font-size:1.05rem}.beer-slot-user{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.user-name{font-weight:700}.location-pill{background:rgba(59,130,246,.15);color:#bfdbfe;padding:.15rem .45rem;border-radius:999px;font-size:.85rem}.beer-slot-note{color:var(--text-muted);font-style:italic;font-size:.95rem}.day-grid{touch-action:pan-x}@media (max-width:640px){.beer-calendar{--hour-step:44px}.planner-controls{padding:.65rem}.control-row{width:100%}.day-grid{grid-auto-columns:minmax(180px,1fr)}}