*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
/* Brand – Strava orange */
--brand:#D80865;
--brand-light:#FF6A33;
--brand-dark:#D63E00;
--brand-hover:#E04400;
--brand-glow:rgba(216,8,101,0.15);
--accent:#3A86FF;
--accent2:#06b6d4;
--gold:#F59E0B;
/* Surfaces */
--bg-page:#EDEDED;
--bg-nav:#FFFFFF;
--bg-card:#FFFFFF;
--bg-card-hover:#FAFAFA;
--bg-input:#EDEDED;
--bg-subtle:rgba(0,0,0,0.03);
--surface-1:rgba(0,0,0,0.04);
--surface-2:rgba(0,0,0,0.07);
/* Borders */
--border:#E8E8E8;
--border-med:#D1D1D6;
--border-hover:rgba(216,8,101,0.4);
--border-focus:rgba(216,8,101,0.6);
/* Text */
--text-pri:#141414;
--text-sec:#6D6D78;
--text-mute:#AEAEB2;
--text-inv:#FFFFFF;
/* Status */
--online:#22c55e;
--online-ring:rgba(34,197,94,0.18);
--red:#ef4444;
/* Shadows */
--shadow-xs:0 1px 3px rgba(0,0,0,0.06);
--shadow-sm:0 2px 8px rgba(0,0,0,0.07);
--shadow-md:0 4px 16px rgba(0,0,0,0.09);
--shadow-lg:0 8px 32px rgba(0,0,0,0.11);
--shadow-brand:0 4px 16px rgba(216,8,101,0.28);
/* Radii */
--radius:8px;
--radius-sm:6px;
--radius-xs:4px;
--radius-pill:999px;
/* Motion */
--ease:cubic-bezier(0.4,0,0.2,1);
--dur:0.18s;
--transition:0.18s cubic-bezier(0.4,0,0.2,1);
/* Layout */
--nav-h:60px;
/* Glass (light equiv) */
--glass:rgba(255,255,255,0.9);
--glass-border:#E8E8E8
}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#D1D1D6;border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:#AEAEB2}

/* ── Base ── */
html{scroll-behavior:smooth}
body{
font-family:'Inter',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;
background:var(--bg-page);
color:var(--text-pri);
min-height:100vh;
overflow-x:hidden;
-webkit-font-smoothing:antialiased;
-moz-osx-font-smoothing:grayscale;
letter-spacing:-0.01em;
}

/* ── Typography ── */
h1,h2,h3,h4{font-weight:700;line-height:1.2;letter-spacing:-0.02em;color:var(--text-pri)}
a{color:var(--brand);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--brand-dark)}
p{line-height:1.65;color:var(--text-sec)}

/* ══════════════════════════════════
   NAV
══════════════════════════════════ */
.navbar{
position:sticky;top:0;z-index:100;
background:var(--bg-nav);
border-bottom:1px solid var(--border)
}
.nav-inner{
max-width:1240px;margin:0 auto;padding:0 28px;
height:var(--nav-h);display:flex;align-items:center;gap:20px
}
.nav-brand{
display:flex;align-items:center;
flex-shrink:0
}
.nav-logo{height:34px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:0;flex:1;justify-content:center}
.nav-link{
display:flex;align-items:center;gap:6px;
padding:8px 14px;
color:var(--text-sec);font-size:0.855rem;font-weight:500;
transition:all var(--transition);position:relative;
border-bottom:3px solid transparent;margin-bottom:-1px;
background:transparent;border-top:none;border-left:none;border-right:none;
cursor:pointer;font-family:inherit
}
.nav-link:hover{color:var(--text-pri)}
.nav-link.active{
color:var(--text-pri);
font-weight:600;
border-bottom-color:var(--brand)
}
.nav-link.active::after{display:none}
.nav-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}

/* ── Theme toggle (hidden – light only) ── */
.theme-toggle{display:none}

/* ── Badges ── */
.badge{
background:var(--brand);
color:#fff;font-size:0.6rem;font-weight:700;
padding:1px 6px;border-radius:99px;min-width:18px;
text-align:center;display:inline-block;
letter-spacing:0.01em
}
.badge.red{background:var(--red)}
.badge.gold{background:var(--gold);color:#000}

/* ── Icon buttons ── */
.icon-btn{
min-width:36px;height:36px;
background:transparent;
border:1px solid var(--border);
border-radius:var(--radius-pill);
display:inline-flex;align-items:center;justify-content:center;gap:5px;
padding:0 10px;
cursor:pointer;color:var(--text-sec);
transition:all var(--transition);position:relative;
white-space:nowrap;text-decoration:none
}
/* icon-btn with no badge → stays a tight circle */
.icon-btn:not(:has(.badge)){
width:36px;padding:0
}
.icon-btn svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}
.icon-btn:hover{
background:var(--surface-1);
color:var(--text-pri);
border-color:var(--border-med)
}
/* badge inside icon-btn flows inline next to icon */
.icon-btn .badge{
position:static;
font-size:0.65rem;font-weight:700;
padding:1px 5px;min-width:16px;
border-radius:99px;line-height:1.4
}

/* ── Avatar btn ── */
.avatar-btn{
display:inline-flex;align-items:center;
position:relative;border-radius:50%;
padding:2px;
background:var(--brand);
transition:box-shadow var(--transition)
}
.avatar-btn:hover{box-shadow:0 0 0 3px rgba(216,8,101,0.2)}
.avatar-btn .avatar-img{outline:none;box-shadow:none}
.avatar-img{
width:34px;height:34px;border-radius:50%;
object-fit:cover;
transition:all var(--transition)
}
.online-dot{
position:absolute;bottom:1px;right:1px;
width:9px;height:9px;
background:var(--online);border-radius:50%;
border:2px solid var(--bg-page)
}

