*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f13;--bg2:#18181f;--bg3:#22222d;--border:#2e2e3a;--text:#f0f0f5;--text2:#99a;--primary:#a855f7;--primary-dark:#7c3aed;--primary-light:#d8b4fe;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--adult:#f97316;--rank-blue:#3b82f6;--rank-green:#22c55e;--rank-pink:#ec4899;--radius:12px;--radius-sm:8px;font-size:16px}html,body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,sans-serif}a{color:var(--primary-light);text-decoration:none}ul{list-style:none}input,button{font-family:inherit}*{scrollbar-width:none}::-webkit-scrollbar{display:none}.app{flex-direction:column;min-height:100vh;display:flex}.navbar{background:var(--bg2);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 1.25rem;display:flex;position:sticky;top:0}.nav-logo{color:var(--text);font-size:1.1rem;font-weight:700}.nav-links{align-items:center;gap:.75rem;display:flex}.nav-link{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.25rem .5rem;font-size:.9rem;transition:color .15s}.nav-link:hover{color:var(--text)}.nav-signout{color:var(--danger)}.main{flex:1;width:100%;max-width:640px;margin:0 auto;padding:1.5rem 1rem 4rem}.page{flex-direction:column;display:flex}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.6rem;font-weight:700}.page-subtitle,.venue-meta{color:var(--text2);margin-top:.25rem;font-size:.9rem}.back-btn{color:var(--primary-light);cursor:pointer;background:0 0;border:none;margin-bottom:1rem;padding:0;font-size:.9rem}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:1rem 1.25rem}.card-clickable{cursor:pointer;transition:border-color .15s,transform .1s}.card-clickable:hover{border-color:var(--primary);transform:translateY(-1px)}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.95rem;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:not(:disabled):hover{background:var(--primary-dark)}.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.btn-secondary:not(:disabled):hover{border-color:var(--primary)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{color:var(--text2);background:0 0}.btn-ghost:not(:disabled):hover{color:var(--text);background:var(--bg3)}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.btn-lg{border-radius:var(--radius);width:100%;padding:.85rem 2rem;font-size:1.05rem}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.badge{border-radius:20px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-default{background:var(--bg3);color:var(--text2)}.badge-success{color:var(--success);background:#22c55e26}.badge-warning{color:var(--warning);background:#f59e0b26}.badge-danger{color:var(--danger);background:#ef444426}.badge-adult{color:var(--adult);background:#f9731626}.modal-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=480px){.modal-overlay{align-items:center}}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;max-height:90vh;padding:1.25rem;overflow-y:auto}@media (width>=480px){.modal{border-radius:var(--radius)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.modal-title{font-size:1.1rem;font-weight:700}.modal-close{color:var(--text2);cursor:pointer;background:0 0;border:none;font-size:1.1rem}.modal-body{flex-direction:column;gap:.75rem;display:flex}.modal-actions{gap:.75rem;margin-top:.5rem;display:flex}.modal-actions .btn{flex:1}.search-bar{margin-bottom:1.25rem}.search-input,.input,.report-input{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);padding:.65rem 1rem;font-size:.95rem}.search-input:focus,.input:focus,.report-input:focus{border-color:var(--primary);outline:none}.loading-state{color:var(--text2);flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.empty-state{text-align:center;color:var(--text2);padding:3rem 1rem}.empty-state h3{color:var(--text);margin-bottom:.5rem}.age-gate-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.age-gate-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;padding:2rem 1.5rem}.age-gate-logo{text-align:center;margin-bottom:1.5rem}.logo-icon{margin-bottom:.5rem;font-size:3rem;display:block}.brand-logo{object-fit:contain;height:auto;display:block}.brand-logo-auth{width:min(300px,88%);margin:0 auto 1.5rem}.brand-logo-topbar{flex:none;width:42px}.brand-logo-setup{width:min(260px,100%);margin:0 auto .5rem}.logo-title{background:linear-gradient(135deg, var(--primary), var(--adult));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800}.age-gate-content{flex-direction:column;gap:1rem;display:flex}.age-gate-content h2{font-size:1.3rem}.age-gate-description{color:var(--text2);line-height:1.6}.age-gate-notice{border-radius:var(--radius-sm);background:#a855f71a;border:1px solid #a855f74d;padding:.75rem 1rem;font-size:.9rem;line-height:1.5}.age-gate-footer{text-align:center;color:var(--text2);font-size:.8rem}.auth-mode-switch{flex-wrap:wrap;gap:.5rem;display:flex}.auth-mode-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:999px;padding:.45rem .8rem;font-size:.82rem;font-weight:600;transition:border-color .15s,color .15s,background .15s}.auth-mode-chip:hover{border-color:var(--primary);color:var(--text)}.auth-mode-chip-active{border-color:var(--primary);color:var(--text);background:#a855f726}.auth-panel,.venue-list{flex-direction:column;gap:.75rem;display:flex}.venue-rank-card{margin-bottom:0}.venue-rank-shell{align-items:flex-start;gap:.9rem;display:flex}.venue-avatar-wrap{flex:none;position:relative}.venue-avatar{object-fit:cover;border:1px solid #ffffff14;border-radius:999px;width:64px;height:64px;display:block}.venue-avatar-fallback{color:#fff;letter-spacing:.04em;background:linear-gradient(135deg,#3b82f63d,#ec48993d);justify-content:center;align-items:center;font-weight:800;display:flex}.venue-rank-badge{background:var(--bg);border:1px solid var(--border);min-width:28px;height:28px;color:var(--text);border-radius:999px;justify-content:center;align-items:center;padding:0 .45rem;font-size:.75rem;font-weight:700;display:inline-flex;position:absolute;bottom:-4px;right:-4px}.venue-rank-body{flex:1;min-width:0}.venue-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.25rem;display:flex}.venue-name{font-size:1.05rem;font-weight:600}.venue-location{color:var(--text2);font-size:.85rem}.venue-score-row{justify-content:space-between;align-items:center;gap:.75rem;margin:.75rem 0 .6rem;display:flex}.venue-score-label{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.venue-score-value{font-size:.95rem;font-weight:700}.venue-progress-list{flex-direction:column;gap:.5rem;display:flex}.venue-progress-item{flex-direction:column;gap:.28rem;display:flex}.venue-progress-meta{color:var(--text2);justify-content:space-between;align-items:center;gap:.75rem;font-size:.82rem;display:flex}.venue-progress-meta strong{color:var(--text);font-size:.84rem}.venue-progress-track{background:var(--bg3);border-radius:999px;width:100%;height:8px;overflow:hidden}.venue-progress-fill{border-radius:inherit;height:100%;transition:width .25s}.stats-title{margin-bottom:.25rem;font-size:1.1rem;font-weight:700}.stats-total{color:var(--text2);margin-bottom:1rem;font-size:.9rem}.stats-list{flex-direction:column;gap:.5rem;display:flex}.stats-item{background:var(--bg3);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.stats-item-adult{border-left:2px solid var(--adult)}.stats-emoji{text-align:center;width:28px;font-size:1.2rem}.stats-label{flex:1;font-size:.95rem}.stats-count{color:var(--primary-light);font-size:1rem;font-weight:700}.stats-hidden{color:var(--text2);font-size:.85rem;font-weight:400}.stats-threshold-notice{color:var(--text2);text-align:center;margin-top:.75rem;font-size:.8rem}.stats-empty-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);text-align:center;color:var(--text2);margin-bottom:.75rem;padding:2rem}.intent-section{margin:1rem 0}.my-intent-card{background:var(--bg2);border:1px solid var(--primary);border-radius:var(--radius);padding:1rem 1.25rem}.my-intent-card h3{margin-bottom:.5rem;font-size:1rem}.my-intent-list{color:var(--text2);flex-direction:column;gap:.25rem;margin-bottom:.75rem;font-size:.9rem;display:flex}.my-intent-actions{gap:.5rem;display:flex}.intent-modal-hint{color:var(--text2);font-size:.85rem}.intent-list{flex-direction:column;gap:.5rem;display:flex}.intent-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:border-color .15s;display:flex}.intent-item:hover{border-color:var(--primary)}.intent-selected{border-color:var(--primary);background:#a855f71a}.intent-adult{border-left:2px solid var(--adult)}.intent-emoji{text-align:center;width:28px;font-size:1.2rem}.intent-label{flex:1}.intent-check{color:var(--primary);font-weight:700}.adult-notice{border-radius:var(--radius-sm);color:var(--adult);background:#f973161a;border:1px solid #f973164d;padding:.6rem .9rem;font-size:.85rem}.consent-checkbox{cursor:pointer;align-items:flex-start;gap:.5rem;font-size:.85rem;line-height:1.4;display:flex}.consent-checkbox input{accent-color:var(--primary);margin-top:2px}.consent-notice{border-radius:var(--radius-sm);color:var(--text2);background:#a855f712;border:1px solid #a855f733;margin:.75rem 0;padding:.75rem 1rem;font-size:.85rem;line-height:1.5}.consent-age{color:var(--primary-light);margin-top:.25rem;font-weight:600}.report-section{border-top:1px solid var(--border);margin-top:2rem;padding-top:1.5rem}.report-section h4{color:var(--text2);margin-bottom:.75rem;font-size:.95rem}.report-input{margin-bottom:.5rem}.report-sent{color:var(--success)}.venue-closed-notice{border-radius:var(--radius-sm);color:var(--danger);background:#ef44441a;border:1px solid #ef44444d;margin-top:.5rem;padding:.5rem .9rem;font-size:.85rem;display:inline-block}.admin-page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.admin-page-header h1{margin:0;font-size:1.6rem;font-weight:700}.admin-header-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.admin-profile-trigger{border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;border-radius:14px;align-items:center;gap:.65rem;min-width:0;padding:.45rem .7rem;display:inline-flex}.admin-profile-trigger:hover{border-color:var(--primary)}.admin-profile-avatar{object-fit:cover;border-radius:999px;width:36px;height:36px}.admin-profile-copy{text-align:left;flex-direction:column;min-width:0;display:flex}.admin-profile-copy strong{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;overflow:hidden}.admin-profile-copy span{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:.76rem;overflow:hidden}.admin-profile-panel{flex-direction:column;gap:.9rem;display:flex}.admin-profile-hero{align-items:center;gap:1rem;display:flex}.admin-profile-photo-lg{object-fit:cover;border:1px solid var(--border);border-radius:999px;width:72px;height:72px}.admin-profile-photo-fallback{color:var(--text);background:linear-gradient(135deg,#3b82f638,#ec489938);justify-content:center;align-items:center;font-size:1.6rem;font-weight:800;display:flex}.admin-upload-btn{width:auto}.venue-admin-card .venue-card-header{flex-wrap:wrap}.venue-admin-actions{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.venue-settings-hint{color:var(--text2);margin-top:.5rem;font-size:.75rem}.reports-section{margin-top:2rem}.reports-section h2{margin-bottom:1rem}.reports-list{flex-direction:column;gap:.75rem;display:flex}.report-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.9rem 1rem}.report-header{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.report-venue{color:var(--text2);font-size:.8rem}.report-meta{color:var(--text2);margin-top:.4rem;font-size:.75rem}.no-reports{color:var(--text2)}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-group label{color:var(--text2);font-size:.85rem}.form-group-check{flex-direction:row;align-items:center;gap:.5rem}.form-group-check label{color:var(--text);cursor:pointer;align-items:center;gap:.5rem;display:flex}.error-text{color:var(--danger);font-size:.85rem}.topbar{background:var(--bg2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:52px;padding:0 1rem;display:flex}.topbar-logo{color:var(--text);align-items:center;gap:.65rem;font-size:1rem;font-weight:700;display:inline-flex}.topbar-actions{gap:.5rem;display:flex}.topbar-signout,.topbar-signin{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.25rem .5rem;font-size:.85rem}.topbar-signin:hover{color:var(--text)}.main-fullscreen{padding:0}.bottom-nav{background:var(--bg2);border-top:1px solid var(--border);z-index:100;align-items:stretch;height:60px;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--text2);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:.7rem;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item:hover,.bottom-nav-active{color:var(--primary-light)}.bottom-nav-icon{font-size:1.15rem;line-height:1}.bottom-nav-label{font-size:.65rem}.bottom-nav-scan{color:var(--primary)}.bottom-nav-scan-icon{font-size:1.4rem}.app:has(.bottom-nav) .main{padding-bottom:80px}.logo-tagline{color:var(--text2);margin-top:.25rem;font-size:.85rem}.auth-divider{color:var(--text2);align-items:center;gap:.75rem;margin:.25rem 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-back-link{color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:none;margin-top:.25rem;font-size:.85rem}.auth-back-link:hover{color:var(--text)}.btn-google{color:#1f1f1f;background:#fff}.btn-google:hover:not(:disabled){background:#f5f5f5}.auth-mode-switch{flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem;display:flex}.auth-mode-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:20px;padding:.35rem .75rem;font-size:.8rem}.auth-mode-chip-active{border-color:var(--primary);color:var(--primary-light)}.filter-chips{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.filter-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.3rem .8rem;font-size:.8rem}.filter-chip-active{border-color:var(--primary);color:var(--primary-light);background:#a855f71a}.checkin-hint{color:var(--text2);text-align:center;background:var(--bg3);border-radius:var(--radius-sm);margin-top:.75rem;padding:.75rem;font-size:.85rem}.placeholder-notice{color:var(--text2);text-align:center;background:var(--bg2);border:1px dashed var(--border);border-radius:var(--radius);padding:2rem}.setup-page{justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.setup-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:1.25rem;width:100%;max-width:520px;padding:2rem;display:flex}.setup-eyebrow{color:var(--warning);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.setup-description{color:var(--text2);font-size:.9rem;line-height:1.6}.setup-block{flex-direction:column;gap:.5rem;display:flex}.setup-block h2{font-size:.95rem}.setup-list{color:var(--text2);flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}.setup-list code{background:var(--bg3);color:var(--primary-light);border-radius:4px;padding:.1rem .4rem;font-size:.85rem}.setup-list-numbered{padding-left:1.2rem;list-style:decimal}.mood-form{flex-direction:column;gap:1.25rem;display:flex}.mood-section{flex-direction:column;gap:.6rem;display:flex}.mood-section-title{color:var(--text2);text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;font-weight:600}.mood-chip-row{flex-wrap:wrap;gap:.5rem;display:flex}.mood-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:20px;padding:.4rem .9rem;font-size:.85rem}.mood-chip:hover{border-color:var(--primary)}.mood-chip-active{border-color:var(--primary);color:var(--primary-light);background:#a855f71a}.mood-intent-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.mood-intent-btn{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;font-size:.8rem;transition:border-color .15s;display:flex;position:relative}.mood-intent-btn:hover{border-color:var(--primary)}.mood-intent-btn span:first-child{font-size:1.4rem}.mood-intent-active{border-color:var(--primary);color:var(--text);background:#a855f71a}.mood-check{color:var(--primary);font-size:.85rem;font-weight:700;position:absolute;top:6px;right:8px}.mood-consent{color:var(--text2);text-align:center;font-size:.78rem;line-height:1.5}.my-mood-card{flex-direction:column;gap:.6rem;display:flex}.clear-mood-btn{align-self:center}.checkin-gate{background:var(--bg2);border:1px dashed var(--border);border-radius:var(--radius);text-align:center;padding:1.5rem}.consent-notice-inline{color:var(--text2);text-align:center;padding:.5rem 0;font-size:.78rem}.qr-page{align-items:center}.qr-container{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:.75rem;width:fit-content;margin:0 auto;padding:1rem;display:flex;position:relative}.qr-canvas{border-radius:var(--radius-sm);display:block}.qr-canvas-loading{opacity:.4}.qr-overlay{border-radius:var(--radius);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.qr-expiry{color:var(--text2);font-size:.85rem}.qr-expiry-warn{color:var(--warning)}.qr-expiry-urgent{color:var(--danger);font-weight:700}.qr-error{flex-direction:column;align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.qr-instructions{color:var(--text2);text-align:center;margin-top:.75rem;font-size:.82rem;line-height:1.7}.owner-mode-switch{flex-wrap:wrap;gap:.5rem;margin:0 0 1rem;display:flex}.setup-page{background:radial-gradient(circle at top, #1f2937 0%, var(--bg) 55%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.setup-card{border:1px solid var(--border);background:#18181ff5;border-radius:24px;width:100%;max-width:760px;padding:2rem;box-shadow:0 24px 80px #00000059}.setup-eyebrow{color:#f4b740;text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem;font-size:.78rem}.setup-card h1{margin-bottom:.75rem;font-size:2rem}.setup-description{color:var(--text2);max-width:60ch;margin-bottom:1.5rem;line-height:1.65}.setup-block+.setup-block{margin-top:1.25rem}.setup-block h2{margin-bottom:.75rem;font-size:1rem}.setup-list{color:var(--text2);flex-direction:column;gap:.5rem;padding-left:1rem;display:flex}.setup-list li{line-height:1.5}.setup-list code{background:var(--bg3);border:1px solid var(--border);color:var(--primary-light);border-radius:999px;padding:.18rem .5rem}.setup-list-numbered{list-style:decimal}.app-shell{flex-direction:column;min-height:100dvh;display:flex}.app-main{flex:1;width:100%;max-width:680px;margin:0 auto;padding:1.25rem 1rem 1.5rem}.app-main-auth{max-width:100%;padding:0}.app-main-with-nav{padding-bottom:100px}.topbar{background:var(--bg2);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:1rem;height:56px;padding:0 1.5rem;display:none;position:sticky;top:0}@media (width>=768px){.topbar{display:flex}}.topbar-logo{color:var(--text);white-space:nowrap;align-items:center;gap:.65rem;font-size:1rem;font-weight:700;display:inline-flex}.topbar-nav{flex:1;gap:.25rem;display:flex}.topbar-link{color:var(--text2);border-radius:8px;padding:.3rem .75rem;font-size:.875rem;transition:color .15s,background .15s}.topbar-link:hover{color:var(--text);background:var(--bg3)}.topbar-link-active{color:var(--primary-light)}.topbar-actions{align-items:center;gap:.5rem;margin-left:auto;display:flex}.topbar-signout{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.3rem .6rem;font-size:.875rem;transition:color .15s;display:flex}.topbar-signout:hover{color:var(--danger)}.topbar-signin{color:var(--text2);border-radius:8px;padding:.3rem .6rem;font-size:.875rem}.topbar-profile-link{min-width:0;max-width:190px;color:var(--text2);border:1px solid #0000;border-radius:999px;align-items:center;gap:.5rem;padding:.25rem .45rem;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.topbar-profile-link:hover,.topbar-profile-link-active{color:var(--text);border-color:var(--border);background:var(--bg3)}.topbar-profile-link span{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.875rem;overflow:hidden}.topbar-profile-avatar{object-fit:cover;border:1px solid var(--border);border-radius:999px;flex:none;width:28px;height:28px}.profile-page{gap:1rem}.profile-page-header{margin-bottom:.25rem}.profile-identity{align-items:center;gap:1rem;min-width:0;display:flex}.profile-photo-wrap{flex:none;position:relative}.profile-photo{object-fit:cover;border:1px solid var(--border);background:var(--bg2);border-radius:999px;width:88px;height:88px}.profile-photo-fallback{color:var(--text2);background:linear-gradient(135deg,#3b82f633,#ec48992e);justify-content:center;align-items:center;display:flex}.profile-photo-action{color:#fff;background:var(--primary);border:2px solid var(--bg);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;width:34px;height:34px;display:flex;position:absolute;bottom:-2px;right:-2px;box-shadow:0 8px 20px #00000059}.profile-photo-action:hover{background:var(--primary-dark)}.profile-role-row{flex-wrap:wrap;gap:.35rem;margin-top:.55rem;display:flex}.profile-role{color:var(--primary-light);background:#a855f71f;border:1px solid #a855f73d;border-radius:999px;padding:.18rem .55rem;font-size:.72rem;font-weight:700}.profile-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.85rem;padding:1rem 1.1rem;display:flex}.profile-section-title{color:var(--text);align-items:center;gap:.55rem;display:flex}.profile-section-title h2{font-size:1rem;line-height:1.2}.profile-hint{color:var(--text2);font-size:.84rem;line-height:1.5}.profile-security-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.profile-security-row strong{margin-bottom:.2rem;font-size:.95rem;display:block}.profile-security-row p{color:var(--text2);font-size:.84rem;line-height:1.45}.profile-danger-zone{background:0 0;border-style:dashed}.profile-message{border-radius:var(--radius-sm);padding:.75rem .95rem;font-size:.88rem;line-height:1.45}.profile-message-error{color:#fecaca;background:#ef44441f;border:1px solid #ef444447}.profile-saved-inline{min-height:20px;color:var(--success);justify-content:center;align-items:center;gap:.4rem;font-size:.84rem;display:flex}@media (width<=440px){.profile-photo{width:76px;height:76px}.profile-security-row{flex-direction:column;align-items:stretch}}.mobile-nav{padding-bottom:max(env(safe-area-inset-bottom), .75rem);z-index:100;pointer-events:none;justify-content:center;padding-top:.5rem;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width>=768px){.mobile-nav{display:none}}.mobile-nav-pill{pointer-events:auto;-webkit-backdrop-filter:blur(20px)saturate(1.4);background:#18181fe0;border:1px solid #ffffff1a;border-radius:2.5rem;align-items:center;gap:.25rem;padding:.4rem .5rem;display:flex;box-shadow:0 16px 40px #00000080,0 2px 8px #0000004d}.mnav-item{color:#ffffff73;cursor:pointer;background:0 0;border:none;border-radius:1.25rem;justify-content:center;align-items:center;width:44px;height:44px;transition:color .15s,background .15s;display:flex}.mnav-item:hover{color:#fffc;background:#ffffff12}.mnav-active{color:var(--primary-light);background:#a855f726}.mnav-center{background:linear-gradient(160deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;border-radius:1.4rem;justify-content:center;align-items:center;width:48px;height:48px;margin:0 .15rem;transition:opacity .15s,transform .1s;display:flex;box-shadow:0 8px 20px #a855f766}.mnav-center:hover{opacity:.9}.mnav-center:active{transform:scale(.95)}