/* ── Profile dropdown (appears under the nav avatar) ── */
.profile-menu{
position:absolute;top:calc(100% + 10px);right:0;
min-width:200px;
background:var(--bg-card);
border:1px solid var(--border);
border-radius:12px;
box-shadow:0 12px 32px rgba(0,0,0,0.14);
padding:6px;
z-index:1100;
opacity:0;visibility:hidden;
transform:translateY(-6px) scale(0.98);
transform-origin:top right;
transition:opacity 0.15s, transform 0.15s, visibility 0s linear 0.15s
}
.profile-menu.open{
opacity:1;visibility:visible;
transform:translateY(0) scale(1);
transition:opacity 0.15s, transform 0.15s, visibility 0s
}
.profile-menu a{
display:flex;align-items:center;gap:11px;
padding:9px 13px;
border-radius:8px;
font-size:0.875rem;font-weight:500;
font-family:'Inter',sans-serif;
color:var(--text-pri);
text-decoration:none;
transition:background 0.12s, color 0.12s
}
.profile-menu a:hover{background:var(--bg-input)}
.profile-menu a svg{
width:16px;height:16px;
stroke:currentColor;stroke-width:1.9;
fill:none;flex-shrink:0;opacity:0.7
}
.profile-menu a.danger{color:#ef4444}
.profile-menu a.danger:hover{background:rgba(239,68,68,0.06)}
.profile-menu a.danger svg{opacity:0.9}
.profile-menu-divider{
height:1px;background:var(--border);
margin:5px 8px
}

/* ── Logged-out nav CTA (Login + Join Free) ── */
.nav-auth-cta{
display:inline-flex;align-items:center;gap:10px
}
.nav-auth-prompt{
font-size:0.82rem;color:var(--text-sec);
margin-right:2px;white-space:nowrap
}
.nav-auth-btn{
display:inline-flex;align-items:center;
padding:8px 18px;border-radius:999px;
font-size:0.85rem;font-weight:600;
font-family:'Inter',sans-serif;
text-decoration:none;white-space:nowrap;
transition:all var(--transition);cursor:pointer
}
.nav-auth-btn-ghost{
background:transparent;color:var(--text-pri);
border:1.5px solid var(--border-med)
}
.nav-auth-btn-ghost:hover{
border-color:var(--brand);color:var(--brand);
background:rgba(216,8,101,0.04)
}
.nav-auth-btn-primary{
background:var(--brand);color:#fff;border:1.5px solid var(--brand)
}
.nav-auth-btn-primary:hover{
background:var(--brand-hover);border-color:var(--brand-hover);
transform:translateY(-1px);
box-shadow:0 4px 14px rgba(216,8,101,0.28)
}
@media(max-width:600px){
.nav-auth-prompt{display:none}
.nav-auth-btn{padding:7px 14px;font-size:0.8rem}
}

/* ── Logged-out: blur gallery images and cover photos only — NOT profile avatars/icons ── */
body.logged-out .gallery-img,
body.logged-out .member-card-img,
body.logged-out .post-image,
body.logged-out .mp-photo-item img,
body.logged-out .preview-cover img,
body.logged-out #profile-cover-img,
body.logged-out .nm-card-img,
body.logged-out .party-img,
body.logged-out .match-card-img,
body.logged-out .match-img{
filter:blur(18px) saturate(0.7);
-webkit-filter:blur(18px) saturate(0.7);
transform:scale(1.06);
transition:filter var(--transition);
pointer-events:none;
user-select:none
}
/* Never blur brand assets or theme icons
   Note: .footer-logo intentionally OMITTED here — it has its own
   filter:brightness(0) invert(1) to render white on the pink footer,
   and "filter:none !important" would clobber that. The footer logo is
   not in the blur selector list above, so it doesn't need a reset. */
body.logged-out .nav-logo,
body.logged-out [data-no-blur],
body.logged-out .nav-link svg,
body.logged-out .nav-link i,
body.logged-out .icon-btn svg,
body.logged-out .icon-btn i{
filter:none !important;
-webkit-filter:none !important;
transform:none !important;
pointer-events:auto !important
}
body.logged-out .gallery-item,
body.logged-out .member-card,
body.logged-out .nm-card,
body.logged-out .party-card,
body.logged-out .match-card{
cursor:pointer
}

/* ── Signup gate modal ── */
.sg-overlay{
position:fixed;inset:0;z-index:10500;
background:rgba(0,0,0,0.62);
display:none;
align-items:center;justify-content:center;
padding:20px;
backdrop-filter:blur(4px)
}
.sg-overlay.active{display:flex}
.sg-card{
background:var(--bg-card);
border-radius:18px;
width:100%;max-width:460px;
padding:36px 32px 30px;
position:relative;
box-shadow:0 20px 60px rgba(0,0,0,0.3);
animation:sg-in 0.2s ease-out;
text-align:center
}
@keyframes sg-in{from{opacity:0;transform:translateY(12px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.sg-close{
position:absolute;top:14px;right:14px;
width:32px;height:32px;border-radius:50%;
background:transparent;border:none;cursor:pointer;
display:flex;align-items:center;justify-content:center;
color:var(--text-mute);transition:background 0.15s,color 0.15s
}
.sg-close:hover{background:var(--bg-input);color:var(--text-pri)}
.sg-icon{
width:64px;height:64px;
margin:0 auto 16px;
border-radius:50%;
background:rgba(216,8,101,0.1);
color:var(--brand);
display:flex;align-items:center;justify-content:center
}
.sg-card h2{
font-size:1.35rem;font-weight:800;
color:var(--text-pri);
letter-spacing:-0.02em;
margin:0 0 8px
}
.sg-card .sg-sub{
font-size:0.92rem;color:var(--text-sec);
line-height:1.55;margin:0 0 22px
}
.sg-features{
list-style:none;padding:0;margin:0 0 26px;
text-align:left;
display:flex;flex-direction:column;gap:9px
}
.sg-features li{
font-size:0.875rem;color:var(--text-pri);
display:flex;align-items:center;gap:10px
}
.sg-features li svg{
width:16px;height:16px;color:#22c55e;flex-shrink:0
}
.sg-actions{display:flex;flex-direction:column;gap:9px}
.sg-actions a{
display:inline-flex;align-items:center;justify-content:center;
padding:12px 24px;border-radius:999px;
font-size:0.92rem;font-weight:600;
font-family:'Inter',sans-serif;
text-decoration:none;transition:all 0.15s
}
.sg-join{
background:var(--brand);color:#fff;
border:1.5px solid var(--brand)
}
.sg-join:hover{
background:var(--brand-hover);border-color:var(--brand-hover);
transform:translateY(-1px);
box-shadow:0 4px 14px rgba(216,8,101,0.28)
}
.sg-login{
background:transparent;color:var(--text-pri);
border:1.5px solid var(--border-med)
}
.sg-login:hover{border-color:var(--brand);color:var(--brand)}

/* ══════════════════════════════════
   BUTTONS
══════════════════════════════════ */
.primary-btn{
background:var(--brand);
color:#fff;border:none;
padding:9px 20px;
border-radius:var(--radius-pill);
font-size:0.84rem;font-weight:600;
cursor:pointer;
transition:background var(--transition),transform var(--transition),box-shadow var(--transition);
display:inline-flex;align-items:center;gap:6px;
letter-spacing:0.01em
}
.primary-btn:hover{
background:var(--brand-hover);
transform:translateY(-1px);
box-shadow:var(--shadow-brand)
}
.primary-btn:active{transform:translateY(0);box-shadow:none}
.primary-btn.small{padding:6px 14px;font-size:0.79rem}

.ghost-btn{
background:transparent;
color:var(--text-sec);
border:1px solid var(--border-med);
padding:9px 16px;
border-radius:var(--radius-pill);
font-size:0.84rem;font-weight:500;
cursor:pointer;
transition:all var(--transition);
display:inline-flex;align-items:center;gap:6px
}
.ghost-btn svg{width:14px;height:14px;fill:currentColor}
.ghost-btn:hover{
background:var(--surface-1);
color:var(--text-pri);
border-color:var(--border-med)
}
.ghost-btn:active{transform:scale(0.98)}
.ghost-btn.small{padding:6px 12px;font-size:0.79rem}

.close-btn{
background:none;border:none;
color:var(--text-mute);
font-size:1rem;cursor:pointer;margin-left:auto;
padding:4px 8px;border-radius:50%;
transition:all var(--transition)
}
.close-btn:hover{color:var(--text-pri);background:var(--surface-1)}

/* ══════════════════════════════════
   LAYOUT
══════════════════════════════════ */
.dashboard-layout{
max-width:1240px;margin:0 auto;
padding:24px 28px;
display:grid;
grid-template-columns:1fr 336px;
gap:24px;
min-height:calc(100vh - var(--nav-h))
}
.feed-column{display:flex;flex-direction:column;gap:14px}
.sidebar-column{
display:flex;flex-direction:column;gap:14px;
height:fit-content;
position:sticky;top:calc(var(--nav-h) + 16px)
}

/* ── Cards ── */
.card{
background:var(--bg-card);
border:1px solid var(--border);
border-radius:var(--radius);
padding:20px;
box-shadow:var(--shadow-xs);
transition:box-shadow var(--transition),border-color var(--transition);
animation:fadeUp 0.28s var(--ease) both
}
.card:hover{
box-shadow:var(--shadow-md);
border-color:var(--border-med)
}
@keyframes fadeUp{
from{opacity:0;transform:translateY(8px)}
to{opacity:1;transform:translateY(0)}
}

/* ── Activity banner ── */
.activity-banner{
display:flex;align-items:center;gap:10px;
background:rgba(216,8,101,0.05);
border:1px solid rgba(216,8,101,0.15);
border-radius:var(--radius);padding:12px 18px;
font-size:0.855rem;font-weight:600;color:var(--brand)
}
.pulse-dot{
width:8px;height:8px;
background:var(--brand);
border-radius:50%;
animation:pulse 2.4s infinite;
flex-shrink:0
}
@keyframes pulse{
0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(216,8,101,0.35)}
50%{opacity:0.8;box-shadow:0 0 0 5px rgba(216,8,101,0)}
}

/* ── Post box ── */
.post-box .post-input{
width:100%;background:var(--bg-input);
border:1px solid var(--border);border-radius:var(--radius-sm);
color:var(--text-pri);padding:14px 16px;
font-family:'Inter',sans-serif;font-size:0.88rem;
resize:none;height:80px;outline:none;
transition:border-color var(--transition),box-shadow var(--transition)
}
.post-input:focus{
border-color:var(--brand);
box-shadow:0 0 0 3px rgba(216,8,101,0.08)
}
.post-input::placeholder{color:var(--text-mute)}
.post-actions{
display:flex;justify-content:space-between;align-items:center;
margin-top:10px;flex-wrap:wrap;gap:8px
}
.post-media-btns{display:flex;gap:8px}

/* ── Verify card ── */
.verify-card{
background:rgba(216,8,101,0.04);
border:1px solid rgba(216,8,101,0.12)
}
.verify-content{display:flex;gap:16px;align-items:center;margin-bottom:16px}
.circular-chart{width:64px;height:64px}
.circle-bg{fill:none;stroke:var(--border);stroke-width:3.8}
.circle{fill:none;stroke:var(--brand);stroke-width:3.8;stroke-linecap:round;animation:chart-progress 0.8s ease-out}
@keyframes chart-progress{from{stroke-dasharray:0,100}}
.percentage{fill:var(--text-pri);font-size:0.38em;text-anchor:middle;font-weight:700}
.verify-text h4{font-size:0.97rem;margin-bottom:4px}
.verify-text p{font-size:0.775rem;color:var(--text-sec);line-height:1.5}
.verify-btn{
width:100%;
background:var(--brand);
color:#fff;border:none;
padding:10px;
border-radius:var(--radius-pill);
font-weight:600;cursor:pointer;
transition:background var(--transition),box-shadow var(--transition),transform var(--transition);
font-size:0.855rem;
letter-spacing:0.01em
}
.verify-btn:hover{
background:var(--brand-hover);
transform:translateY(-1px);
box-shadow:var(--shadow-brand)
}
.verify-btn:active{transform:translateY(0)}

/* ── Section titles ── */
.section-title{
font-size:0.82rem;font-weight:700;
color:var(--text-mute);
margin-bottom:12px;display:flex;align-items:center;gap:7px;
letter-spacing:0.06em;text-transform:uppercase
}
.section-title svg{width:14px;height:14px;stroke:var(--brand);stroke-width:2;fill:none;flex-shrink:0}
.count-badge{
background:var(--brand);
color:#fff;font-size:0.66rem;padding:2px 8px;border-radius:99px;
font-weight:700
}

/* ── Viewers ── */
.viewers-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.viewer-item{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer}
.viewer-avatar{
width:50px;height:50px;border-radius:var(--radius-sm);
object-fit:cover;
border:1px solid var(--border);
transition:all var(--transition);background:var(--bg-subtle)
}
.viewer-item:hover .viewer-avatar{
border-color:var(--brand);
transform:translateY(-2px) scale(1.04);
box-shadow:0 4px 12px rgba(216,8,101,0.2)
}
.viewer-name{font-size:0.68rem;color:var(--text-sec);text-align:center}
.viewer-date{font-size:0.6rem;color:var(--text-mute)}

/* ── Meet CTA ── */
.meet-cta-card{
background:rgba(216,8,101,0.04);
border:1px solid rgba(216,8,101,0.12);
text-align:center
}
.meet-cta-card h3{font-size:1rem;margin-bottom:5px;color:var(--text-pri)}
.meet-cta-card p{font-size:0.8rem;color:var(--text-sec);margin-bottom:14px;line-height:1.55}
.meet-cta-card .primary-btn{width:100%;justify-content:center;font-size:0.9rem;padding:11px}

/* ── Nearby ── */
.nearby-list{display:flex;flex-direction:column;gap:5px}
.nearby-item{
display:flex;align-items:center;gap:11px;
padding:9px 12px;
background:var(--bg-card);
border-radius:var(--radius-sm);
border:1px solid var(--border);
cursor:pointer;transition:all var(--transition)
}
.nearby-item:hover{
background:rgba(216,8,101,0.04);
border-color:rgba(216,8,101,0.2)
}
.nearby-avatar{
width:40px;height:40px;border-radius:50%;
object-fit:cover;
border:1px solid var(--border);
flex-shrink:0;background:var(--bg-subtle)
}
.nearby-info{flex:1;min-width:0}
.nearby-name{font-size:0.855rem;font-weight:600;color:var(--text-pri);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nearby-meta{font-size:0.72rem;color:var(--text-mute);margin-top:1px}
.nearby-online{width:7px;height:7px;background:var(--online);border-radius:50%;flex-shrink:0}

/* ── Load more ── */
.load-more-btn{
background:transparent;
border:1px solid var(--border-med);
color:var(--text-sec);padding:13px;width:100%;
border-radius:var(--radius);font-size:0.855rem;font-weight:500;
cursor:pointer;transition:all var(--transition)
}
.load-more-btn:hover{
background:rgba(216,8,101,0.04);
color:var(--brand);
border-color:rgba(216,8,101,0.3)
}

/* ── Floating messages button ── */
.floating-messages-btn{
position:fixed;bottom:24px;right:24px;
background:var(--brand);
color:#fff;padding:12px 22px;
border-radius:var(--radius-pill);
font-weight:600;font-size:0.81rem;
display:flex;align-items:center;gap:7px;
box-shadow:0 4px 20px rgba(216,8,101,0.3);
z-index:50;
transition:all var(--transition);
letter-spacing:0.03em;
border:none;cursor:pointer
}
/* floating-messages-btn hidden — nav handles messaging access */
.floating-messages-btn{display:none!important}

/* ══════════════════════════════════
   PAGE LAYOUT
══════════════════════════════════ */
.page-layout{max-width:1240px;margin:0 auto;padding:24px 28px}

/* ══════════════════════════════════
   GALLERY
══════════════════════════════════ */
.gallery-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}
.filter-card{position:sticky;top:calc(var(--nav-h) + 16px)}
.filter-card h3{font-size:0.97rem;margin-bottom:14px;display:flex;align-items:center;gap:8px;color:var(--text-pri)}
.filter-group{margin-bottom:16px}
.filter-label{
font-size:0.72rem;color:var(--text-mute);font-weight:700;
text-transform:uppercase;letter-spacing:0.08em;margin-bottom:7px;display:block
}
.filter-input{
width:100%;background:var(--bg-input);border:1px solid var(--border);
border-radius:var(--radius-sm);color:var(--text-pri);padding:9px 13px;
font-size:0.855rem;outline:none;transition:border-color var(--transition)
}
.filter-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(216,8,101,0.08)}
.filter-input::placeholder{color:var(--text-mute)}
.range-label{display:flex;justify-content:space-between;font-size:0.77rem;color:var(--text-sec);margin-bottom:5px}
.range-group{
background:rgba(216,8,101,0.05);
border:1px solid rgba(216,8,101,0.15);
border-radius:var(--radius-sm);padding:5px 11px;
font-size:0.84rem;color:var(--brand);font-weight:700;text-align:center
}
input[type=range]{width:100%;accent-color:var(--brand);cursor:pointer;background:transparent}
.toggle-field{display:flex;justify-content:space-between;align-items:center}
.toggle{
width:42px;height:23px;
background:var(--border-med);
border:1px solid var(--border);
border-radius:12px;
cursor:pointer;position:relative;transition:all var(--transition)
}
.toggle.active{background:var(--brand);border-color:var(--brand)}
.toggle::after{
content:'';position:absolute;width:17px;height:17px;
background:white;border-radius:50%;top:2px;left:2px;
transition:transform var(--transition);
box-shadow:0 1px 3px rgba(0,0,0,0.2)
}
.toggle.active::after{transform:translateX(19px)}
.reset-btn{
width:100%;background:transparent;border:1px solid var(--border-med);
color:var(--text-sec);padding:9px;border-radius:var(--radius-pill);
cursor:pointer;font-size:0.855rem;transition:all var(--transition)
}
.reset-btn:hover{border-color:var(--border-hover);color:var(--text-pri)}
.matches-btn{
width:100%;
background:var(--brand);
border:none;color:#fff;padding:11px;border-radius:var(--radius-pill);
font-weight:600;cursor:pointer;margin-bottom:14px;
display:flex;align-items:center;justify-content:center;gap:8px;
transition:background var(--transition),transform var(--transition),box-shadow var(--transition);
font-size:0.855rem;letter-spacing:0.01em
}
.matches-btn:hover{
background:var(--brand-hover);
transform:translateY(-1px);
box-shadow:var(--shadow-brand)
}
.matches-btn:active{transform:translateY(0)}

/* ══════════════════════════════════════════════════════════
   SHARED FILTER UI KIT  (.flt-*)  — used by browse + gallery
   One consistent, high-contrast design language for every filter
   panel. Includes a proper non-crossing dual-handle range slider.
══════════════════════════════════════════════════════════ */
.flt-card{
background:var(--bg-card);
border:1px solid var(--border);
border-radius:var(--radius);
box-shadow:var(--shadow-sm);
padding:20px;
display:flex;flex-direction:column;gap:0
}
.flt-card--sticky{position:sticky;top:calc(var(--nav-h) + 16px);height:fit-content}

/* Header */
.flt-head{
display:flex;align-items:center;justify-content:space-between;
padding-bottom:16px;margin-bottom:4px;
border-bottom:1px solid var(--border)
}
.flt-head h2{
font-size:1rem;font-weight:800;color:var(--text-pri);
display:flex;align-items:center;gap:9px;letter-spacing:-0.01em
}
.flt-head h2 svg{color:var(--brand)}
.flt-clear{
font-size:0.78rem;font-weight:600;color:var(--brand);
background:none;border:none;cursor:pointer;
padding:4px 8px;border-radius:7px;transition:background var(--transition)
}
.flt-clear:hover{background:rgba(216,8,101,0.09)}

/* Section — divider between each for structure/scannability */
.flt-section{padding:16px 0;border-bottom:1px solid var(--border)}
.flt-section:last-of-type{border-bottom:none}
.flt-label{
display:flex;align-items:center;gap:6px;
font-size:0.72rem;font-weight:700;color:var(--text-sec);
text-transform:uppercase;letter-spacing:0.08em;margin-bottom:11px
}
.flt-label .flt-count{
margin-left:auto;color:var(--brand);background:rgba(216,8,101,0.1);
font-size:0.68rem;font-weight:700;padding:1px 7px;border-radius:99px;letter-spacing:0
}

/* Segmented multi-select pills */
.flt-seg{display:flex;flex-wrap:wrap;gap:8px}
.flt-seg-item{cursor:pointer;user-select:none}
.flt-seg-item input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.flt-seg-item span{
display:inline-flex;align-items:center;gap:5px;
padding:8px 15px;border-radius:var(--radius-pill);
border:1.5px solid var(--border-med);background:var(--bg-input);
color:var(--text-sec);font-size:0.84rem;font-weight:600;
transition:all var(--transition);white-space:nowrap
}
.flt-seg-item:hover span{border-color:var(--brand);color:var(--text-pri)}
.flt-seg-item input:checked + span{
background:rgba(216,8,101,0.1);border-color:var(--brand);
color:var(--brand);font-weight:700
}
.flt-seg-item input:checked + span::before{
content:'';width:13px;height:13px;flex-shrink:0;
background:var(--brand);border-radius:50%;
-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;
mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat
}
.flt-seg-item input:focus-visible + span{box-shadow:0 0 0 3px rgba(216,8,101,0.18)}

/* Select dropdown */
.flt-select{
width:100%;background:var(--bg-input);
border:1.5px solid var(--border-med);border-radius:var(--radius-sm);
color:var(--text-pri);padding:10px 36px 10px 13px;
font-size:0.875rem;font-family:inherit;font-weight:500;cursor:pointer;
appearance:none;-webkit-appearance:none;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23d80865' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
background-repeat:no-repeat;background-position:right 12px center;
transition:border-color var(--transition),box-shadow var(--transition)
}
.flt-select:hover{border-color:var(--brand)}
.flt-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(216,8,101,0.12)}
.flt-select option{background:var(--bg-card);color:var(--text-pri)}

/* Text input (location search) */
.flt-text-wrap{position:relative}
.flt-text-wrap .flt-text-icon{
position:absolute;left:13px;top:50%;transform:translateY(-50%);
pointer-events:none;font-size:0.95rem;line-height:1
}
.flt-text{
width:100%;background:var(--bg-input);
border:1.5px solid var(--border-med);border-radius:var(--radius-sm);
color:var(--text-pri);padding:10px 34px 10px 36px;
font-size:0.875rem;font-family:inherit;outline:none;
transition:border-color var(--transition),box-shadow var(--transition)
}
.flt-text::placeholder{color:var(--text-mute)}
.flt-text:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(216,8,101,0.12)}
.flt-text-clear{
position:absolute;right:8px;top:50%;transform:translateY(-50%);
display:none;width:22px;height:22px;border-radius:50%;border:none;
background:var(--border-med);color:var(--text-pri);cursor:pointer;
align-items:center;justify-content:center;font-size:0.9rem;line-height:1
}
.flt-text-clear.visible{display:flex}

/* ── Dual-handle range slider (non-crossing) ── */
.flt-range{display:flex;flex-direction:column;gap:10px}
.flt-range-head{display:flex;align-items:center;justify-content:space-between}
.flt-range-val{font-size:0.95rem;font-weight:800;color:var(--brand);letter-spacing:-0.01em}
.flt-range-sep{font-size:0.78rem;color:var(--text-mute);font-weight:500}
.flt-range-bar{position:relative;height:22px}
.flt-range-track{
position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);
height:6px;background:var(--border-med);border-radius:99px
}
.flt-range-fill{
position:absolute;top:0;bottom:0;
background:linear-gradient(90deg,var(--brand),var(--brand-hover,#b80654));
border-radius:99px
}
/* Both inputs stacked & transparent; only the thumbs catch the pointer,
   so either handle is always grabbable even when they meet. */
.flt-range-bar input[type=range]{
position:absolute;top:0;left:0;width:100%;height:22px;margin:0;
background:none;pointer-events:none;-webkit-appearance:none;appearance:none
}
.flt-range-bar input[type=range]::-webkit-slider-thumb{
-webkit-appearance:none;pointer-events:auto;cursor:grab;
width:20px;height:20px;border-radius:50%;
background:var(--brand);border:3px solid var(--bg-card);
box-shadow:0 0 0 3px rgba(216,8,101,0.22),0 2px 5px rgba(0,0,0,0.25)
}
.flt-range-bar input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.12)}
.flt-range-bar input[type=range]::-moz-range-thumb{
pointer-events:auto;cursor:grab;
width:20px;height:20px;border-radius:50%;
background:var(--brand);border:3px solid var(--bg-card);
box-shadow:0 0 0 3px rgba(216,8,101,0.22),0 2px 5px rgba(0,0,0,0.25)
}
.flt-range-bar input[type=range]::-moz-range-track{background:transparent;border:none}

/* ── Single-value range (distance) ── */
.flt-srange{
width:100%;height:6px;-webkit-appearance:none;appearance:none;
background:var(--border-med);border-radius:99px;outline:none;cursor:pointer;margin:4px 0
}
.flt-srange::-webkit-slider-thumb{
-webkit-appearance:none;width:20px;height:20px;border-radius:50%;
background:var(--brand);border:3px solid var(--bg-card);
box-shadow:0 0 0 3px rgba(216,8,101,0.22),0 2px 5px rgba(0,0,0,0.25);cursor:pointer
}
.flt-srange::-moz-range-thumb{
width:20px;height:20px;border-radius:50%;
background:var(--brand);border:3px solid var(--bg-card);
box-shadow:0 0 0 3px rgba(216,8,101,0.22),0 2px 5px rgba(0,0,0,0.25);cursor:pointer
}
.flt-srange-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}
.flt-srange-head .lbl{font-size:0.8rem;color:var(--text-sec)}
.flt-srange-head .val{font-size:0.9rem;font-weight:800;color:var(--brand)}
.flt-inline-link{
display:inline-flex;align-items:center;gap:5px;margin-top:9px;
font-size:0.8rem;font-weight:600;color:var(--brand);
background:none;border:none;cursor:pointer;padding:0;font-family:inherit
}
.flt-inline-link:hover{text-decoration:underline}

/* Toggle switch rows */
.flt-switch-list{display:flex;flex-direction:column;gap:13px}
.flt-switch{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.flt-switch-label{font-size:0.9rem;font-weight:500;color:var(--text-pri)}
.flt-switch input{position:absolute;opacity:0;width:0;height:0}
.flt-switch-ui{
position:relative;width:42px;height:24px;flex-shrink:0;
background:var(--border-med);border-radius:99px;transition:background var(--transition)
}
.flt-switch-ui::after{
content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;
background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,0.3);
transition:transform var(--transition)
}
.flt-switch input:checked + .flt-switch-ui{background:var(--brand)}
.flt-switch input:checked + .flt-switch-ui::after{transform:translateX(18px)}
.flt-switch input:focus-visible + .flt-switch-ui{box-shadow:0 0 0 3px rgba(216,8,101,0.22)}

/* Action buttons */
.flt-actions{display:flex;flex-direction:column;gap:9px;padding-top:18px}
.flt-btn{
width:100%;padding:12px 16px;border-radius:var(--radius-pill);
font-size:0.9rem;font-weight:700;font-family:inherit;cursor:pointer;
display:flex;align-items:center;justify-content:center;gap:8px;
border:none;transition:all var(--transition)
}
.flt-btn--primary{background:var(--brand);color:#fff}
.flt-btn--primary:hover{background:var(--brand-hover,#b80654);transform:translateY(-1px);box-shadow:var(--shadow-brand)}
.flt-btn--primary:active{transform:translateY(0)}
.flt-btn--ghost{background:transparent;color:var(--text-sec);border:1.5px solid var(--border-med)}
.flt-btn--ghost:hover{color:var(--text-pri);border-color:var(--brand)}

.gallery-grid{
columns:4 220px;
column-gap:12px
}
.gallery-item{
position:relative;border-radius:var(--radius-sm);overflow:hidden;
cursor:pointer;background:var(--bg-subtle);
border:1px solid var(--border);transition:all var(--transition);
break-inside:avoid;margin-bottom:12px;display:block
}
/* Reserve each tile's box from its aspect ratio so the mosaic lays out
   instantly with no reflow as images stream in. */
.gallery-img{background:var(--bg-subtle)}
.gallery-item:hover{
box-shadow:var(--shadow-lg);
border-color:transparent
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-img{width:100%;height:auto;display:block;transition:transform 0.38s ease}
.gallery-item:hover .gallery-img{transform:scale(1.03)}
.gallery-overlay{
position:absolute;inset:0;
background:linear-gradient(to top,rgba(0,0,0,0.78) 0%,transparent 55%);
opacity:0;transition:opacity var(--transition);
display:flex;align-items:flex-end;padding:12px
}
.gallery-info{display:flex;align-items:center;justify-content:space-between;width:100%}
.gallery-user{font-size:0.81rem;font-weight:600;color:#fff}
.gallery-like-count{display:flex;align-items:center;gap:4px;font-size:0.76rem;color:rgba(255,255,255,0.7)}
.gallery-type{position:absolute;top:8px;right:8px}
.gallery-type .icon-btn{width:28px;height:28px;background:rgba(0,0,0,0.45);border:none;color:#fff}

/* ══════════════════════════════════
   PARTIES
══════════════════════════════════ */
.parties-header{margin-bottom:24px;padding:28px 0 8px}
.parties-header h1{font-size:1.75rem;font-weight:800;margin-bottom:6px;letter-spacing:-0.03em;color:var(--text-pri);display:flex;align-items:center;gap:10px}
.parties-header h1 svg{width:24px;height:24px;stroke:var(--brand);stroke-width:1.8;fill:none;flex-shrink:0}
.parties-header p{color:var(--text-sec);font-size:0.9rem;line-height:1.65;max-width:580px}
.search-filters{display:flex;gap:9px;margin-bottom:24px;flex-wrap:wrap}
.search-input-wrap{flex:1;min-width:200px;position:relative}
.search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:15px;height:15px;fill:var(--text-mute)}
.search-field{
width:100%;background:var(--bg-card);border:1px solid var(--border);
border-radius:var(--radius-sm);color:var(--text-pri);
padding:11px 14px 11px 38px;font-size:0.855rem;outline:none;
transition:border-color var(--transition)
}
.search-field:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(216,8,101,0.08)}
.filter-select{
background:var(--bg-input);border:1px solid var(--border);
border-radius:var(--radius-sm);color:var(--text-pri);
padding:11px 15px;font-size:0.855rem;cursor:pointer;outline:none;min-width:140px;
appearance:none;-webkit-appearance:none;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
background-repeat:no-repeat;background-position:right 12px center;padding-right:34px
}
.filter-select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(216,8,101,0.08)}
.parties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.party-card{
background:var(--bg-card);border:1px solid var(--border);
border-radius:var(--radius);overflow:hidden;
cursor:pointer;transition:all var(--transition);
animation:fadeUp 0.28s var(--ease) both
}
.party-card:hover{
transform:translateY(-3px);
box-shadow:var(--shadow-lg);
border-color:var(--border-med)
}
.party-img-wrap{position:relative;height:170px;overflow:hidden}
.party-img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease}
.party-card:hover .party-img{transform:scale(1.04)}
.party-date-badge{
position:absolute;top:12px;left:12px;
background:var(--brand);
color:#fff;border-radius:var(--radius-sm);
padding:5px 11px;text-align:center;min-width:48px
}
.party-month{font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;opacity:0.85}
.party-day{font-size:1.25rem;font-weight:800;line-height:1}
.party-paid-badge{
position:absolute;top:12px;right:12px;
background:var(--gold);color:#000;
border-radius:var(--radius-xs);padding:3px 9px;
font-size:0.7rem;font-weight:700
}
.party-title{
position:absolute;bottom:0;left:0;right:0;padding:12px 15px;
background:linear-gradient(to top,rgba(0,0,0,0.82) 0%,transparent 100%);
font-weight:700;font-size:0.96rem;color:#fff
}
.party-body{padding:15px}
.party-meta{display:flex;gap:12px;margin-bottom:9px}
.party-meta-item{display:flex;align-items:center;gap:5px;font-size:0.74rem;color:var(--text-sec)}
.party-meta-item svg{width:12px;height:12px;fill:currentColor}
.party-desc{
font-size:0.8rem;color:var(--text-sec);line-height:1.5;
display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;
-webkit-box-orient:vertical;overflow:hidden;margin-bottom:9px
}
.party-location{display:flex;align-items:center;gap:4px;font-size:0.74rem;color:var(--text-mute)}
.party-location svg{width:11px;height:11px;fill:currentColor}
.create-party-btn{
display:flex;align-items:center;justify-content:center;
background:var(--brand);color:#fff;
padding:12px 30px;border-radius:var(--radius-pill);
font-weight:600;font-size:0.9rem;margin:0 auto 24px;width:fit-content;
border:none;cursor:pointer;
transition:background var(--transition),transform var(--transition),box-shadow var(--transition);
gap:8px;letter-spacing:0.01em
}
.create-party-btn:hover{
background:var(--brand-hover);
transform:translateY(-2px);
box-shadow:var(--shadow-brand);
color:white
}
.create-party-btn:active{transform:translateY(0)}

/* ══════════════════════════════════
   PROFILE PAGE
══════════════════════════════════ */
.profile-hero{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:22px}
.profile-cover{
height:200px;
background:linear-gradient(135deg,#f5e6dc 0%,#ecddd6 30%,#dde3ef 65%,#cfd8ea 100%);
position:relative;overflow:hidden
}
/* Subtle geometric pattern overlay on cover */
.profile-cover::before{
content:'';position:absolute;inset:0;
background-image:radial-gradient(circle at 20% 50%,rgba(216,8,101,0.06) 0%,transparent 55%),
  radial-gradient(circle at 80% 20%,rgba(58,134,255,0.06) 0%,transparent 50%);
}
.cover-edit{
position:absolute;bottom:14px;right:14px;
display:inline-flex;align-items:center;gap:6px;
background:rgba(255,255,255,0.92);
border:1px solid var(--border);
color:var(--text-sec);padding:7px 14px;border-radius:var(--radius-pill);
font-size:0.78rem;font-weight:500;cursor:pointer;transition:all var(--transition);
backdrop-filter:blur(8px);text-decoration:none
}
.cover-edit:hover{background:#fff;color:var(--text-pri);border-color:var(--border-med)}
.profile-info-section{
background:var(--bg-card);border:1px solid var(--border);
border-radius:var(--radius);padding:22px;
position:relative;display:flex;gap:22px
}
.profile-avatar-wrap{flex-shrink:0;position:relative;margin-top:-56px}
.profile-avatar{
width:114px;height:114px;border-radius:50%;
border:4px solid var(--bg-page);
object-fit:cover;background:var(--bg-subtle)
}
.profile-badge{
position:absolute;bottom:4px;right:4px;
background:var(--gold);
width:26px;height:26px;border-radius:50%;
display:flex;align-items:center;justify-content:center;
font-size:0.78rem;border:2px solid var(--bg-card)
}
.profile-details{flex:1}
.profile-name{font-size:1.7rem;font-weight:800;margin-bottom:3px;letter-spacing:-0.03em;color:var(--text-pri)}
.profile-username{color:var(--text-sec);font-size:0.86rem;margin-bottom:9px}
.profile-location{display:flex;align-items:center;gap:5px;color:var(--text-sec);font-size:0.84rem;margin-bottom:14px}
.profile-location svg{width:13px;height:13px;fill:currentColor}
.profile-stats-row{display:flex;gap:22px}
.profile-stat{text-align:center}
.profile-stat .num{font-size:1.3rem;font-weight:800;letter-spacing:-0.02em;color:var(--text-pri)}
.profile-stat .lbl{font-size:0.7rem;color:var(--text-mute)}
.profile-actions{display:flex;gap:8px;flex-shrink:0;align-self:flex-start;padding-top:18px}

/* ══════════════════════════════════
   MATCH CARD
══════════════════════════════════ */
.match-card{padding:0;overflow:hidden}
.match-card:hover .match-media img{transform:scale(1.04)}
.match-media{
height:210px;position:relative;overflow:hidden;
display:flex;align-items:center;justify-content:center;
background:linear-gradient(135deg,#FFF0EB 0%,#F5F0FF 100%)
}
.match-media .match-hero-avatar{
width:120px;height:120px;
border-radius:50%;object-fit:cover;
box-shadow:
  0 0 0 3px rgba(216,8,101,0.35),
  0 0 28px rgba(216,8,101,0.2),
  0 8px 22px rgba(0,0,0,0.15);
position:relative;z-index:1;
transition:box-shadow 0.3s ease,transform 0.3s ease
}
.match-card:hover .match-media .match-hero-avatar{
transform:scale(1.05);
box-shadow:
  0 0 0 3px var(--brand),
  0 0 36px rgba(216,8,101,0.3),
  0 12px 30px rgba(0,0,0,0.18)
}
.match-media::before,.match-media::after{display:none}
.match-media img:not(.match-hero-avatar){
width:100%;height:100%;object-fit:cover;
transition:transform 0.42s ease
}
.match-card:hover .match-media img:not(.match-hero-avatar){transform:scale(1.04)}
.match-overlay{
position:absolute;inset:0;
background:linear-gradient(to top,rgba(0,0,0,0.7) 0%,transparent 52%)
}
.match-info{padding:18px}
.match-header{display:flex;align-items:flex-start;gap:11px;margin-bottom:14px}
.match-icon{
width:34px;height:34px;
background:var(--brand);
border-radius:50%;
display:flex;align-items:center;justify-content:center;
flex-shrink:0
}
.match-icon svg{width:15px;height:15px;fill:white}
.match-name{font-size:0.97rem;font-weight:700;color:var(--text-pri)}
.match-name a{color:var(--text-pri)}
.match-name a:hover{color:var(--brand)}
.match-meta{font-size:0.76rem;color:var(--text-mute);margin-top:2px}
.match-interests{margin-bottom:14px}
.interests-title{font-size:0.8rem;font-weight:600;color:var(--text-sec);margin-bottom:7px}
.match-interests ul{list-style:none;display:flex;flex-direction:column;gap:3px}
.match-interests li{font-size:0.81rem;color:var(--text-sec)}
.match-cta{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.message-input-wrap{
display:flex;align-items:center;gap:8px;
background:var(--bg-input);border:1px solid var(--border);
border-radius:var(--radius-sm);padding:6px 11px
}
.message-input{
flex:1;background:none;border:none;
color:var(--text-pri);font-size:0.855rem;outline:none
}
.message-input::placeholder{color:var(--text-mute)}

/* ══════════════════════════════════
   FEED POSTS
══════════════════════════════════ */
.feed-post{
background:var(--bg-card);border:1px solid var(--border);
border-radius:var(--radius);overflow:hidden;
box-shadow:var(--shadow-xs);
transition:all var(--transition);
animation:fadeUp 0.28s var(--ease) both
}
.feed-post:hover{
border-color:var(--border-med);
box-shadow:var(--shadow-sm)
}
.post-header{display:flex;align-items:center;gap:11px;padding:14px 18px}
.post-avatar{
width:42px;height:42px;border-radius:50%;
object-fit:cover;
border:2px solid var(--border)
}
.post-user-info{flex:1}
.post-username{font-weight:600;font-size:0.9rem;color:var(--text-pri)}
.post-time{font-size:0.74rem;color:var(--text-mute);margin-top:1px}
.post-menu{
background:none;border:none;color:var(--text-mute);
font-size:1.1rem;cursor:pointer;padding:4px 7px;
border-radius:var(--radius-xs);transition:all var(--transition)
}
.post-menu:hover{color:var(--text-pri);background:var(--surface-1)}
.post-image-wrap{overflow:hidden;display:block;cursor:pointer}
.post-image{width:100%;max-height:400px;object-fit:cover;display:block;transition:transform 0.4s ease}
.post-image-wrap:hover .post-image{transform:scale(1.04)}
.post-body{padding:0 18px 11px}
.post-text{font-size:0.88rem;color:var(--text-sec);line-height:1.65}
.post-content{padding:11px 18px;font-size:0.88rem;line-height:1.65;color:var(--text-sec)}
.post-footer{
display:flex;align-items:center;gap:3px;
padding:9px 12px;border-top:1px solid var(--border)
}
.react-btn{
background:none;border:none;color:var(--text-mute);
font-size:0.8rem;cursor:pointer;padding:5px 10px;
border-radius:var(--radius-sm);
display:flex;align-items:center;gap:5px;
transition:all var(--transition)
}
.react-btn:hover{background:var(--surface-1);color:var(--text-pri)}
.react-btn.liked{color:var(--brand)}
.react-btn.liked:hover{background:rgba(216,8,101,0.06)}

/* ── Profile stats ── */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.stat{
display:flex;flex-direction:column;align-items:center;
gap:4px;padding:11px 6px;
background:var(--surface-1);
border:1px solid var(--border);
border-radius:var(--radius-sm);
cursor:pointer;transition:all var(--transition)
}
.stat:hover{
background:rgba(216,8,101,0.04);
border-color:rgba(216,8,101,0.2);
transform:translateY(-1px)
}
.stat svg{width:18px;height:18px;fill:var(--text-sec)}
.stat-num{font-size:0.93rem;font-weight:800;color:var(--text-pri);letter-spacing:-0.01em}
.stat-label{font-size:0.61rem;color:var(--text-mute);text-align:center}

/* ══════════════════════════════════
   CHAT
══════════════════════════════════ */
.chat-layout{
display:grid;grid-template-columns:300px 1fr;
gap:0;height:calc(100vh - var(--nav-h));
max-width:1240px;margin:0 auto
}
.chat-sidebar{
background:var(--bg-card);border-right:1px solid var(--border);
display:flex;flex-direction:column;overflow:hidden
}
.chat-sidebar-header{padding:15px;border-bottom:1px solid var(--border);flex-shrink:0}
.chat-sidebar-title{font-size:0.97rem;font-weight:700;color:var(--text-pri);display:flex;align-items:center;margin-bottom:11px}
.chat-search{
width:100%;background:var(--bg-input);border:1px solid var(--border);
border-radius:var(--radius-sm);color:var(--text-pri);
padding:9px 13px;font-size:0.855rem;outline:none
}
.chat-list{flex:1;overflow-y:auto}
.chat-item{
display:flex;align-items:center;gap:11px;
padding:11px 14px;cursor:pointer;
transition:background var(--transition);
border-bottom:1px solid var(--border);position:relative
}
.chat-item:hover{background:var(--surface-1)}
.chat-item.active{background:rgba(216,8,101,0.05);border-left:3px solid var(--brand)}
.chat-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--bg-subtle)}
.chat-user-info{flex:1;min-width:0}
.chat-name{font-size:0.88rem;font-weight:600;color:var(--text-pri)}
.chat-preview{font-size:0.74rem;color:var(--text-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-time{font-size:0.67rem;color:var(--text-mute)}
.chat-unread{
background:var(--brand);
color:#fff;font-size:0.6rem;padding:2px 7px;border-radius:99px;font-weight:700
}
.chat-online-dot{
position:absolute;bottom:1px;right:1px;
width:10px;height:10px;background:var(--online);
border-radius:50%;border:2px solid var(--bg-card)
}
.chat-main{display:flex;flex-direction:column;background:var(--bg-page)}
.chat-header{
padding:14px 22px;background:var(--bg-card);
border-bottom:1px solid var(--border);
display:flex;align-items:center;gap:13px;flex-shrink:0
}
.chat-header-info h3{font-size:0.97rem;font-weight:700;color:var(--text-pri)}
.chat-online-status{font-size:0.74rem;color:var(--online)}
.chat-header-meta{display:flex;align-items:center;gap:8px;margin-top:2px}
.badge-type{
font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;
background:rgba(216,8,101,0.08);border:1px solid rgba(216,8,101,0.18);
color:var(--brand);padding:2px 7px;border-radius:99px
}
.chat-messages{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:12px}
.message{display:flex;gap:9px;max-width:68%}
.message.sent{flex-direction:row-reverse;align-self:flex-end}
.msg-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:var(--bg-subtle)}
.msg-bubble{
background:var(--bg-card);border:1px solid var(--border);
border-radius:13px;padding:9px 13px;font-size:0.855rem;line-height:1.55;
color:var(--text-pri)
}
.message.sent .msg-bubble{
background:var(--brand);
border-color:var(--brand-dark);color:#fff
}
.msg-time{font-size:0.62rem;color:var(--text-mute);margin-top:3px;text-align:right}
.chat-input-area{
padding:13px 22px;background:var(--bg-card);
border-top:1px solid var(--border);
display:flex;gap:9px;align-items:center;flex-shrink:0
}
.chat-input{
flex:1;background:var(--bg-input);border:1px solid var(--border);
border-radius:var(--radius-pill);color:var(--text-pri);
padding:11px 18px;font-size:0.855rem;outline:none;
transition:border-color var(--transition),box-shadow var(--transition)
}
.chat-input:focus{
border-color:var(--brand);
box-shadow:0 0 0 3px rgba(216,8,101,0.08)
}
.send-btn{
width:42px;height:42px;
background:var(--brand);
border:none;border-radius:50%;
display:flex;align-items:center;justify-content:center;
cursor:pointer;
transition:background var(--transition),transform var(--transition),box-shadow var(--transition)
}
.send-btn svg{width:18px;height:18px;fill:white;transform:translateX(1px)}
.send-btn:hover{
background:var(--brand-hover);
transform:scale(1.07);
box-shadow:0 3px 12px rgba(216,8,101,0.3)
}
.send-btn:active{transform:scale(0.96)}
.typing-indicator{display:flex;align-items:center;gap:4px;padding:11px 15px}
.typing-indicator span{
width:6px;height:6px;background:var(--text-mute);
border-radius:50%;animation:typingBounce 1.2s infinite ease-in-out
}
.typing-indicator span:nth-child(2){animation-delay:0.2s}
.typing-indicator span:nth-child(3){animation-delay:0.4s}
@keyframes typingBounce{
0%,80%,100%{transform:scale(0.7);opacity:0.4}
40%{transform:scale(1);opacity:1}
}

/* ══════════════════════════════════
   MEETS
══════════════════════════════════ */
.meets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:18px}
.meet-card{
background:var(--bg-card);border:1px solid var(--border);
border-radius:var(--radius);overflow:hidden;
cursor:pointer;transition:all var(--transition)
}
.meet-card:hover{
transform:translateY(-3px);
box-shadow:var(--shadow-lg);
border-color:var(--border-med)
}
.meet-img-wrap{position:relative;height:190px;overflow:hidden}
.meet-img{width:100%;height:100%;object-fit:cover;background:var(--bg-subtle);transition:transform 0.4s ease}
.meet-card:hover .meet-img{transform:scale(1.05)}
.meet-badge{
position:absolute;top:11px;left:11px;
background:var(--online);color:#000;
font-size:0.67rem;font-weight:700;
padding:3px 10px;border-radius:99px
}
.meet-body{padding:15px}
.meet-name{font-size:1rem;font-weight:700;margin-bottom:3px;letter-spacing:-0.01em;color:var(--text-pri)}
.meet-location{font-size:0.76rem;color:var(--text-mute);display:flex;align-items:center;gap:4px;margin-bottom:11px}
.meet-interests{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:13px}
.interest-tag{
background:rgba(216,8,101,0.06);
border:1px solid rgba(216,8,101,0.15);
color:var(--brand);font-size:0.69rem;
padding:3px 9px;border-radius:99px
}
.meet-actions{display:flex;gap:8px}
.meet-actions .primary-btn{flex:1;justify-content:center}
.meet-actions .ghost-btn{flex:1;justify-content:center}

/* ══════════════════════════════════
   TOAST
══════════════════════════════════ */
.toast{
position:fixed;bottom:88px;right:22px;
background:var(--bg-card);
border:1px solid rgba(216,8,101,0.2);
border-radius:var(--radius-sm);
padding:12px 18px;
box-shadow:var(--shadow-lg);
font-size:0.855rem;z-index:200;
animation:toastIn 0.22s var(--ease),toastOut 0.22s ease-in 2.5s both;
display:flex;align-items:center;gap:9px;
color:var(--text-pri)
}
@keyframes toastIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0}}
.toast-ico{display:inline-flex;align-items:center;justify-content:center;color:var(--brand);flex-shrink:0}
.toast-ico svg{width:17px;height:17px;stroke-width:2}

/* ══════════════════════════════════════════════════════════
   ICON TILE — strong brand-gradient rounded square with a white
   icon. Reusable across profile info rows, stats, feature lists.
══════════════════════════════════════════════════════════ */
.icon-tile{
display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
width:38px;height:38px;border-radius:11px;
background:#D80865;
color:#fff;box-shadow:0 2px 6px rgba(216,8,101,0.28)
}
.icon-tile svg{width:18px;height:18px;stroke:#fff;stroke-width:2;fill:none}
.icon-tile i{display:inline-flex}
.icon-tile.sm{width:30px;height:30px;border-radius:9px}
.icon-tile.sm svg{width:15px;height:15px}
.icon-tile.lg{width:48px;height:48px;border-radius:14px}
.icon-tile.lg svg{width:23px;height:23px}
/* Small inline icon that inherits the surrounding text colour/size */
.row-ico{width:15px;height:15px;stroke-width:2;flex-shrink:0;color:inherit;display:inline-block;vertical-align:-2px}
.row-ico-sm{width:13px;height:13px;stroke-width:2;flex-shrink:0;color:inherit;display:inline-block;vertical-align:-2px}

/* ══════════════════════════════════
   LIGHTBOX
══════════════════════════════════ */
.chat-list::-webkit-scrollbar{width:3px}
.chat-messages::-webkit-scrollbar{width:3px}
.chat-page .floating-messages-btn{display:none}
.lightbox-overlay{
position:fixed;inset:0;z-index:20000;
display:flex;align-items:center;justify-content:center;
background:rgba(0,0,0,0.9);backdrop-filter:blur(12px);
-webkit-backdrop-filter:blur(12px);opacity:0;pointer-events:none;
transition:opacity 0.22s var(--ease)
}
.lightbox-overlay.open{opacity:1;pointer-events:all}
.lightbox-inner{
position:relative;display:flex;
width:90vw;height:90vh;
border-radius:var(--radius);overflow:hidden;
background:var(--bg-card);border:1px solid var(--border);
box-shadow:0 40px 120px rgba(0,0,0,0.6);
transform:scale(0.96) translateY(12px);transition:transform 0.22s var(--ease)
}
.lightbox-overlay.open .lightbox-inner{transform:scale(1) translateY(0)}
/* Close button sits on the side panel's top-right corner */
.lb-close{
position:absolute;top:12px;right:12px;z-index:30;
width:32px;height:32px;border-radius:50%;
border:1px solid var(--border);background:var(--bg-card);
color:var(--text-sec);font-size:0.95rem;cursor:pointer;
display:flex;align-items:center;justify-content:center;
transition:background var(--transition),color var(--transition),transform var(--transition)
}
.lb-close:hover{background:var(--bg-subtle);color:var(--text-pri);transform:rotate(90deg)}
/* Nav arrows — inside the image panel only */
.lb-nav-btn{
position:absolute;top:50%;transform:translateY(-50%);z-index:10;
width:42px;height:42px;border-radius:50%;
border:1px solid rgba(255,255,255,0.18);background:rgba(0,0,0,0.5);
color:#fff;font-size:1.1rem;cursor:pointer;
display:flex;align-items:center;justify-content:center;
transition:background var(--transition),opacity var(--transition);
backdrop-filter:blur(4px);opacity:0.7
}
.lb-nav-btn:hover{background:rgba(0,0,0,0.75);opacity:1}
.lb-prev{left:14px}
.lb-next{right:14px}
/* Image panel: fills all space not taken by the side panel;
   black background creates letterboxing for any aspect ratio */
.lb-image-panel{
flex:1 1 0;min-width:0;position:relative;
background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden
}
.lb-image-panel img{
width:100%;height:100%;
object-fit:contain;display:block;
transition:opacity 0.18s
}
.lb-image-panel img.fading{opacity:0}
/* Side panel: fixed 360px, scrollable comments, sticky header/footer */
.lb-side-panel{
width:360px;flex-shrink:0;display:flex;flex-direction:column;
border-left:1px solid var(--border);background:var(--bg-card);
overflow:hidden
}
.lb-poster-header{
display:flex;align-items:center;gap:11px;
/* extra right padding reserves space for the absolutely-positioned close ✕
   (right:12px + 32px wide) so the Message button never sits under it */
padding:15px 52px 15px 17px;
border-bottom:1px solid var(--border);flex-shrink:0
}
.lb-poster-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid var(--brand)}
.lb-poster-info{flex:1;min-width:0}
.lb-poster-name{font-weight:700;font-size:0.93rem;color:var(--text-pri);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-poster-meta{font-size:0.76rem;color:var(--text-mute);margin-top:1px}
.lb-stats-bar{
display:flex;align-items:center;gap:18px;padding:11px 17px;
border-bottom:1px solid var(--border);flex-shrink:0
}
.lb-stat-item{display:flex;align-items:center;gap:5px;font-size:0.84rem;color:var(--text-sec)}
.lb-stat-item span:first-child{font-size:0.97rem}
.lb-stat-item strong{font-weight:700;color:var(--text-pri)}
.lb-like-btn{
margin-left:auto;display:flex;align-items:center;gap:5px;
padding:5px 13px;border-radius:var(--radius-pill);
border:1px solid var(--border);background:transparent;
color:var(--text-sec);font-size:0.84rem;font-weight:600;cursor:pointer;transition:all var(--transition)
}
.lb-like-btn:hover{border-color:var(--brand);color:var(--brand);background:rgba(216,8,101,0.06)}
.lb-like-btn.liked{border-color:var(--brand);color:var(--brand);background:rgba(216,8,101,0.08)}
.lb-like-btn.liked .lb-heart{animation:heartPop 0.32s var(--ease)}
@keyframes heartPop{0%{transform:scale(1)}50%{transform:scale(1.42)}100%{transform:scale(1)}}
.lb-comments-list{
flex:1 1 0;overflow-y:auto;padding:13px 17px;
display:flex;flex-direction:column;gap:12px;
scrollbar-width:thin;scrollbar-color:var(--border) transparent
}
.lb-comments-list::-webkit-scrollbar{width:3px}
.lb-comments-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.lb-comment{display:flex;gap:9px;align-items:flex-start;animation:commentIn 0.22s var(--ease)}
@keyframes commentIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.lb-comment-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0;margin-top:2px}
.lb-comment-body{flex:1;min-width:0}
.lb-comment-author{font-size:0.8rem;font-weight:700;color:var(--text-pri);margin-bottom:2px}
.lb-comment-text{font-size:0.84rem;color:var(--text-sec);line-height:1.5;word-break:break-word}
.lb-comment-time{font-size:0.7rem;color:var(--text-mute);margin-top:3px}
.lb-no-comments{text-align:center;color:var(--text-mute);font-size:0.84rem;padding:22px 0}
.lb-comment-form{
display:flex;gap:8px;padding:11px 13px;
border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end
}
.lb-comment-input{
flex:1;background:var(--bg-input);border:1px solid var(--border);
border-radius:var(--radius-pill);color:var(--text-pri);font-size:0.855rem;
font-family:'Inter',sans-serif;padding:8px 13px;outline:none;resize:none;
max-height:84px;min-height:36px;line-height:1.4;
transition:border-color var(--transition),box-shadow var(--transition)
}
.lb-comment-input:focus{
border-color:var(--brand);
box-shadow:0 0 0 3px rgba(216,8,101,0.08)
}
.lb-comment-input::placeholder{color:var(--text-mute)}
.lb-send-btn{
width:36px;height:36px;border-radius:50%;border:none;
background:var(--brand);
color:#fff;font-size:0.97rem;cursor:pointer;
display:flex;align-items:center;justify-content:center;flex-shrink:0;
transition:background var(--transition),transform var(--transition)
}
.lb-send-btn:hover{background:var(--brand-hover);transform:scale(1.07)}
.lb-send-btn:active{transform:scale(0.94)}

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media(max-width:900px){
.dashboard-layout{grid-template-columns:1fr}
.sidebar-column{position:static}
.gallery-layout{grid-template-columns:1fr}
.filter-card{position:static}
.parties-grid{grid-template-columns:repeat(2,1fr)}
.gallery-grid{columns:3 180px}
.chat-layout{grid-template-columns:1fr}
.chat-sidebar{display:none}
}
@media(max-width:600px){
.nav-links{display:none}
.parties-grid{grid-template-columns:1fr}
.gallery-grid{columns:2}
.dashboard-layout,.page-layout{padding:12px}
}
/* On narrow screens: stack vertically, image on top, comments below */
@media(max-width:700px){
.lightbox-inner{flex-direction:column;height:96vh;width:96vw}
.lb-image-panel{flex:0 0 52vw;min-height:200px}
.lb-side-panel{width:100%;flex:1 1 0;border-left:none;border-top:1px solid var(--border)}
.lb-close{top:8px;right:8px}
.lb-nav-btn{width:36px;height:36px}
.lb-prev{left:8px}
.lb-next{right:8px}
}

/* ══════════════════════════════════
   LUCIDE ICONS
══════════════════════════════════ */
.nav-icon{
width:16px;height:16px;
stroke:currentColor;fill:none;stroke-width:1.8;
display:inline-flex;align-items:center;
vertical-align:middle;margin-top:-2px
}
.nav-icon svg{width:16px;height:16px}
.brand-icon-wrap{
display:flex;align-items:center;
color:var(--brand)
}
.brand-icon-wrap svg,.brand-icon-wrap i{
width:22px;height:22px;
stroke:var(--brand);
fill:none;stroke-width:2
}
.brand-icon-svg{
width:22px;height:22px;
stroke:var(--brand);
fill:none;stroke-width:2.2;display:block
}
i[data-lucide]{
display:inline-flex;align-items:center;
justify-content:center;vertical-align:middle
}
i[data-lucide] svg{display:block}
.nav-link i[data-lucide] svg{stroke:currentColor;fill:none}
.ghost-btn i[data-lucide]{width:14px;height:14px;margin-top:-1px}
.ghost-btn i[data-lucide] svg{stroke:currentColor;fill:none;stroke-width:1.8}
.floating-messages-btn i[data-lucide] svg{stroke:white;fill:none;stroke-width:1.8}
.send-btn i[data-lucide] svg,.lb-send-btn i[data-lucide] svg{stroke:white;fill:none;stroke-width:1.8}
.match-icon i[data-lucide] svg{stroke:white;fill:white;stroke-width:1.5}

/* ══════════════════════════════════
   AVATAR SYSTEM
══════════════════════════════════ */
.avatar-img,
.post-avatar,
.chat-avatar,
.msg-avatar,
.nearby-avatar,
.viewer-avatar,
.lb-poster-avatar,
.lb-comment-avatar,
.profile-avatar,
img[class*="avatar"]{
border-radius:50%;
object-fit:cover;
background:transparent;
transition:box-shadow 0.22s ease,transform 0.22s ease
}
.avatar-img:hover,
.post-avatar:hover,
.chat-avatar:hover,
img[class*="avatar"]:hover{
transform:scale(1.04)
}
.profile-avatar{
box-shadow:0 0 0 3px rgba(216,8,101,0.3),0 4px 16px rgba(0,0,0,0.12) !important
}
.online-dot,.chat-online-dot,.nearby-online{
position:absolute;
background:var(--online);
border:2px solid var(--bg-card);
border-radius:50%
}
@keyframes pulse-online{
0%,100%{box-shadow:0 0 5px rgba(34,197,94,0.5)}
50%{box-shadow:0 0 12px rgba(34,197,94,0.8)}
}
.feed-post .post-avatar{width:40px;height:40px;flex-shrink:0}
.nm-stacked-avatar,.msc-list-avatar{
border:2px solid var(--bg-card);
outline:none !important
}
.lb-poster-avatar{
box-shadow:0 0 0 2px rgba(216,8,101,0.3),0 4px 12px rgba(0,0,0,0.12) !important
}
.viewer-avatar{width:48px;height:48px}
.viewer-item:hover .viewer-avatar{transform:scale(1.06) translateY(-2px)}
.match-media img:not(.match-hero-avatar){
border-radius:0 !important;
box-shadow:none !important;
outline:none !important;
transform:none !important
}
.chat-avatar{width:44px;height:44px}
.msg-avatar{width:32px;height:32px;flex-shrink:0}
.match-hero-initials{
width:96px;height:96px;border-radius:50%;
display:flex;align-items:center;justify-content:center;
font-family:'Space Grotesk','Inter',sans-serif;
font-size:2.1rem;font-weight:700;letter-spacing:0.04em;
color:#fff;
background:var(--brand);
box-shadow:
  0 0 0 3px rgba(216,8,101,0.25),
  0 8px 22px rgba(216,8,101,0.2);
position:relative;z-index:1;
transition:transform 0.28s ease,box-shadow 0.28s ease;
user-select:none
}
.match-card:hover .match-hero-initials{
transform:scale(1.05);
box-shadow:
  0 0 0 3px var(--brand),
  0 0 40px rgba(216,8,101,0.25),
  0 12px 28px rgba(0,0,0,0.14)
}
img[src*="dicebear.com/7.x/initials"]{image-rendering:crisp-edges;background:transparent !important}

/* ══════════════════════════════════
   SITE FOOTER
══════════════════════════════════ */
.site-footer{
background:var(--brand);
color:#fff;
margin-top:60px
}
.footer-inner{
max-width:1240px;margin:0 auto;
padding:48px 28px 32px;
display:grid;
grid-template-columns:1.4fr 1fr 1fr;
gap:40px
}
.footer-brand{display:inline-block;margin-bottom:14px}
.footer-logo{
height:36px;width:auto;
filter:brightness(0) invert(1);
display:block
}
.footer-tagline{
font-size:0.87rem;
color:rgba(255,255,255,0.7);
line-height:1.6;
margin-top:0
}
.footer-heading{
font-size:0.78rem;font-weight:700;
text-transform:uppercase;letter-spacing:0.09em;
color:rgba(255,255,255,0.55);
margin-bottom:14px
}
.footer-nav{
display:flex;flex-direction:column;gap:10px
}
.footer-nav a{
font-size:0.875rem;
color:rgba(255,255,255,0.82);
text-decoration:none;
transition:color 0.18s
}
.footer-nav a:hover{color:#fff}
.footer-bottom{
border-top:1px solid rgba(255,255,255,0.15);
text-align:center;
padding:18px 28px
}
.footer-bottom p{
font-size:0.8rem;
color:rgba(255,255,255,0.5);
margin:0;line-height:1
}

/* ══════════════════════════════════
   RESPONSIVE FIXES
══════════════════════════════════ */
/* Prevent horizontal overflow globally */
html,body{max-width:100%;overflow-x:hidden}
/* box-sizing only — do NOT override max-width:1240px set above */
.page-layout{box-sizing:border-box}
.gallery-layout{max-width:100%;box-sizing:border-box}
.dashboard-layout{box-sizing:border-box}

/* Member cards / profile cards responsive */
.member-card,.profile-stats,.profile-info-section{max-width:100%}

@media(max-width:1024px){
.dashboard-layout{grid-template-columns:1fr 280px;padding:16px 16px}
.page-layout{padding:16px 16px}
.gallery-layout{grid-template-columns:220px 1fr;gap:16px}
.parties-grid{grid-template-columns:repeat(2,1fr)}
.footer-inner{grid-template-columns:1fr 1fr;gap:28px}
}

@media(max-width:768px){
/* Nav */
.nav-inner{padding:0 14px;gap:10px}
.nav-links{display:none}
/* Layouts */
.dashboard-layout{
  grid-template-columns:1fr;
  padding:12px 12px;
  gap:14px
}
.sidebar-column{display:none}
.page-layout{padding:12px 12px}
.gallery-layout{
  grid-template-columns:1fr;
  gap:12px
}
.filter-card{display:none}
.browse-layout{grid-template-columns:1fr !important;padding:12px !important}
.filter-sidebar{display:none}
/* Profile page */
.profile-info-section{flex-direction:column;gap:14px;padding:14px}
.profile-avatar-wrap{margin-top:-48px}
.profile-avatar{width:90px;height:90px}
.profile-actions{flex-wrap:wrap}
.profile-stats-row{gap:14px}
/* Cards */
.parties-grid{grid-template-columns:1fr}
.gallery-grid{columns:2}
.viewers-row{grid-template-columns:repeat(3,1fr)}
/* Footer */
.footer-inner{
  grid-template-columns:1fr;
  gap:28px;
  padding:32px 20px 24px
}
.footer-bottom{padding:14px 20px}
/* Profile tab grid */
#tab-content-about > div[style*="grid-template-columns"]{
  display:flex !important;
  flex-direction:column !important
}
}

@media(max-width:480px){
.nav-brand .nav-logo{height:26px}
.gallery-grid{columns:2}
.parties-grid{grid-template-columns:1fr}
.party-card{max-width:100%}
.search-filters{flex-direction:column}
.footer-inner{padding:24px 16px 20px}
}
